% TIMEFORMAT='%3R'; { time (exec 2>&1; /home/martin/bin/satallax -E /home/martin/.isabelle/contrib/e-2.5-1/x86_64-linux/eprover -p tstp -t 5 /home/martin/judgement-day/tptp-thf/tptp/FFT/prob_366__3226100_1 ) ; }
% This file was generated by Isabelle (most likely Sledgehammer)
% 2020-12-16 14:10:47.348

% Could-be-implicit typings (4)
thf(ty_n_t__Set__Oset_It__Nat__Onat_J, type,
    set_nat : $tType).
thf(ty_n_t__Complex__Ocomplex, type,
    complex : $tType).
thf(ty_n_t__Num__Onum, type,
    num : $tType).
thf(ty_n_t__Nat__Onat, type,
    nat : $tType).

% Explicit typings (24)
thf(sy_c_FFT__Mirabelle__ulikgskiun_Oroot, type,
    fFT_Mirabelle_root : nat > complex).
thf(sy_c_Groups_Otimes__class_Otimes_001t__Complex__Ocomplex, type,
    times_times_complex : complex > complex > complex).
thf(sy_c_Groups_Otimes__class_Otimes_001t__Nat__Onat, type,
    times_times_nat : nat > nat > nat).
thf(sy_c_Groups_Otimes__class_Otimes_001t__Num__Onum, type,
    times_times_num : num > num > num).
thf(sy_c_Groups_Ozero__class_Ozero_001t__Complex__Ocomplex, type,
    zero_zero_complex : complex).
thf(sy_c_Groups_Ozero__class_Ozero_001t__Nat__Onat, type,
    zero_zero_nat : nat).
thf(sy_c_Groups__Big_Ocomm__monoid__add__class_Osum_001t__Nat__Onat_001t__Complex__Ocomplex, type,
    groups59700922omplex : (nat > complex) > set_nat > complex).
thf(sy_c_Nat_OSuc, type,
    suc : nat > nat).
thf(sy_c_Num_Onum_OBit0, type,
    bit0 : num > num).
thf(sy_c_Num_Onum_OOne, type,
    one : num).
thf(sy_c_Num_Onumeral__class_Onumeral_001t__Complex__Ocomplex, type,
    numera632737353omplex : num > complex).
thf(sy_c_Num_Onumeral__class_Onumeral_001t__Nat__Onat, type,
    numeral_numeral_nat : num > nat).
thf(sy_c_Orderings_Oord__class_Oless_001t__Nat__Onat, type,
    ord_less_nat : nat > nat > $o).
thf(sy_c_Orderings_Oord__class_Oless_001t__Num__Onum, type,
    ord_less_num : num > num > $o).
thf(sy_c_Orderings_Oord__class_Oless__eq_001t__Nat__Onat, type,
    ord_less_eq_nat : nat > nat > $o).
thf(sy_c_Orderings_Oord__class_Oless__eq_001t__Num__Onum, type,
    ord_less_eq_num : num > num > $o).
thf(sy_c_Power_Opower__class_Opower_001t__Complex__Ocomplex, type,
    power_power_complex : complex > nat > complex).
thf(sy_c_Power_Opower__class_Opower_001t__Nat__Onat, type,
    power_power_nat : nat > nat > nat).
thf(sy_c_Rings_Odivide__class_Odivide_001t__Complex__Ocomplex, type,
    divide1210191872omplex : complex > complex > complex).
thf(sy_c_Rings_Odivide__class_Odivide_001t__Nat__Onat, type,
    divide_divide_nat : nat > nat > nat).
thf(sy_c_Set__Interval_Oord__class_OatLeastLessThan_001t__Nat__Onat, type,
    set_or562006527an_nat : nat > nat > set_nat).
thf(sy_v_a, type,
    a : nat > complex).
thf(sy_v_i, type,
    i : nat).
thf(sy_v_m, type,
    m : nat).

% Relevant facts (153)
thf(fact_0_mbound, axiom,
    ((ord_less_nat @ zero_zero_nat @ m))). % mbound
thf(fact_1_ibound, axiom,
    ((ord_less_eq_nat @ m @ i))). % ibound
thf(fact_2_root__cancel1, axiom,
    ((![M : nat, I : nat, J : nat]: ((power_power_complex @ (fFT_Mirabelle_root @ (times_times_nat @ (numeral_numeral_nat @ (bit0 @ one)) @ M)) @ (times_times_nat @ I @ (times_times_nat @ (numeral_numeral_nat @ (bit0 @ one)) @ J))) = (power_power_complex @ (fFT_Mirabelle_root @ M) @ (times_times_nat @ I @ J)))))). % root_cancel1
thf(fact_3_zero__eq__power2, axiom,
    ((![A : complex]: (((power_power_complex @ A @ (numeral_numeral_nat @ (bit0 @ one))) = zero_zero_complex) = (A = zero_zero_complex))))). % zero_eq_power2
thf(fact_4_zero__eq__power2, axiom,
    ((![A : nat]: (((power_power_nat @ A @ (numeral_numeral_nat @ (bit0 @ one))) = zero_zero_nat) = (A = zero_zero_nat))))). % zero_eq_power2
thf(fact_5_divide__eq__eq__numeral1_I1_J, axiom,
    ((![B : complex, W : num, A : complex]: (((divide1210191872omplex @ B @ (numera632737353omplex @ W)) = A) = (((((~ (((numera632737353omplex @ W) = zero_zero_complex)))) => ((B = (times_times_complex @ A @ (numera632737353omplex @ W)))))) & (((((numera632737353omplex @ W) = zero_zero_complex)) => ((A = zero_zero_complex))))))))). % divide_eq_eq_numeral1(1)
thf(fact_6_eq__divide__eq__numeral1_I1_J, axiom,
    ((![A : complex, B : complex, W : num]: ((A = (divide1210191872omplex @ B @ (numera632737353omplex @ W))) = (((((~ (((numera632737353omplex @ W) = zero_zero_complex)))) => (((times_times_complex @ A @ (numera632737353omplex @ W)) = B)))) & (((((numera632737353omplex @ W) = zero_zero_complex)) => ((A = zero_zero_complex))))))))). % eq_divide_eq_numeral1(1)
thf(fact_7_mult__eq__1__iff, axiom,
    ((![M : nat, N : nat]: (((times_times_nat @ M @ N) = (suc @ zero_zero_nat)) = (((M = (suc @ zero_zero_nat))) & ((N = (suc @ zero_zero_nat)))))))). % mult_eq_1_iff
thf(fact_8_one__eq__mult__iff, axiom,
    ((![M : nat, N : nat]: (((suc @ zero_zero_nat) = (times_times_nat @ M @ N)) = (((M = (suc @ zero_zero_nat))) & ((N = (suc @ zero_zero_nat)))))))). % one_eq_mult_iff
thf(fact_9_power__Suc0__right, axiom,
    ((![A : complex]: ((power_power_complex @ A @ (suc @ zero_zero_nat)) = A)))). % power_Suc0_right
thf(fact_10_power__Suc0__right, axiom,
    ((![A : nat]: ((power_power_nat @ A @ (suc @ zero_zero_nat)) = A)))). % power_Suc0_right
thf(fact_11_power__zero__numeral, axiom,
    ((![K : num]: ((power_power_complex @ zero_zero_complex @ (numeral_numeral_nat @ K)) = zero_zero_complex)))). % power_zero_numeral
thf(fact_12_power__zero__numeral, axiom,
    ((![K : num]: ((power_power_nat @ zero_zero_nat @ (numeral_numeral_nat @ K)) = zero_zero_nat)))). % power_zero_numeral
thf(fact_13_power__0__Suc, axiom,
    ((![N : nat]: ((power_power_complex @ zero_zero_complex @ (suc @ N)) = zero_zero_complex)))). % power_0_Suc
thf(fact_14_power__0__Suc, axiom,
    ((![N : nat]: ((power_power_nat @ zero_zero_nat @ (suc @ N)) = zero_zero_nat)))). % power_0_Suc
thf(fact_15_mult__divide__mult__cancel__left__if, axiom,
    ((![C : complex, A : complex, B : complex]: (((C = zero_zero_complex) => ((divide1210191872omplex @ (times_times_complex @ C @ A) @ (times_times_complex @ C @ B)) = zero_zero_complex)) & ((~ ((C = zero_zero_complex))) => ((divide1210191872omplex @ (times_times_complex @ C @ A) @ (times_times_complex @ C @ B)) = (divide1210191872omplex @ A @ B))))))). % mult_divide_mult_cancel_left_if
thf(fact_16_nonzero__mult__divide__mult__cancel__left, axiom,
    ((![C : complex, A : complex, B : complex]: ((~ ((C = zero_zero_complex))) => ((divide1210191872omplex @ (times_times_complex @ C @ A) @ (times_times_complex @ C @ B)) = (divide1210191872omplex @ A @ B)))))). % nonzero_mult_divide_mult_cancel_left
thf(fact_17_nonzero__mult__div__cancel__left, axiom,
    ((![A : nat, B : nat]: ((~ ((A = zero_zero_nat))) => ((divide_divide_nat @ (times_times_nat @ A @ B) @ A) = B))))). % nonzero_mult_div_cancel_left
thf(fact_18_nonzero__mult__div__cancel__left, axiom,
    ((![A : complex, B : complex]: ((~ ((A = zero_zero_complex))) => ((divide1210191872omplex @ (times_times_complex @ A @ B) @ A) = B))))). % nonzero_mult_div_cancel_left
thf(fact_19_nonzero__mult__divide__mult__cancel__left2, axiom,
    ((![C : complex, A : complex, B : complex]: ((~ ((C = zero_zero_complex))) => ((divide1210191872omplex @ (times_times_complex @ C @ A) @ (times_times_complex @ B @ C)) = (divide1210191872omplex @ A @ B)))))). % nonzero_mult_divide_mult_cancel_left2
thf(fact_20_numeral__eq__iff, axiom,
    ((![M : num, N : num]: (((numeral_numeral_nat @ M) = (numeral_numeral_nat @ N)) = (M = N))))). % numeral_eq_iff
thf(fact_21_numeral__eq__iff, axiom,
    ((![M : num, N : num]: (((numera632737353omplex @ M) = (numera632737353omplex @ N)) = (M = N))))). % numeral_eq_iff
thf(fact_22_old_Onat_Oinject, axiom,
    ((![Nat : nat, Nat2 : nat]: (((suc @ Nat) = (suc @ Nat2)) = (Nat = Nat2))))). % old.nat.inject
thf(fact_23_nat_Oinject, axiom,
    ((![X2 : nat, Y2 : nat]: (((suc @ X2) = (suc @ Y2)) = (X2 = Y2))))). % nat.inject
thf(fact_24_mult__cancel__right, axiom,
    ((![A : nat, C : nat, B : nat]: (((times_times_nat @ A @ C) = (times_times_nat @ B @ C)) = (((C = zero_zero_nat)) | ((A = B))))))). % mult_cancel_right
thf(fact_25_mult__cancel__right, axiom,
    ((![A : complex, C : complex, B : complex]: (((times_times_complex @ A @ C) = (times_times_complex @ B @ C)) = (((C = zero_zero_complex)) | ((A = B))))))). % mult_cancel_right
thf(fact_26_mult__cancel__left, axiom,
    ((![C : nat, A : nat, B : nat]: (((times_times_nat @ C @ A) = (times_times_nat @ C @ B)) = (((C = zero_zero_nat)) | ((A = B))))))). % mult_cancel_left
thf(fact_27_mult__cancel__left, axiom,
    ((![C : complex, A : complex, B : complex]: (((times_times_complex @ C @ A) = (times_times_complex @ C @ B)) = (((C = zero_zero_complex)) | ((A = B))))))). % mult_cancel_left
thf(fact_28_mult__eq__0__iff, axiom,
    ((![A : nat, B : nat]: (((times_times_nat @ A @ B) = zero_zero_nat) = (((A = zero_zero_nat)) | ((B = zero_zero_nat))))))). % mult_eq_0_iff
thf(fact_29_mult__eq__0__iff, axiom,
    ((![A : complex, B : complex]: (((times_times_complex @ A @ B) = zero_zero_complex) = (((A = zero_zero_complex)) | ((B = zero_zero_complex))))))). % mult_eq_0_iff
thf(fact_30_mult__zero__right, axiom,
    ((![A : nat]: ((times_times_nat @ A @ zero_zero_nat) = zero_zero_nat)))). % mult_zero_right
thf(fact_31_mult__zero__right, axiom,
    ((![A : complex]: ((times_times_complex @ A @ zero_zero_complex) = zero_zero_complex)))). % mult_zero_right
thf(fact_32_mult__zero__left, axiom,
    ((![A : nat]: ((times_times_nat @ zero_zero_nat @ A) = zero_zero_nat)))). % mult_zero_left
thf(fact_33_mult__zero__left, axiom,
    ((![A : complex]: ((times_times_complex @ zero_zero_complex @ A) = zero_zero_complex)))). % mult_zero_left
thf(fact_34_numeral__le__iff, axiom,
    ((![M : num, N : num]: ((ord_less_eq_nat @ (numeral_numeral_nat @ M) @ (numeral_numeral_nat @ N)) = (ord_less_eq_num @ M @ N))))). % numeral_le_iff
thf(fact_35_numeral__less__iff, axiom,
    ((![M : num, N : num]: ((ord_less_nat @ (numeral_numeral_nat @ M) @ (numeral_numeral_nat @ N)) = (ord_less_num @ M @ N))))). % numeral_less_iff
thf(fact_36_division__ring__divide__zero, axiom,
    ((![A : complex]: ((divide1210191872omplex @ A @ zero_zero_complex) = zero_zero_complex)))). % division_ring_divide_zero
thf(fact_37_divide__cancel__right, axiom,
    ((![A : complex, C : complex, B : complex]: (((divide1210191872omplex @ A @ C) = (divide1210191872omplex @ B @ C)) = (((C = zero_zero_complex)) | ((A = B))))))). % divide_cancel_right
thf(fact_38_divide__cancel__left, axiom,
    ((![C : complex, A : complex, B : complex]: (((divide1210191872omplex @ C @ A) = (divide1210191872omplex @ C @ B)) = (((C = zero_zero_complex)) | ((A = B))))))). % divide_cancel_left
thf(fact_39_div__by__0, axiom,
    ((![A : nat]: ((divide_divide_nat @ A @ zero_zero_nat) = zero_zero_nat)))). % div_by_0
thf(fact_40_div__by__0, axiom,
    ((![A : complex]: ((divide1210191872omplex @ A @ zero_zero_complex) = zero_zero_complex)))). % div_by_0
thf(fact_41_divide__eq__0__iff, axiom,
    ((![A : complex, B : complex]: (((divide1210191872omplex @ A @ B) = zero_zero_complex) = (((A = zero_zero_complex)) | ((B = zero_zero_complex))))))). % divide_eq_0_iff
thf(fact_42_div__0, axiom,
    ((![A : nat]: ((divide_divide_nat @ zero_zero_nat @ A) = zero_zero_nat)))). % div_0
thf(fact_43_div__0, axiom,
    ((![A : complex]: ((divide1210191872omplex @ zero_zero_complex @ A) = zero_zero_complex)))). % div_0
thf(fact_44_numeral__times__numeral, axiom,
    ((![M : num, N : num]: ((times_times_nat @ (numeral_numeral_nat @ M) @ (numeral_numeral_nat @ N)) = (numeral_numeral_nat @ (times_times_num @ M @ N)))))). % numeral_times_numeral
thf(fact_45_numeral__times__numeral, axiom,
    ((![M : num, N : num]: ((times_times_complex @ (numera632737353omplex @ M) @ (numera632737353omplex @ N)) = (numera632737353omplex @ (times_times_num @ M @ N)))))). % numeral_times_numeral
thf(fact_46_mult__numeral__left__semiring__numeral, axiom,
    ((![V : num, W : num, Z : nat]: ((times_times_nat @ (numeral_numeral_nat @ V) @ (times_times_nat @ (numeral_numeral_nat @ W) @ Z)) = (times_times_nat @ (numeral_numeral_nat @ (times_times_num @ V @ W)) @ Z))))). % mult_numeral_left_semiring_numeral
thf(fact_47_mult__numeral__left__semiring__numeral, axiom,
    ((![V : num, W : num, Z : complex]: ((times_times_complex @ (numera632737353omplex @ V) @ (times_times_complex @ (numera632737353omplex @ W) @ Z)) = (times_times_complex @ (numera632737353omplex @ (times_times_num @ V @ W)) @ Z))))). % mult_numeral_left_semiring_numeral
thf(fact_48_times__divide__eq__right, axiom,
    ((![A : complex, B : complex, C : complex]: ((times_times_complex @ A @ (divide1210191872omplex @ B @ C)) = (divide1210191872omplex @ (times_times_complex @ A @ B) @ C))))). % times_divide_eq_right
thf(fact_49_divide__divide__eq__right, axiom,
    ((![A : complex, B : complex, C : complex]: ((divide1210191872omplex @ A @ (divide1210191872omplex @ B @ C)) = (divide1210191872omplex @ (times_times_complex @ A @ C) @ B))))). % divide_divide_eq_right
thf(fact_50_divide__divide__eq__left, axiom,
    ((![A : complex, B : complex, C : complex]: ((divide1210191872omplex @ (divide1210191872omplex @ A @ B) @ C) = (divide1210191872omplex @ A @ (times_times_complex @ B @ C)))))). % divide_divide_eq_left
thf(fact_51_times__divide__eq__left, axiom,
    ((![B : complex, C : complex, A : complex]: ((times_times_complex @ (divide1210191872omplex @ B @ C) @ A) = (divide1210191872omplex @ (times_times_complex @ B @ A) @ C))))). % times_divide_eq_left
thf(fact_52_num__double, axiom,
    ((![N : num]: ((times_times_num @ (bit0 @ one) @ N) = (bit0 @ N))))). % num_double
thf(fact_53_nat__power__eq__Suc__0__iff, axiom,
    ((![X : nat, M : nat]: (((power_power_nat @ X @ M) = (suc @ zero_zero_nat)) = (((M = zero_zero_nat)) | ((X = (suc @ zero_zero_nat)))))))). % nat_power_eq_Suc_0_iff
thf(fact_54_power__Suc__0, axiom,
    ((![N : nat]: ((power_power_nat @ (suc @ zero_zero_nat) @ N) = (suc @ zero_zero_nat))))). % power_Suc_0
thf(fact_55_power__mult__numeral, axiom,
    ((![A : complex, M : num, N : num]: ((power_power_complex @ (power_power_complex @ A @ (numeral_numeral_nat @ M)) @ (numeral_numeral_nat @ N)) = (power_power_complex @ A @ (numeral_numeral_nat @ (times_times_num @ M @ N))))))). % power_mult_numeral
thf(fact_56_power__mult__numeral, axiom,
    ((![A : nat, M : num, N : num]: ((power_power_nat @ (power_power_nat @ A @ (numeral_numeral_nat @ M)) @ (numeral_numeral_nat @ N)) = (power_power_nat @ A @ (numeral_numeral_nat @ (times_times_num @ M @ N))))))). % power_mult_numeral
thf(fact_57_nat__zero__less__power__iff, axiom,
    ((![X : nat, N : nat]: ((ord_less_nat @ zero_zero_nat @ (power_power_nat @ X @ N)) = (((ord_less_nat @ zero_zero_nat @ X)) | ((N = zero_zero_nat))))))). % nat_zero_less_power_iff
thf(fact_58_bot__nat__0_Onot__eq__extremum, axiom,
    ((![A : nat]: ((~ ((A = zero_zero_nat))) = (ord_less_nat @ zero_zero_nat @ A))))). % bot_nat_0.not_eq_extremum
thf(fact_59_less__nat__zero__code, axiom,
    ((![N : nat]: (~ ((ord_less_nat @ N @ zero_zero_nat)))))). % less_nat_zero_code
thf(fact_60_neq0__conv, axiom,
    ((![N : nat]: ((~ ((N = zero_zero_nat))) = (ord_less_nat @ zero_zero_nat @ N))))). % neq0_conv
thf(fact_61_Suc__less__eq, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ (suc @ M) @ (suc @ N)) = (ord_less_nat @ M @ N))))). % Suc_less_eq
thf(fact_62_Suc__mono, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ M @ N) => (ord_less_nat @ (suc @ M) @ (suc @ N)))))). % Suc_mono
thf(fact_63_lessI, axiom,
    ((![N : nat]: (ord_less_nat @ N @ (suc @ N))))). % lessI
thf(fact_64_bot__nat__0_Oextremum, axiom,
    ((![A : nat]: (ord_less_eq_nat @ zero_zero_nat @ A)))). % bot_nat_0.extremum
thf(fact_65_le0, axiom,
    ((![N : nat]: (ord_less_eq_nat @ zero_zero_nat @ N)))). % le0
thf(fact_66_Suc__le__mono, axiom,
    ((![N : nat, M : nat]: ((ord_less_eq_nat @ (suc @ N) @ (suc @ M)) = (ord_less_eq_nat @ N @ M))))). % Suc_le_mono
thf(fact_67_mult__cancel2, axiom,
    ((![M : nat, K : nat, N : nat]: (((times_times_nat @ M @ K) = (times_times_nat @ N @ K)) = (((M = N)) | ((K = zero_zero_nat))))))). % mult_cancel2
thf(fact_68_mult__cancel1, axiom,
    ((![K : nat, M : nat, N : nat]: (((times_times_nat @ K @ M) = (times_times_nat @ K @ N)) = (((M = N)) | ((K = zero_zero_nat))))))). % mult_cancel1
thf(fact_69_mult__0__right, axiom,
    ((![M : nat]: ((times_times_nat @ M @ zero_zero_nat) = zero_zero_nat)))). % mult_0_right
thf(fact_70_mult__is__0, axiom,
    ((![M : nat, N : nat]: (((times_times_nat @ M @ N) = zero_zero_nat) = (((M = zero_zero_nat)) | ((N = zero_zero_nat))))))). % mult_is_0
thf(fact_71_nonzero__mult__divide__mult__cancel__right2, axiom,
    ((![C : complex, A : complex, B : complex]: ((~ ((C = zero_zero_complex))) => ((divide1210191872omplex @ (times_times_complex @ A @ C) @ (times_times_complex @ C @ B)) = (divide1210191872omplex @ A @ B)))))). % nonzero_mult_divide_mult_cancel_right2
thf(fact_72_nonzero__mult__div__cancel__right, axiom,
    ((![B : nat, A : nat]: ((~ ((B = zero_zero_nat))) => ((divide_divide_nat @ (times_times_nat @ A @ B) @ B) = A))))). % nonzero_mult_div_cancel_right
thf(fact_73_nonzero__mult__div__cancel__right, axiom,
    ((![B : complex, A : complex]: ((~ ((B = zero_zero_complex))) => ((divide1210191872omplex @ (times_times_complex @ A @ B) @ B) = A))))). % nonzero_mult_div_cancel_right
thf(fact_74_nonzero__mult__divide__mult__cancel__right, axiom,
    ((![C : complex, A : complex, B : complex]: ((~ ((C = zero_zero_complex))) => ((divide1210191872omplex @ (times_times_complex @ A @ C) @ (times_times_complex @ B @ C)) = (divide1210191872omplex @ A @ B)))))). % nonzero_mult_divide_mult_cancel_right
thf(fact_75_zero__less__Suc, axiom,
    ((![N : nat]: (ord_less_nat @ zero_zero_nat @ (suc @ N))))). % zero_less_Suc
thf(fact_76_less__Suc0, axiom,
    ((![N : nat]: ((ord_less_nat @ N @ (suc @ zero_zero_nat)) = (N = zero_zero_nat))))). % less_Suc0
thf(fact_77_nat__0__less__mult__iff, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ zero_zero_nat @ (times_times_nat @ M @ N)) = (((ord_less_nat @ zero_zero_nat @ M)) & ((ord_less_nat @ zero_zero_nat @ N))))))). % nat_0_less_mult_iff
thf(fact_78_mult__less__cancel2, axiom,
    ((![M : nat, K : nat, N : nat]: ((ord_less_nat @ (times_times_nat @ M @ K) @ (times_times_nat @ N @ K)) = (((ord_less_nat @ zero_zero_nat @ K)) & ((ord_less_nat @ M @ N))))))). % mult_less_cancel2
thf(fact_79_power__eq__0__iff, axiom,
    ((![A : complex, N : nat]: (((power_power_complex @ A @ N) = zero_zero_complex) = (((A = zero_zero_complex)) & ((ord_less_nat @ zero_zero_nat @ N))))))). % power_eq_0_iff
thf(fact_80_power__eq__0__iff, axiom,
    ((![A : nat, N : nat]: (((power_power_nat @ A @ N) = zero_zero_nat) = (((A = zero_zero_nat)) & ((ord_less_nat @ zero_zero_nat @ N))))))). % power_eq_0_iff
thf(fact_81_one__le__mult__iff, axiom,
    ((![M : nat, N : nat]: ((ord_less_eq_nat @ (suc @ zero_zero_nat) @ (times_times_nat @ M @ N)) = (((ord_less_eq_nat @ (suc @ zero_zero_nat) @ M)) & ((ord_less_eq_nat @ (suc @ zero_zero_nat) @ N))))))). % one_le_mult_iff
thf(fact_82_mult__le__cancel2, axiom,
    ((![M : nat, K : nat, N : nat]: ((ord_less_eq_nat @ (times_times_nat @ M @ K) @ (times_times_nat @ N @ K)) = (((ord_less_nat @ zero_zero_nat @ K)) => ((ord_less_eq_nat @ M @ N))))))). % mult_le_cancel2
thf(fact_83_power__mono__iff, axiom,
    ((![A : nat, B : nat, N : nat]: ((ord_less_eq_nat @ zero_zero_nat @ A) => ((ord_less_eq_nat @ zero_zero_nat @ B) => ((ord_less_nat @ zero_zero_nat @ N) => ((ord_less_eq_nat @ (power_power_nat @ A @ N) @ (power_power_nat @ B @ N)) = (ord_less_eq_nat @ A @ B)))))))). % power_mono_iff
thf(fact_84_power2__eq__iff__nonneg, axiom,
    ((![X : nat, Y : nat]: ((ord_less_eq_nat @ zero_zero_nat @ X) => ((ord_less_eq_nat @ zero_zero_nat @ Y) => (((power_power_nat @ X @ (numeral_numeral_nat @ (bit0 @ one))) = (power_power_nat @ Y @ (numeral_numeral_nat @ (bit0 @ one)))) = (X = Y))))))). % power2_eq_iff_nonneg
thf(fact_85_Suc__leI, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ M @ N) => (ord_less_eq_nat @ (suc @ M) @ N))))). % Suc_leI
thf(fact_86_le__refl, axiom,
    ((![N : nat]: (ord_less_eq_nat @ N @ N)))). % le_refl
thf(fact_87_le__trans, axiom,
    ((![I : nat, J : nat, K : nat]: ((ord_less_eq_nat @ I @ J) => ((ord_less_eq_nat @ J @ K) => (ord_less_eq_nat @ I @ K)))))). % le_trans
thf(fact_88_Suc__le__eq, axiom,
    ((![M : nat, N : nat]: ((ord_less_eq_nat @ (suc @ M) @ N) = (ord_less_nat @ M @ N))))). % Suc_le_eq
thf(fact_89_eq__imp__le, axiom,
    ((![M : nat, N : nat]: ((M = N) => (ord_less_eq_nat @ M @ N))))). % eq_imp_le
thf(fact_90_dec__induct, axiom,
    ((![I : nat, J : nat, P : nat > $o]: ((ord_less_eq_nat @ I @ J) => ((P @ I) => ((![N2 : nat]: ((ord_less_eq_nat @ I @ N2) => ((ord_less_nat @ N2 @ J) => ((P @ N2) => (P @ (suc @ N2)))))) => (P @ J))))))). % dec_induct
thf(fact_91_inc__induct, axiom,
    ((![I : nat, J : nat, P : nat > $o]: ((ord_less_eq_nat @ I @ J) => ((P @ J) => ((![N2 : nat]: ((ord_less_eq_nat @ I @ N2) => ((ord_less_nat @ N2 @ J) => ((P @ (suc @ N2)) => (P @ N2))))) => (P @ I))))))). % inc_induct
thf(fact_92_le__antisym, axiom,
    ((![M : nat, N : nat]: ((ord_less_eq_nat @ M @ N) => ((ord_less_eq_nat @ N @ M) => (M = N)))))). % le_antisym
thf(fact_93_nat__less__le, axiom,
    ((ord_less_nat = (^[M2 : nat]: (^[N3 : nat]: (((ord_less_eq_nat @ M2 @ N3)) & ((~ ((M2 = N3)))))))))). % nat_less_le
thf(fact_94_nat__neq__iff, axiom,
    ((![M : nat, N : nat]: ((~ ((M = N))) = (((ord_less_nat @ M @ N)) | ((ord_less_nat @ N @ M))))))). % nat_neq_iff
thf(fact_95_Suc__le__lessD, axiom,
    ((![M : nat, N : nat]: ((ord_less_eq_nat @ (suc @ M) @ N) => (ord_less_nat @ M @ N))))). % Suc_le_lessD
thf(fact_96_less__not__refl, axiom,
    ((![N : nat]: (~ ((ord_less_nat @ N @ N)))))). % less_not_refl
thf(fact_97_nat__le__linear, axiom,
    ((![M : nat, N : nat]: ((ord_less_eq_nat @ M @ N) | (ord_less_eq_nat @ N @ M))))). % nat_le_linear
thf(fact_98_le__less__Suc__eq, axiom,
    ((![M : nat, N : nat]: ((ord_less_eq_nat @ M @ N) => ((ord_less_nat @ N @ (suc @ M)) = (N = M)))))). % le_less_Suc_eq
thf(fact_99_less__Suc__eq__le, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ M @ (suc @ N)) = (ord_less_eq_nat @ M @ N))))). % less_Suc_eq_le
thf(fact_100_less__eq__Suc__le, axiom,
    ((ord_less_nat = (^[N3 : nat]: (ord_less_eq_nat @ (suc @ N3)))))). % less_eq_Suc_le
thf(fact_101_less__not__refl2, axiom,
    ((![N : nat, M : nat]: ((ord_less_nat @ N @ M) => (~ ((M = N))))))). % less_not_refl2
thf(fact_102_less__not__refl3, axiom,
    ((![S : nat, T : nat]: ((ord_less_nat @ S @ T) => (~ ((S = T))))))). % less_not_refl3
thf(fact_103_ex__least__nat__le, axiom,
    ((![P : nat > $o, N : nat]: ((P @ N) => ((~ ((P @ zero_zero_nat))) => (?[K2 : nat]: ((ord_less_eq_nat @ K2 @ N) & ((![I2 : nat]: ((ord_less_nat @ I2 @ K2) => (~ ((P @ I2))))) & (P @ K2))))))))). % ex_least_nat_le
thf(fact_104_le__imp__less__Suc, axiom,
    ((![M : nat, N : nat]: ((ord_less_eq_nat @ M @ N) => (ord_less_nat @ M @ (suc @ N)))))). % le_imp_less_Suc
thf(fact_105_less__imp__le__nat, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ M @ N) => (ord_less_eq_nat @ M @ N))))). % less_imp_le_nat
thf(fact_106_less__irrefl__nat, axiom,
    ((![N : nat]: (~ ((ord_less_nat @ N @ N)))))). % less_irrefl_nat
thf(fact_107_nat__less__induct, axiom,
    ((![P : nat > $o, N : nat]: ((![N2 : nat]: ((![M3 : nat]: ((ord_less_nat @ M3 @ N2) => (P @ M3))) => (P @ N2))) => (P @ N))))). % nat_less_induct
thf(fact_108_infinite__descent, axiom,
    ((![P : nat > $o, N : nat]: ((![N2 : nat]: ((~ ((P @ N2))) => (?[M3 : nat]: ((ord_less_nat @ M3 @ N2) & (~ ((P @ M3))))))) => (P @ N))))). % infinite_descent
thf(fact_109_le__eq__less__or__eq, axiom,
    ((ord_less_eq_nat = (^[M2 : nat]: (^[N3 : nat]: (((ord_less_nat @ M2 @ N3)) | ((M2 = N3)))))))). % le_eq_less_or_eq
thf(fact_110_less__or__eq__imp__le, axiom,
    ((![M : nat, N : nat]: (((ord_less_nat @ M @ N) | (M = N)) => (ord_less_eq_nat @ M @ N))))). % less_or_eq_imp_le
thf(fact_111_linorder__neqE__nat, axiom,
    ((![X : nat, Y : nat]: ((~ ((X = Y))) => ((~ ((ord_less_nat @ X @ Y))) => (ord_less_nat @ Y @ X)))))). % linorder_neqE_nat
thf(fact_112_Nat_Oex__has__greatest__nat, axiom,
    ((![P : nat > $o, K : nat, B : nat]: ((P @ K) => ((![Y3 : nat]: ((P @ Y3) => (ord_less_eq_nat @ Y3 @ B))) => (?[X3 : nat]: ((P @ X3) & (![Y4 : nat]: ((P @ Y4) => (ord_less_eq_nat @ Y4 @ X3)))))))))). % Nat.ex_has_greatest_nat
thf(fact_113_le__neq__implies__less, axiom,
    ((![M : nat, N : nat]: ((ord_less_eq_nat @ M @ N) => ((~ ((M = N))) => (ord_less_nat @ M @ N)))))). % le_neq_implies_less
thf(fact_114_less__mono__imp__le__mono, axiom,
    ((![F : nat > nat, I : nat, J : nat]: ((![I3 : nat, J2 : nat]: ((ord_less_nat @ I3 @ J2) => (ord_less_nat @ (F @ I3) @ (F @ J2)))) => ((ord_less_eq_nat @ I @ J) => (ord_less_eq_nat @ (F @ I) @ (F @ J))))))). % less_mono_imp_le_mono
thf(fact_115_nat__power__less__imp__less, axiom,
    ((![I : nat, M : nat, N : nat]: ((ord_less_nat @ zero_zero_nat @ I) => ((ord_less_nat @ (power_power_nat @ I @ M) @ (power_power_nat @ I @ N)) => (ord_less_nat @ M @ N)))))). % nat_power_less_imp_less
thf(fact_116_lift__Suc__mono__le, axiom,
    ((![F : nat > nat, N : nat, N4 : nat]: ((![N2 : nat]: (ord_less_eq_nat @ (F @ N2) @ (F @ (suc @ N2)))) => ((ord_less_eq_nat @ N @ N4) => (ord_less_eq_nat @ (F @ N) @ (F @ N4))))))). % lift_Suc_mono_le
thf(fact_117_lift__Suc__mono__less, axiom,
    ((![F : nat > nat, N : nat, N4 : nat]: ((![N2 : nat]: (ord_less_nat @ (F @ N2) @ (F @ (suc @ N2)))) => ((ord_less_nat @ N @ N4) => (ord_less_nat @ (F @ N) @ (F @ N4))))))). % lift_Suc_mono_less
thf(fact_118_lift__Suc__antimono__le, axiom,
    ((![F : nat > nat, N : nat, N4 : nat]: ((![N2 : nat]: (ord_less_eq_nat @ (F @ (suc @ N2)) @ (F @ N2))) => ((ord_less_eq_nat @ N @ N4) => (ord_less_eq_nat @ (F @ N4) @ (F @ N))))))). % lift_Suc_antimono_le
thf(fact_119_lift__Suc__mono__less__iff, axiom,
    ((![F : nat > nat, N : nat, M : nat]: ((![N2 : nat]: (ord_less_nat @ (F @ N2) @ (F @ (suc @ N2)))) => ((ord_less_nat @ (F @ N) @ (F @ M)) = (ord_less_nat @ N @ M)))))). % lift_Suc_mono_less_iff
thf(fact_120_less__numeral__extra_I3_J, axiom,
    ((~ ((ord_less_nat @ zero_zero_nat @ zero_zero_nat))))). % less_numeral_extra(3)
thf(fact_121_le__numeral__extra_I3_J, axiom,
    ((ord_less_eq_nat @ zero_zero_nat @ zero_zero_nat))). % le_numeral_extra(3)
thf(fact_122_bot__nat__0_Oextremum__strict, axiom,
    ((![A : nat]: (~ ((ord_less_nat @ A @ zero_zero_nat)))))). % bot_nat_0.extremum_strict
thf(fact_123_infinite__descent0, axiom,
    ((![P : nat > $o, N : nat]: ((P @ zero_zero_nat) => ((![N2 : nat]: ((ord_less_nat @ zero_zero_nat @ N2) => ((~ ((P @ N2))) => (?[M3 : nat]: ((ord_less_nat @ M3 @ N2) & (~ ((P @ M3)))))))) => (P @ N)))))). % infinite_descent0
thf(fact_124_gr__implies__not0, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ M @ N) => (~ ((N = zero_zero_nat))))))). % gr_implies_not0
thf(fact_125_less__zeroE, axiom,
    ((![N : nat]: (~ ((ord_less_nat @ N @ zero_zero_nat)))))). % less_zeroE
thf(fact_126_not__less0, axiom,
    ((![N : nat]: (~ ((ord_less_nat @ N @ zero_zero_nat)))))). % not_less0
thf(fact_127_not__gr0, axiom,
    ((![N : nat]: ((~ ((ord_less_nat @ zero_zero_nat @ N))) = (N = zero_zero_nat))))). % not_gr0
thf(fact_128_gr0I, axiom,
    ((![N : nat]: ((~ ((N = zero_zero_nat))) => (ord_less_nat @ zero_zero_nat @ N))))). % gr0I
thf(fact_129_not__less__less__Suc__eq, axiom,
    ((![N : nat, M : nat]: ((~ ((ord_less_nat @ N @ M))) => ((ord_less_nat @ N @ (suc @ M)) = (N = M)))))). % not_less_less_Suc_eq
thf(fact_130_strict__inc__induct, axiom,
    ((![I : nat, J : nat, P : nat > $o]: ((ord_less_nat @ I @ J) => ((![I3 : nat]: ((J = (suc @ I3)) => (P @ I3))) => ((![I3 : nat]: ((ord_less_nat @ I3 @ J) => ((P @ (suc @ I3)) => (P @ I3)))) => (P @ I))))))). % strict_inc_induct
thf(fact_131_less__Suc__induct, axiom,
    ((![I : nat, J : nat, P : nat > nat > $o]: ((ord_less_nat @ I @ J) => ((![I3 : nat]: (P @ I3 @ (suc @ I3))) => ((![I3 : nat, J2 : nat, K2 : nat]: ((ord_less_nat @ I3 @ J2) => ((ord_less_nat @ J2 @ K2) => ((P @ I3 @ J2) => ((P @ J2 @ K2) => (P @ I3 @ K2)))))) => (P @ I @ J))))))). % less_Suc_induct
thf(fact_132_less__trans__Suc, axiom,
    ((![I : nat, J : nat, K : nat]: ((ord_less_nat @ I @ J) => ((ord_less_nat @ J @ K) => (ord_less_nat @ (suc @ I) @ K)))))). % less_trans_Suc
thf(fact_133_Suc__less__SucD, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ (suc @ M) @ (suc @ N)) => (ord_less_nat @ M @ N))))). % Suc_less_SucD
thf(fact_134_less__antisym, axiom,
    ((![N : nat, M : nat]: ((~ ((ord_less_nat @ N @ M))) => ((ord_less_nat @ N @ (suc @ M)) => (M = N)))))). % less_antisym
thf(fact_135_Suc__less__eq2, axiom,
    ((![N : nat, M : nat]: ((ord_less_nat @ (suc @ N) @ M) = (?[M4 : nat]: (((M = (suc @ M4))) & ((ord_less_nat @ N @ M4)))))))). % Suc_less_eq2
thf(fact_136_All__less__Suc, axiom,
    ((![N : nat, P : nat > $o]: ((![I4 : nat]: (((ord_less_nat @ I4 @ (suc @ N))) => ((P @ I4)))) = (((P @ N)) & ((![I4 : nat]: (((ord_less_nat @ I4 @ N)) => ((P @ I4)))))))))). % All_less_Suc
thf(fact_137_not__less__eq, axiom,
    ((![M : nat, N : nat]: ((~ ((ord_less_nat @ M @ N))) = (ord_less_nat @ N @ (suc @ M)))))). % not_less_eq
thf(fact_138_less__Suc__eq, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ M @ (suc @ N)) = (((ord_less_nat @ M @ N)) | ((M = N))))))). % less_Suc_eq
thf(fact_139_Ex__less__Suc, axiom,
    ((![N : nat, P : nat > $o]: ((?[I4 : nat]: (((ord_less_nat @ I4 @ (suc @ N))) & ((P @ I4)))) = (((P @ N)) | ((?[I4 : nat]: (((ord_less_nat @ I4 @ N)) & ((P @ I4)))))))))). % Ex_less_Suc
thf(fact_140_less__SucI, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ M @ N) => (ord_less_nat @ M @ (suc @ N)))))). % less_SucI
thf(fact_141_less__SucE, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ M @ (suc @ N)) => ((~ ((ord_less_nat @ M @ N))) => (M = N)))))). % less_SucE
thf(fact_142_Suc__lessI, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ M @ N) => ((~ (((suc @ M) = N))) => (ord_less_nat @ (suc @ M) @ N)))))). % Suc_lessI
thf(fact_143_Suc__lessE, axiom,
    ((![I : nat, K : nat]: ((ord_less_nat @ (suc @ I) @ K) => (~ ((![J2 : nat]: ((ord_less_nat @ I @ J2) => (~ ((K = (suc @ J2)))))))))))). % Suc_lessE
thf(fact_144_Suc__lessD, axiom,
    ((![M : nat, N : nat]: ((ord_less_nat @ (suc @ M) @ N) => (ord_less_nat @ M @ N))))). % Suc_lessD
thf(fact_145_Nat_OlessE, axiom,
    ((![I : nat, K : nat]: ((ord_less_nat @ I @ K) => ((~ ((K = (suc @ I)))) => (~ ((![J2 : nat]: ((ord_less_nat @ I @ J2) => (~ ((K = (suc @ J2))))))))))))). % Nat.lessE
thf(fact_146_bot__nat__0_Oextremum__uniqueI, axiom,
    ((![A : nat]: ((ord_less_eq_nat @ A @ zero_zero_nat) => (A = zero_zero_nat))))). % bot_nat_0.extremum_uniqueI
thf(fact_147_bot__nat__0_Oextremum__unique, axiom,
    ((![A : nat]: ((ord_less_eq_nat @ A @ zero_zero_nat) = (A = zero_zero_nat))))). % bot_nat_0.extremum_unique
thf(fact_148_le__0__eq, axiom,
    ((![N : nat]: ((ord_less_eq_nat @ N @ zero_zero_nat) = (N = zero_zero_nat))))). % le_0_eq
thf(fact_149_less__eq__nat_Osimps_I1_J, axiom,
    ((![N : nat]: (ord_less_eq_nat @ zero_zero_nat @ N)))). % less_eq_nat.simps(1)
thf(fact_150_transitive__stepwise__le, axiom,
    ((![M : nat, N : nat, R : nat > nat > $o]: ((ord_less_eq_nat @ M @ N) => ((![X3 : nat]: (R @ X3 @ X3)) => ((![X3 : nat, Y3 : nat, Z2 : nat]: ((R @ X3 @ Y3) => ((R @ Y3 @ Z2) => (R @ X3 @ Z2)))) => ((![N2 : nat]: (R @ N2 @ (suc @ N2))) => (R @ M @ N)))))))). % transitive_stepwise_le
thf(fact_151_nat__induct__at__least, axiom,
    ((![M : nat, N : nat, P : nat > $o]: ((ord_less_eq_nat @ M @ N) => ((P @ M) => ((![N2 : nat]: ((ord_less_eq_nat @ M @ N2) => ((P @ N2) => (P @ (suc @ N2))))) => (P @ N))))))). % nat_induct_at_least
thf(fact_152_full__nat__induct, axiom,
    ((![P : nat > $o, N : nat]: ((![N2 : nat]: ((![M3 : nat]: ((ord_less_eq_nat @ (suc @ M3) @ N2) => (P @ M3))) => (P @ N2))) => (P @ N))))). % full_nat_induct

% Conjectures (1)
thf(conj_0, conjecture,
    (((groups59700922omplex @ (^[J3 : nat]: (divide1210191872omplex @ (a @ (suc @ (times_times_nat @ (numeral_numeral_nat @ (bit0 @ one)) @ J3))) @ (times_times_complex @ (power_power_complex @ (fFT_Mirabelle_root @ (times_times_nat @ (numeral_numeral_nat @ (bit0 @ one)) @ m)) @ i) @ (power_power_complex @ (fFT_Mirabelle_root @ (times_times_nat @ (numeral_numeral_nat @ (bit0 @ one)) @ m)) @ (times_times_nat @ i @ (times_times_nat @ (numeral_numeral_nat @ (bit0 @ one)) @ J3)))))) @ (set_or562006527an_nat @ zero_zero_nat @ m)) = (groups59700922omplex @ (^[N3 : nat]: (divide1210191872omplex @ (a @ (suc @ (times_times_nat @ (numeral_numeral_nat @ (bit0 @ one)) @ N3))) @ (times_times_complex @ (power_power_complex @ (power_power_complex @ (fFT_Mirabelle_root @ m) @ i) @ N3) @ (power_power_complex @ (fFT_Mirabelle_root @ (times_times_nat @ (numeral_numeral_nat @ (bit0 @ one)) @ m)) @ i)))) @ (set_or562006527an_nat @ zero_zero_nat @ m))))).
