%   ORIGINAL: h4/bag/SET__OF__BAG__IMAGE
% Assm: HL_TRUTH: T
% Assm: HL_FALSITY: ~F
% Assm: HL_BOOL_CASES: !t. (t <=> T) \/ (t <=> F)
% Assm: HL_EXT: !f g. (!x. f x = g x) ==> f = g
% Assm: h4/bool/BOOL__CASES__AX: !t. (t <=> T) \/ (t <=> F)
% Assm: h4/bool/TRUTH: T
% Assm: h4/bool/IMP__ANTISYM__AX: !t2 t1. (t1 ==> t2) ==> (t2 ==> t1) ==> (t1 <=> t2)
% Assm: h4/bool/FALSITY: !t. F ==> t
% Assm: h4/bool/EXCLUDED__MIDDLE: !t. t \/ ~t
% Assm: h4/bool/LET__THM: !x f. h4/bool/LET f x = f x
% Assm: h4/bool/FORALL__SIMP: !t. (!x. t) <=> t
% Assm: h4/bool/IMP__F: !t. (t ==> F) ==> ~t
% Assm: h4/bool/F__IMP: !t. ~t ==> t ==> F
% Assm: h4/bool/AND__CLAUSES_c0: !t. T /\ t <=> t
% Assm: h4/bool/AND__CLAUSES_c3: !t. t /\ F <=> F
% Assm: h4/bool/OR__CLAUSES_c0: !t. T \/ t <=> T
% Assm: h4/bool/OR__CLAUSES_c2: !t. F \/ t <=> t
% Assm: h4/bool/IMP__CLAUSES_c2: !t. F ==> t <=> T
% Assm: h4/bool/IMP__CLAUSES_c4: !t. t ==> F <=> ~t
% Assm: h4/bool/NOT__CLAUSES_c0: !t. ~ ~t <=> t
% Assm: h4/bool/NOT__CLAUSES_c1: ~T <=> F
% Assm: h4/bool/NOT__CLAUSES_c2: ~F <=> T
% Assm: h4/bool/REFL__CLAUSE: !x. x = x <=> T
% Assm: h4/bool/EQ__SYM__EQ: !y x. x = y <=> y = x
% Assm: h4/bool/EQ__CLAUSES_c0: !t. (T <=> t) <=> t
% Assm: h4/bool/EQ__CLAUSES_c1: !t. (t <=> T) <=> t
% Assm: h4/bool/EQ__CLAUSES_c2: !t. (F <=> t) <=> ~t
% Assm: h4/bool/EQ__CLAUSES_c3: !t. (t <=> F) <=> ~t
% Assm: h4/bool/COND__CLAUSES_c0: !t2 t1. h4/bool/COND T t1 t2 = t1
% Assm: h4/bool/COND__CLAUSES_c1: !t2 t1. h4/bool/COND F t1 t2 = t2
% Assm: h4/bool/NOT__FORALL__THM: !P. ~(!x. P x) <=> (?x. ~P x)
% Assm: h4/bool/NOT__EXISTS__THM: !P. ~(?x. P x) <=> (!x. ~P x)
% Assm: h4/bool/RIGHT__FORALL__OR__THM: !Q P. (!x. P \/ Q x) <=> P \/ (!x. Q x)
% Assm: h4/bool/NOT__IMP: !B A. ~(A ==> B) <=> A /\ ~B
% Assm: h4/bool/DISJ__ASSOC: !C B A. A \/ B \/ C <=> (A \/ B) \/ C
% Assm: h4/bool/DISJ__SYM: !B A. A \/ B <=> B \/ A
% Assm: h4/bool/DE__MORGAN__THM_c0: !B A. ~(A /\ B) <=> ~A \/ ~B
% Assm: h4/bool/DE__MORGAN__THM_c1: !B A. ~(A \/ B) <=> ~A /\ ~B
% Assm: h4/bool/IMP__F__EQ__F: !t. t ==> F <=> t <=> F
% Assm: h4/bool/AND__IMP__INTRO: !t3 t2 t1. t1 ==> t2 ==> t3 <=> t1 /\ t2 ==> t3
% Assm: h4/bool/IMP__CONG: !y_27 y x_27 x. (x <=> x_27) /\ (x_27 ==> (y <=> y_27)) ==> (x ==> y <=> x_27 ==> y_27)
% Assm: h4/sat/NOT__NOT: !t. ~ ~t <=> t
% Assm: h4/sat/AND__INV__IMP: !A. A ==> ~A ==> F
% Assm: h4/sat/OR__DUAL2: !B A. ~(A \/ B) ==> F <=> (A ==> F) ==> ~B ==> F
% Assm: h4/sat/OR__DUAL3: !B A. ~(~A \/ B) ==> F <=> A ==> ~B ==> F
% Assm: h4/sat/AND__INV2: !A. (~A ==> F) ==> (A ==> F) ==> F
% Assm: h4/sat/dc__eq: !r q p. (p <=> q <=> r) <=> (p \/ q \/ r) /\ (p \/ ~r \/ ~q) /\ (q \/ ~r \/ ~p) /\ (r \/ ~q \/ ~p)
% Assm: h4/sat/dc__conj: !r q p. (p <=> q /\ r) <=> (p \/ ~q \/ ~r) /\ (q \/ ~p) /\ (r \/ ~p)
% Assm: h4/sat/dc__disj: !r q p. (p <=> q \/ r) <=> (p \/ ~q) /\ (p \/ ~r) /\ (q \/ r \/ ~p)
% Assm: h4/sat/dc__imp: !r q p. (p <=> q ==> r) <=> (p \/ q) /\ (p \/ ~r) /\ (~q \/ r \/ ~p)
% Assm: h4/sat/dc__neg: !q p. (p <=> ~q) <=> (p \/ q) /\ (~q \/ ~p)
% Assm: h4/marker/Abbrev__def: !x. h4/marker/Abbrev x <=> x
% Assm: h4/combin/o__THM: !x g f. h4/combin/o f g x = f (g x)
% Assm: h4/combin/I__THM: !x. h4/combin/I x = x
% Assm: h4/arithmetic/ADD__CLAUSES_c0: !m. h4/arithmetic/_2B h4/num/0 m = m
% Assm: h4/arithmetic/ADD__SYM: !n m. h4/arithmetic/_2B m n = h4/arithmetic/_2B n m
% Assm: h4/arithmetic/ADD__ASSOC: !p n m. h4/arithmetic/_2B m (h4/arithmetic/_2B n p) = h4/arithmetic/_2B (h4/arithmetic/_2B m n) p
% Assm: h4/arithmetic/MULT__CLAUSES_c2: !m. h4/arithmetic/_2A (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO)) m = m
% Assm: h4/arithmetic/LESS__EQ__TRANS: !p n m. h4/arithmetic/_3C_3D m n /\ h4/arithmetic/_3C_3D n p ==> h4/arithmetic/_3C_3D m p
% Assm: h4/arithmetic/ZERO__LESS__EQ: !n. h4/arithmetic/_3C_3D h4/num/0 n
% Assm: h4/arithmetic/ADD__MONO__LESS__EQ: !p n m. h4/arithmetic/_3C_3D (h4/arithmetic/_2B m n) (h4/arithmetic/_2B m p) <=> h4/arithmetic/_3C_3D n p
% Assm: h4/arithmetic/NOT__GREATER__EQ: !n m. ~h4/arithmetic/_3E_3D m n <=> h4/arithmetic/_3C_3D (h4/num/SUC m) n
% Assm: h4/arithmetic/SUC__ONE__ADD: !n. h4/num/SUC n = h4/arithmetic/_2B (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO)) n
% Assm: h4/numeral/numeral__distrib_c1: !n. h4/arithmetic/_2B n h4/num/0 = n
% Assm: h4/numeral/numeral__distrib_c2: !n m. h4/arithmetic/_2B (h4/arithmetic/NUMERAL n) (h4/arithmetic/NUMERAL m) = h4/arithmetic/NUMERAL (h4/numeral/iZ (h4/arithmetic/_2B n m))
% Assm: h4/numeral/numeral__distrib_c17: !n. h4/arithmetic/NUMERAL n = h4/num/0 <=> n = h4/arithmetic/ZERO
% Assm: h4/numeral/numeral__distrib_c27: !n. h4/arithmetic/_3C_3D (h4/arithmetic/NUMERAL n) h4/num/0 <=> h4/arithmetic/_3C_3D n h4/arithmetic/ZERO
% Assm: h4/numeral/numeral__distrib_c30: !n. h4/arithmetic/_3E_3D h4/num/0 n <=> n = h4/num/0
% Assm: h4/numeral/numeral__add_c0: !n. h4/numeral/iZ (h4/arithmetic/_2B h4/arithmetic/ZERO n) = n
% Assm: h4/numeral/numeral__add_c2: !n m. h4/numeral/iZ (h4/arithmetic/_2B (h4/arithmetic/BIT1 n) (h4/arithmetic/BIT1 m)) = h4/arithmetic/BIT2 (h4/numeral/iZ (h4/arithmetic/_2B n m))
% Assm: h4/numeral/numeral__eq_c1: !n. h4/arithmetic/BIT1 n = h4/arithmetic/ZERO <=> F
% Assm: h4/numeral/numeral__lte_c1: !n. h4/arithmetic/_3C_3D (h4/arithmetic/BIT1 n) h4/arithmetic/ZERO <=> F
% Assm: h4/pred__set/EXTENSION: !t s. s = t <=> (!x. h4/bool/IN x s <=> h4/bool/IN x t)
% Assm: h4/pred__set/IN__IMAGE: !y s f. h4/bool/IN y (h4/pred__set/IMAGE f s) <=> (?x. y = f x /\ h4/bool/IN x s)
% Assm: h4/bag/BAG__INN0: !n e b. h4/bag/BAG__INN e n b <=> h4/arithmetic/_3E_3D (b e) n
% Assm: h4/bag/BAG__IN0: !e b. h4/bag/BAG__IN e b <=> h4/bag/BAG__INN e (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO)) b
% Assm: h4/bag/BAG__cases: !b. b = h4/bag/EMPTY__BAG \/ (?b0 e. b = h4/bag/BAG__INSERT e b0)
% Assm: h4/bag/BAG__IN__BAG__INSERT: !e2 e1 b. h4/bag/BAG__IN e1 (h4/bag/BAG__INSERT e2 b) <=> e1 = e2 \/ h4/bag/BAG__IN e1 b
% Assm: h4/bag/BAG__INSERT__NOT__EMPTY: !x b. ~(h4/bag/BAG__INSERT x b = h4/bag/EMPTY__BAG)
% Assm: h4/bag/BAG__INSERT__ONE__ONE: !x b2 b1. h4/bag/BAG__INSERT x b1 = h4/bag/BAG__INSERT x b2 <=> b1 = b2
% Assm: h4/bag/BAG__INSERT__commutes: !e2 e1 b. h4/bag/BAG__INSERT e1 (h4/bag/BAG__INSERT e2 b) = h4/bag/BAG__INSERT e2 (h4/bag/BAG__INSERT e1 b)
% Assm: h4/bag/BAG__DELETE0: !e b0 b. h4/bag/BAG__DELETE b0 e b <=> b0 = h4/bag/BAG__INSERT e b
% Assm: h4/bag/BAG__IN__BAG__DELETE: !e b. h4/bag/BAG__IN e b ==> (?b_27. h4/bag/BAG__DELETE b e b_27)
% Assm: h4/bag/BAG__INSERT__EQUAL: !b a N M. h4/bag/BAG__INSERT a M = h4/bag/BAG__INSERT b N <=> M = N /\ a = b \/ (?k. M = h4/bag/BAG__INSERT b k /\ N = h4/bag/BAG__INSERT a k)
% Assm: h4/bag/IN__SET__OF__BAG: !x b. h4/bool/IN x (h4/bag/SET__OF__BAG b) <=> h4/bag/BAG__IN x b
% Assm: h4/bag/FINITE__BAG__INSERT: !b. h4/bag/FINITE__BAG b ==> (!e. h4/bag/FINITE__BAG (h4/bag/BAG__INSERT e b))
% Assm: h4/bag/STRONG__FINITE__BAG__INDUCT: !P. P h4/bag/EMPTY__BAG /\ (!b. h4/bag/FINITE__BAG b /\ P b ==> (!e. P (h4/bag/BAG__INSERT e b))) ==> (!b. h4/bag/FINITE__BAG b ==> P b)
% Assm: h4/bag/FINITE__BAG__THM_c0: h4/bag/FINITE__BAG h4/bag/EMPTY__BAG
% Assm: h4/bag/FINITE__BAG__THM_c1: !e b. h4/bag/FINITE__BAG (h4/bag/BAG__INSERT e b) <=> h4/bag/FINITE__BAG b
% Assm: h4/bag/BAG__CARD__EMPTY: h4/bag/BAG__CARD h4/bag/EMPTY__BAG = h4/num/0
% Assm: h4/bag/BAG__CARD__THM_c1: !b. h4/bag/FINITE__BAG b ==> (!e. h4/bag/BAG__CARD (h4/bag/BAG__INSERT e b) = h4/arithmetic/_2B (h4/bag/BAG__CARD b) (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO)))
% Assm: h4/bag/BAG__IMAGE__DEF: !f b. h4/bag/BAG__IMAGE f b = (\e. h4/bool/LET (\sb. h4/bool/COND (h4/bag/FINITE__BAG sb) (h4/bag/BAG__CARD sb) (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO))) (h4/bag/BAG__FILTER (\e0. f e0 = e) b))
% Assm: h4/bag/BAG__EVERY0: !b P. h4/bag/BAG__EVERY P b <=> (!e. h4/bag/BAG__IN e b ==> P e)
% Assm: h4/bag/BAG__FILTER__EQ__EMPTY: !b P. h4/bag/BAG__FILTER P b = h4/bag/EMPTY__BAG <=> h4/bag/BAG__EVERY (h4/combin/o $not P) b
% Goal: !f b. h4/bag/SET__OF__BAG (h4/bag/BAG__IMAGE f b) = h4/pred__set/IMAGE f (h4/bag/SET__OF__BAG b)
%   PROCESSED
% Assm [HLu_TRUTH]: T
% Assm [HLu_FALSITY]: ~F
% Assm [HLu_BOOLu_CASES]: !t. (t <=> T) \/ (t <=> F)
% Assm [HLu_EXT]: !f g. (!x. happ f x = happ g x) ==> f = g
% Assm [h4s_bools_BOOLu_u_CASESu_u_AX]: !t. (t <=> T) \/ (t <=> F)
% Assm [h4s_bools_TRUTH]: T
% Assm [h4s_bools_IMPu_u_ANTISYMu_u_AX]: !t2 t1. (t1 ==> t2) ==> (t2 ==> t1) ==> (t1 <=> t2)
% Assm [h4s_bools_FALSITY]: !t. F ==> t
% Assm [h4s_bools_EXCLUDEDu_u_MIDDLE]: !t. t \/ ~t
% Assm [h4s_bools_LETu_u_THM]: !x f. h4/bool/LET f x = happ f x
% Assm [h4s_bools_FORALLu_u_SIMP]: !t. (!x. t) <=> t
% Assm [h4s_bools_IMPu_u_F]: !t. (t ==> F) ==> ~t
% Assm [h4s_bools_Fu_u_IMP]: !t. ~t ==> t ==> F
% Assm [h4s_bools_ANDu_u_CLAUSESu_c0]: !t. T /\ t <=> t
% Assm [h4s_bools_ANDu_u_CLAUSESu_c3]: !t. t /\ F <=> F
% Assm [h4s_bools_ORu_u_CLAUSESu_c0]: !t. T \/ t <=> T
% Assm [h4s_bools_ORu_u_CLAUSESu_c2]: !t. F \/ t <=> t
% Assm [h4s_bools_IMPu_u_CLAUSESu_c2]: !t. F ==> t <=> T
% Assm [h4s_bools_IMPu_u_CLAUSESu_c4]: !t. t ==> F <=> ~t
% Assm [h4s_bools_NOTu_u_CLAUSESu_c0]: !t. ~ ~t <=> t
% Assm [h4s_bools_NOTu_u_CLAUSESu_c1]: ~T <=> F
% Assm [h4s_bools_NOTu_u_CLAUSESu_c2]: ~F <=> T
% Assm [h4s_bools_REFLu_u_CLAUSE]: !x. x = x <=> T
% Assm [h4s_bools_EQu_u_SYMu_u_EQ]: !y x. x = y <=> y = x
% Assm [h4s_bools_EQu_u_CLAUSESu_c0]: !t. (T <=> t) <=> t
% Assm [h4s_bools_EQu_u_CLAUSESu_c1]: !t. (t <=> T) <=> t
% Assm [h4s_bools_EQu_u_CLAUSESu_c2]: !t. (F <=> t) <=> ~t
% Assm [h4s_bools_EQu_u_CLAUSESu_c3]: !t. (t <=> F) <=> ~t
% Assm [h4s_bools_CONDu_u_CLAUSESu_c0]: !t2 t1. h4/bool/COND T t1 t2 = t1
% Assm [h4s_bools_CONDu_u_CLAUSESu_c1]: !t2 t1. h4/bool/COND F t1 t2 = t2
% Assm [h4s_bools_NOTu_u_FORALLu_u_THM]: !P. ~(!x. happ P x) <=> (?x. ~happ P x)
% Assm [h4s_bools_NOTu_u_EXISTSu_u_THM]: !P. ~(?x. happ P x) <=> (!x. ~happ P x)
% Assm [h4s_bools_RIGHTu_u_FORALLu_u_ORu_u_THM]: !Q P. (!x. P \/ happ Q x) <=> P \/ (!x. happ Q x)
% Assm [h4s_bools_NOTu_u_IMP]: !B A. ~(A ==> B) <=> A /\ ~B
% Assm [h4s_bools_DISJu_u_ASSOC]: !C B A. A \/ B \/ C <=> (A \/ B) \/ C
% Assm [h4s_bools_DISJu_u_SYM]: !B A. A \/ B <=> B \/ A
% Assm [h4s_bools_DEu_u_MORGANu_u_THMu_c0]: !B A. ~(A /\ B) <=> ~A \/ ~B
% Assm [h4s_bools_DEu_u_MORGANu_u_THMu_c1]: !B A. ~(A \/ B) <=> ~A /\ ~B
% Assm [h4s_bools_IMPu_u_Fu_u_EQu_u_F]: !t. t ==> F <=> t <=> F
% Assm [h4s_bools_ANDu_u_IMPu_u_INTRO]: !t3 t2 t1. t1 ==> t2 ==> t3 <=> t1 /\ t2 ==> t3
% Assm [h4s_bools_IMPu_u_CONG]: !y_27 y x_27 x. (x <=> x_27) /\ (x_27 ==> (y <=> y_27)) ==> (x ==> y <=> x_27 ==> y_27)
% Assm [h4s_sats_NOTu_u_NOT]: !t. ~ ~t <=> t
% Assm [h4s_sats_ANDu_u_INVu_u_IMP]: !A. A ==> ~A ==> F
% Assm [h4s_sats_ORu_u_DUAL2]: !B A. ~(A \/ B) ==> F <=> (A ==> F) ==> ~B ==> F
% Assm [h4s_sats_ORu_u_DUAL3]: !B A. ~(~A \/ B) ==> F <=> A ==> ~B ==> F
% Assm [h4s_sats_ANDu_u_INV2]: !A. (~A ==> F) ==> (A ==> F) ==> F
% Assm [h4s_sats_dcu_u_eq]: !r q p. (p <=> q <=> r) <=> (p \/ q \/ r) /\ (p \/ ~r \/ ~q) /\ (q \/ ~r \/ ~p) /\ (r \/ ~q \/ ~p)
% Assm [h4s_sats_dcu_u_conj]: !r q p. (p <=> q /\ r) <=> (p \/ ~q \/ ~r) /\ (q \/ ~p) /\ (r \/ ~p)
% Assm [h4s_sats_dcu_u_disj]: !r q p. (p <=> q \/ r) <=> (p \/ ~q) /\ (p \/ ~r) /\ (q \/ r \/ ~p)
% Assm [h4s_sats_dcu_u_imp]: !r q p. (p <=> q ==> r) <=> (p \/ q) /\ (p \/ ~r) /\ (~q \/ r \/ ~p)
% Assm [h4s_sats_dcu_u_neg]: !q p. (p <=> ~q) <=> (p \/ q) /\ (~q \/ ~p)
% Assm [h4s_markers_Abbrevu_u_def]: !x. h4/marker/Abbrev x <=> x
% Assm [h4s_combins_ou_u_THM]: !x g f. happ (h4/combin/o f g) x = happ f (happ g x)
% Assm [h4s_combins_Iu_u_THM]: !x. h4/combin/I x = x
% Assm [h4s_arithmetics_ADDu_u_CLAUSESu_c0]: !m. h4/arithmetic/_2B h4/num/0 m = m
% Assm [h4s_arithmetics_ADDu_u_SYM]: !n m. h4/arithmetic/_2B m n = h4/arithmetic/_2B n m
% Assm [h4s_arithmetics_ADDu_u_ASSOC]: !p n m. h4/arithmetic/_2B m (h4/arithmetic/_2B n p) = h4/arithmetic/_2B (h4/arithmetic/_2B m n) p
% Assm [h4s_arithmetics_MULTu_u_CLAUSESu_c2]: !m. h4/arithmetic/_2A (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO)) m = m
% Assm [h4s_arithmetics_LESSu_u_EQu_u_TRANS]: !p n m. h4/arithmetic/_3C_3D m n /\ h4/arithmetic/_3C_3D n p ==> h4/arithmetic/_3C_3D m p
% Assm [h4s_arithmetics_ZEROu_u_LESSu_u_EQ]: !n. h4/arithmetic/_3C_3D h4/num/0 n
% Assm [h4s_arithmetics_ADDu_u_MONOu_u_LESSu_u_EQ]: !p n m. h4/arithmetic/_3C_3D (h4/arithmetic/_2B m n) (h4/arithmetic/_2B m p) <=> h4/arithmetic/_3C_3D n p
% Assm [h4s_arithmetics_NOTu_u_GREATERu_u_EQ]: !n m. ~h4/arithmetic/_3E_3D m n <=> h4/arithmetic/_3C_3D (h4/num/SUC m) n
% Assm [h4s_arithmetics_SUCu_u_ONEu_u_ADD]: !n. h4/num/SUC n = h4/arithmetic/_2B (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO)) n
% Assm [h4s_numerals_numeralu_u_distribu_c1]: !n. h4/arithmetic/_2B n h4/num/0 = n
% Assm [h4s_numerals_numeralu_u_distribu_c2]: !n m. h4/arithmetic/_2B (h4/arithmetic/NUMERAL n) (h4/arithmetic/NUMERAL m) = h4/arithmetic/NUMERAL (h4/numeral/iZ (h4/arithmetic/_2B n m))
% Assm [h4s_numerals_numeralu_u_distribu_c17]: !n. h4/arithmetic/NUMERAL n = h4/num/0 <=> n = h4/arithmetic/ZERO
% Assm [h4s_numerals_numeralu_u_distribu_c27]: !n. h4/arithmetic/_3C_3D (h4/arithmetic/NUMERAL n) h4/num/0 <=> h4/arithmetic/_3C_3D n h4/arithmetic/ZERO
% Assm [h4s_numerals_numeralu_u_distribu_c30]: !n. h4/arithmetic/_3E_3D h4/num/0 n <=> n = h4/num/0
% Assm [h4s_numerals_numeralu_u_addu_c0]: !n. h4/numeral/iZ (h4/arithmetic/_2B h4/arithmetic/ZERO n) = n
% Assm [h4s_numerals_numeralu_u_addu_c2]: !n m. h4/numeral/iZ (h4/arithmetic/_2B (h4/arithmetic/BIT1 n) (h4/arithmetic/BIT1 m)) = h4/arithmetic/BIT2 (h4/numeral/iZ (h4/arithmetic/_2B n m))
% Assm [h4s_numerals_numeralu_u_equ_c1]: !n. h4/arithmetic/BIT1 n = h4/arithmetic/ZERO <=> F
% Assm [h4s_numerals_numeralu_u_lteu_c1]: !n. h4/arithmetic/_3C_3D (h4/arithmetic/BIT1 n) h4/arithmetic/ZERO <=> F
% Assm [h4s_predu_u_sets_EXTENSION]: !t s. s = t <=> (!x. h4/bool/IN x s <=> h4/bool/IN x t)
% Assm [h4s_predu_u_sets_INu_u_IMAGE]: !y s f. h4/bool/IN y (h4/pred__set/IMAGE f s) <=> (?x. y = happ f x /\ h4/bool/IN x s)
% Assm [h4s_bags_BAGu_u_INN0]: !n e b. h4/bag/BAG__INN e n b <=> h4/arithmetic/_3E_3D (happ b e) n
% Assm [h4s_bags_BAGu_u_IN0]: !e b. h4/bag/BAG__IN e b <=> h4/bag/BAG__INN e (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO)) b
% Assm [h4s_bags_BAGu_u_cases]: !b. b = h4/bag/EMPTY__BAG \/ (?b0 e. b = h4/bag/BAG__INSERT e b0)
% Assm [h4s_bags_BAGu_u_INu_u_BAGu_u_INSERT]: !e2 e1 b. h4/bag/BAG__IN e1 (h4/bag/BAG__INSERT e2 b) <=> e1 = e2 \/ h4/bag/BAG__IN e1 b
% Assm [h4s_bags_BAGu_u_INSERTu_u_NOTu_u_EMPTY]: !x b. ~(h4/bag/BAG__INSERT x b = h4/bag/EMPTY__BAG)
% Assm [h4s_bags_BAGu_u_INSERTu_u_ONEu_u_ONE]: !x b2 b1. h4/bag/BAG__INSERT x b1 = h4/bag/BAG__INSERT x b2 <=> b1 = b2
% Assm [h4s_bags_BAGu_u_INSERTu_u_commutes]: !e2 e1 b. h4/bag/BAG__INSERT e1 (h4/bag/BAG__INSERT e2 b) = h4/bag/BAG__INSERT e2 (h4/bag/BAG__INSERT e1 b)
% Assm [h4s_bags_BAGu_u_DELETE0]: !e b0 b. h4/bag/BAG__DELETE b0 e b <=> b0 = h4/bag/BAG__INSERT e b
% Assm [h4s_bags_BAGu_u_INu_u_BAGu_u_DELETE]: !e b. h4/bag/BAG__IN e b ==> (?b_27. h4/bag/BAG__DELETE b e b_27)
% Assm [h4s_bags_BAGu_u_INSERTu_u_EQUAL]: !b a N M. h4/bag/BAG__INSERT a M = h4/bag/BAG__INSERT b N <=> M = N /\ a = b \/ (?k. M = h4/bag/BAG__INSERT b k /\ N = h4/bag/BAG__INSERT a k)
% Assm [h4s_bags_INu_u_SETu_u_OFu_u_BAG]: !x b. h4/bool/IN x (h4/bag/SET__OF__BAG b) <=> h4/bag/BAG__IN x b
% Assm [h4s_bags_FINITEu_u_BAGu_u_INSERT]: !b. h4/bag/FINITE__BAG b ==> (!e. h4/bag/FINITE__BAG (h4/bag/BAG__INSERT e b))
% Assm [h4s_bags_STRONGu_u_FINITEu_u_BAGu_u_INDUCT]: !P. happ P h4/bag/EMPTY__BAG /\ (!b. h4/bag/FINITE__BAG b /\ happ P b ==> (!e. happ P (h4/bag/BAG__INSERT e b))) ==> (!b. h4/bag/FINITE__BAG b ==> happ P b)
% Assm [h4s_bags_FINITEu_u_BAGu_u_THMu_c0]: h4/bag/FINITE__BAG h4/bag/EMPTY__BAG
% Assm [h4s_bags_FINITEu_u_BAGu_u_THMu_c1]: !e b. h4/bag/FINITE__BAG (h4/bag/BAG__INSERT e b) <=> h4/bag/FINITE__BAG b
% Assm [h4s_bags_BAGu_u_CARDu_u_EMPTY]: h4/bag/BAG__CARD h4/bag/EMPTY__BAG = h4/num/0
% Assm [h4s_bags_BAGu_u_CARDu_u_THMu_c1]: !b. h4/bag/FINITE__BAG b ==> (!e. h4/bag/BAG__CARD (h4/bag/BAG__INSERT e b) = h4/arithmetic/_2B (h4/bag/BAG__CARD b) (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO)))
% Assm [h4s_bags_BAGu_u_IMAGEu_u_DEF]: !_1. (!f x e0. happ (happ (happ _1 f) x) e0 <=> happ f e0 = x) ==> (!_0. (!sb. happ _0 sb = h4/bool/COND (h4/bag/FINITE__BAG sb) (h4/bag/BAG__CARD sb) (h4/arithmetic/NUMERAL (h4/arithmetic/BIT1 h4/arithmetic/ZERO))) ==> (!f b x. happ (h4/bag/BAG__IMAGE f b) x = h4/bool/LET _0 (h4/bag/BAG__FILTER (happ (happ _1 f) x) b)))
% Assm [h4s_bags_BAGu_u_EVERY0]: !b P. h4/bag/BAG__EVERY P b <=> (!e. h4/bag/BAG__IN e b ==> happ P e)
% Assm [h4s_bags_BAGu_u_FILTERu_u_EQu_u_EMPTY]: !b P. h4/bag/BAG__FILTER P b = h4/bag/EMPTY__BAG <=> h4/bag/BAG__EVERY (h4/combin/o $not P) b
% Goal: !f b. h4/bag/SET__OF__BAG (h4/bag/BAG__IMAGE f b) = h4/pred__set/IMAGE f (h4/bag/SET__OF__BAG b)
fof(aHLu_TRUTH, axiom, p(s(t_bool,t))).
fof(aHLu_FALSITY, axiom, ~ (p(s(t_bool,f0)))).
fof(aHLu_BOOLu_CASES, axiom, ![V_t]: (s(t_bool,V_t) = s(t_bool,t) | s(t_bool,V_t) = s(t_bool,f0))).
fof(aHLu_EXT, axiom, ![TV_Q232172,TV_Q232168]: ![V_f, V_g]: (![V_x]: s(TV_Q232168,happ(s(t_fun(TV_Q232172,TV_Q232168),V_f),s(TV_Q232172,V_x))) = s(TV_Q232168,happ(s(t_fun(TV_Q232172,TV_Q232168),V_g),s(TV_Q232172,V_x))) => s(t_fun(TV_Q232172,TV_Q232168),V_f) = s(t_fun(TV_Q232172,TV_Q232168),V_g))).
fof(ah4s_bools_BOOLu_u_CASESu_u_AX, axiom, ![V_t]: (s(t_bool,V_t) = s(t_bool,t) | s(t_bool,V_t) = s(t_bool,f0))).
fof(ah4s_bools_TRUTH, axiom, p(s(t_bool,t))).
fof(ah4s_bools_IMPu_u_ANTISYMu_u_AX, axiom, ![V_t2, V_t1]: ((p(s(t_bool,V_t1)) => p(s(t_bool,V_t2))) => ((p(s(t_bool,V_t2)) => p(s(t_bool,V_t1))) => s(t_bool,V_t1) = s(t_bool,V_t2)))).
fof(ah4s_bools_FALSITY, axiom, ![V_t]: (p(s(t_bool,f0)) => p(s(t_bool,V_t)))).
fof(ah4s_bools_EXCLUDEDu_u_MIDDLE, axiom, ![V_t]: (p(s(t_bool,V_t)) | ~ (p(s(t_bool,V_t))))).
fof(ah4s_bools_LETu_u_THM, axiom, ![TV_u_27b,TV_u_27a]: ![V_x, V_f]: s(TV_u_27b,h4s_bools_let(s(t_fun(TV_u_27a,TV_u_27b),V_f),s(TV_u_27a,V_x))) = s(TV_u_27b,happ(s(t_fun(TV_u_27a,TV_u_27b),V_f),s(TV_u_27a,V_x)))).
fof(ah4s_bools_FORALLu_u_SIMP, axiom, ![TV_u_27a]: ![V_t]: (![V_x]: p(s(t_bool,V_t)) <=> p(s(t_bool,V_t)))).
fof(ah4s_bools_IMPu_u_F, axiom, ![V_t]: ((p(s(t_bool,V_t)) => p(s(t_bool,f0))) => ~ (p(s(t_bool,V_t))))).
fof(ah4s_bools_Fu_u_IMP, axiom, ![V_t]: (~ (p(s(t_bool,V_t))) => (p(s(t_bool,V_t)) => p(s(t_bool,f0))))).
fof(ah4s_bools_ANDu_u_CLAUSESu_c0, axiom, ![V_t]: ((p(s(t_bool,t)) & p(s(t_bool,V_t))) <=> p(s(t_bool,V_t)))).
fof(ah4s_bools_ANDu_u_CLAUSESu_c3, axiom, ![V_t]: ((p(s(t_bool,V_t)) & p(s(t_bool,f0))) <=> p(s(t_bool,f0)))).
fof(ah4s_bools_ORu_u_CLAUSESu_c0, axiom, ![V_t]: ((p(s(t_bool,t)) | p(s(t_bool,V_t))) <=> p(s(t_bool,t)))).
fof(ah4s_bools_ORu_u_CLAUSESu_c2, axiom, ![V_t]: ((p(s(t_bool,f0)) | p(s(t_bool,V_t))) <=> p(s(t_bool,V_t)))).
fof(ah4s_bools_IMPu_u_CLAUSESu_c2, axiom, ![V_t]: ((p(s(t_bool,f0)) => p(s(t_bool,V_t))) <=> p(s(t_bool,t)))).
fof(ah4s_bools_IMPu_u_CLAUSESu_c4, axiom, ![V_t]: ((p(s(t_bool,V_t)) => p(s(t_bool,f0))) <=> ~ (p(s(t_bool,V_t))))).
fof(ah4s_bools_NOTu_u_CLAUSESu_c0, axiom, ![V_t]: (~ (~ (p(s(t_bool,V_t)))) <=> p(s(t_bool,V_t)))).
fof(ah4s_bools_NOTu_u_CLAUSESu_c1, axiom, (~ (p(s(t_bool,t))) <=> p(s(t_bool,f0)))).
fof(ah4s_bools_NOTu_u_CLAUSESu_c2, axiom, (~ (p(s(t_bool,f0))) <=> p(s(t_bool,t)))).
fof(ah4s_bools_REFLu_u_CLAUSE, axiom, ![TV_u_27a]: ![V_x]: (s(TV_u_27a,V_x) = s(TV_u_27a,V_x) <=> p(s(t_bool,t)))).
fof(ah4s_bools_EQu_u_SYMu_u_EQ, axiom, ![TV_u_27a]: ![V_y, V_x]: (s(TV_u_27a,V_x) = s(TV_u_27a,V_y) <=> s(TV_u_27a,V_y) = s(TV_u_27a,V_x))).
fof(ah4s_bools_EQu_u_CLAUSESu_c0, axiom, ![V_t]: (s(t_bool,t) = s(t_bool,V_t) <=> p(s(t_bool,V_t)))).
fof(ah4s_bools_EQu_u_CLAUSESu_c1, axiom, ![V_t]: (s(t_bool,V_t) = s(t_bool,t) <=> p(s(t_bool,V_t)))).
fof(ah4s_bools_EQu_u_CLAUSESu_c2, axiom, ![V_t]: (s(t_bool,f0) = s(t_bool,V_t) <=> ~ (p(s(t_bool,V_t))))).
fof(ah4s_bools_EQu_u_CLAUSESu_c3, axiom, ![V_t]: (s(t_bool,V_t) = s(t_bool,f0) <=> ~ (p(s(t_bool,V_t))))).
fof(ah4s_bools_CONDu_u_CLAUSESu_c0, axiom, ![TV_u_27a]: ![V_t2, V_t1]: s(TV_u_27a,h4s_bools_cond(s(t_bool,t),s(TV_u_27a,V_t1),s(TV_u_27a,V_t2))) = s(TV_u_27a,V_t1)).
fof(ah4s_bools_CONDu_u_CLAUSESu_c1, axiom, ![TV_u_27a]: ![V_t2, V_t1]: s(TV_u_27a,h4s_bools_cond(s(t_bool,f0),s(TV_u_27a,V_t1),s(TV_u_27a,V_t2))) = s(TV_u_27a,V_t2)).
fof(ah4s_bools_NOTu_u_FORALLu_u_THM, axiom, ![TV_u_27a]: ![V_P]: (~ (![V_x]: p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_P),s(TV_u_27a,V_x))))) <=> ?[V_x]: ~ (p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_P),s(TV_u_27a,V_x))))))).
fof(ah4s_bools_NOTu_u_EXISTSu_u_THM, axiom, ![TV_u_27a]: ![V_P]: (~ (?[V_x]: p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_P),s(TV_u_27a,V_x))))) <=> ![V_x]: ~ (p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_P),s(TV_u_27a,V_x))))))).
fof(ah4s_bools_RIGHTu_u_FORALLu_u_ORu_u_THM, axiom, ![TV_u_27a]: ![V_Q, V_P]: (![V_x]: (p(s(t_bool,V_P)) | p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_Q),s(TV_u_27a,V_x))))) <=> (p(s(t_bool,V_P)) | ![V_x]: p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_Q),s(TV_u_27a,V_x))))))).
fof(ah4s_bools_NOTu_u_IMP, axiom, ![V_B, V_A]: (~ ((p(s(t_bool,V_A)) => p(s(t_bool,V_B)))) <=> (p(s(t_bool,V_A)) & ~ (p(s(t_bool,V_B)))))).
fof(ah4s_bools_DISJu_u_ASSOC, axiom, ![V_C, V_B, V_A]: ((p(s(t_bool,V_A)) | (p(s(t_bool,V_B)) | p(s(t_bool,V_C)))) <=> ((p(s(t_bool,V_A)) | p(s(t_bool,V_B))) | p(s(t_bool,V_C))))).
fof(ah4s_bools_DISJu_u_SYM, axiom, ![V_B, V_A]: ((p(s(t_bool,V_A)) | p(s(t_bool,V_B))) <=> (p(s(t_bool,V_B)) | p(s(t_bool,V_A))))).
fof(ah4s_bools_DEu_u_MORGANu_u_THMu_c0, axiom, ![V_B, V_A]: (~ ((p(s(t_bool,V_A)) & p(s(t_bool,V_B)))) <=> (~ (p(s(t_bool,V_A))) | ~ (p(s(t_bool,V_B)))))).
fof(ah4s_bools_DEu_u_MORGANu_u_THMu_c1, axiom, ![V_B, V_A]: (~ ((p(s(t_bool,V_A)) | p(s(t_bool,V_B)))) <=> (~ (p(s(t_bool,V_A))) & ~ (p(s(t_bool,V_B)))))).
fof(ah4s_bools_IMPu_u_Fu_u_EQu_u_F, axiom, ![V_t]: ((p(s(t_bool,V_t)) => p(s(t_bool,f0))) <=> s(t_bool,V_t) = s(t_bool,f0))).
fof(ah4s_bools_ANDu_u_IMPu_u_INTRO, axiom, ![V_t3, V_t2, V_t1]: ((p(s(t_bool,V_t1)) => (p(s(t_bool,V_t2)) => p(s(t_bool,V_t3)))) <=> ((p(s(t_bool,V_t1)) & p(s(t_bool,V_t2))) => p(s(t_bool,V_t3))))).
fof(ah4s_bools_IMPu_u_CONG, axiom, ![V_yu_27, V_y, V_xu_27, V_x]: ((s(t_bool,V_x) = s(t_bool,V_xu_27) & (p(s(t_bool,V_xu_27)) => s(t_bool,V_y) = s(t_bool,V_yu_27))) => ((p(s(t_bool,V_x)) => p(s(t_bool,V_y))) <=> (p(s(t_bool,V_xu_27)) => p(s(t_bool,V_yu_27)))))).
fof(ah4s_sats_NOTu_u_NOT, axiom, ![V_t]: (~ (~ (p(s(t_bool,V_t)))) <=> p(s(t_bool,V_t)))).
fof(ah4s_sats_ANDu_u_INVu_u_IMP, axiom, ![V_A]: (p(s(t_bool,V_A)) => (~ (p(s(t_bool,V_A))) => p(s(t_bool,f0))))).
fof(ah4s_sats_ORu_u_DUAL2, axiom, ![V_B, V_A]: ((~ ((p(s(t_bool,V_A)) | p(s(t_bool,V_B)))) => p(s(t_bool,f0))) <=> ((p(s(t_bool,V_A)) => p(s(t_bool,f0))) => (~ (p(s(t_bool,V_B))) => p(s(t_bool,f0)))))).
fof(ah4s_sats_ORu_u_DUAL3, axiom, ![V_B, V_A]: ((~ ((~ (p(s(t_bool,V_A))) | p(s(t_bool,V_B)))) => p(s(t_bool,f0))) <=> (p(s(t_bool,V_A)) => (~ (p(s(t_bool,V_B))) => p(s(t_bool,f0)))))).
fof(ah4s_sats_ANDu_u_INV2, axiom, ![V_A]: ((~ (p(s(t_bool,V_A))) => p(s(t_bool,f0))) => ((p(s(t_bool,V_A)) => p(s(t_bool,f0))) => p(s(t_bool,f0))))).
fof(ah4s_sats_dcu_u_eq, axiom, ![V_r, V_q, V_p]: ((p(s(t_bool,V_p)) <=> s(t_bool,V_q) = s(t_bool,V_r)) <=> ((p(s(t_bool,V_p)) | (p(s(t_bool,V_q)) | p(s(t_bool,V_r)))) & ((p(s(t_bool,V_p)) | (~ (p(s(t_bool,V_r))) | ~ (p(s(t_bool,V_q))))) & ((p(s(t_bool,V_q)) | (~ (p(s(t_bool,V_r))) | ~ (p(s(t_bool,V_p))))) & (p(s(t_bool,V_r)) | (~ (p(s(t_bool,V_q))) | ~ (p(s(t_bool,V_p)))))))))).
fof(ah4s_sats_dcu_u_conj, axiom, ![V_r, V_q, V_p]: ((p(s(t_bool,V_p)) <=> (p(s(t_bool,V_q)) & p(s(t_bool,V_r)))) <=> ((p(s(t_bool,V_p)) | (~ (p(s(t_bool,V_q))) | ~ (p(s(t_bool,V_r))))) & ((p(s(t_bool,V_q)) | ~ (p(s(t_bool,V_p)))) & (p(s(t_bool,V_r)) | ~ (p(s(t_bool,V_p)))))))).
fof(ah4s_sats_dcu_u_disj, axiom, ![V_r, V_q, V_p]: ((p(s(t_bool,V_p)) <=> (p(s(t_bool,V_q)) | p(s(t_bool,V_r)))) <=> ((p(s(t_bool,V_p)) | ~ (p(s(t_bool,V_q)))) & ((p(s(t_bool,V_p)) | ~ (p(s(t_bool,V_r)))) & (p(s(t_bool,V_q)) | (p(s(t_bool,V_r)) | ~ (p(s(t_bool,V_p))))))))).
fof(ah4s_sats_dcu_u_imp, axiom, ![V_r, V_q, V_p]: ((p(s(t_bool,V_p)) <=> (p(s(t_bool,V_q)) => p(s(t_bool,V_r)))) <=> ((p(s(t_bool,V_p)) | p(s(t_bool,V_q))) & ((p(s(t_bool,V_p)) | ~ (p(s(t_bool,V_r)))) & (~ (p(s(t_bool,V_q))) | (p(s(t_bool,V_r)) | ~ (p(s(t_bool,V_p))))))))).
fof(ah4s_sats_dcu_u_neg, axiom, ![V_q, V_p]: ((p(s(t_bool,V_p)) <=> ~ (p(s(t_bool,V_q)))) <=> ((p(s(t_bool,V_p)) | p(s(t_bool,V_q))) & (~ (p(s(t_bool,V_q))) | ~ (p(s(t_bool,V_p))))))).
fof(ah4s_markers_Abbrevu_u_def, axiom, ![V_x]: s(t_bool,h4s_markers_abbrev(s(t_bool,V_x))) = s(t_bool,V_x)).
fof(ah4s_combins_ou_u_THM, axiom, ![TV_u_27b,TV_u_27a,TV_u_27c]: ![V_x, V_g, V_f]: s(TV_u_27b,happ(s(t_fun(TV_u_27c,TV_u_27b),h4s_combins_o(s(t_fun(TV_u_27a,TV_u_27b),V_f),s(t_fun(TV_u_27c,TV_u_27a),V_g))),s(TV_u_27c,V_x))) = s(TV_u_27b,happ(s(t_fun(TV_u_27a,TV_u_27b),V_f),s(TV_u_27a,happ(s(t_fun(TV_u_27c,TV_u_27a),V_g),s(TV_u_27c,V_x)))))).
fof(ah4s_combins_Iu_u_THM, axiom, ![TV_u_27a]: ![V_x]: s(TV_u_27a,h4s_combins_i(s(TV_u_27a,V_x))) = s(TV_u_27a,V_x)).
fof(ah4s_arithmetics_ADDu_u_CLAUSESu_c0, axiom, ![V_m]: s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,h4s_nums_0),s(t_h4s_nums_num,V_m))) = s(t_h4s_nums_num,V_m)).
fof(ah4s_arithmetics_ADDu_u_SYM, axiom, ![V_n, V_m]: s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_m),s(t_h4s_nums_num,V_n))) = s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_n),s(t_h4s_nums_num,V_m)))).
fof(ah4s_arithmetics_ADDu_u_ASSOC, axiom, ![V_p, V_n, V_m]: s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_m),s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_n),s(t_h4s_nums_num,V_p))))) = s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_m),s(t_h4s_nums_num,V_n))),s(t_h4s_nums_num,V_p)))).
fof(ah4s_arithmetics_MULTu_u_CLAUSESu_c2, axiom, ![V_m]: s(t_h4s_nums_num,h4s_arithmetics_u_2a(s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,h4s_arithmetics_bit1(s(t_h4s_nums_num,h4s_arithmetics_zero))))),s(t_h4s_nums_num,V_m))) = s(t_h4s_nums_num,V_m)).
fof(ah4s_arithmetics_LESSu_u_EQu_u_TRANS, axiom, ![V_p, V_n, V_m]: ((p(s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,V_m),s(t_h4s_nums_num,V_n)))) & p(s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,V_n),s(t_h4s_nums_num,V_p))))) => p(s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,V_m),s(t_h4s_nums_num,V_p)))))).
fof(ah4s_arithmetics_ZEROu_u_LESSu_u_EQ, axiom, ![V_n]: p(s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,h4s_nums_0),s(t_h4s_nums_num,V_n))))).
fof(ah4s_arithmetics_ADDu_u_MONOu_u_LESSu_u_EQ, axiom, ![V_p, V_n, V_m]: s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_m),s(t_h4s_nums_num,V_n))),s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_m),s(t_h4s_nums_num,V_p))))) = s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,V_n),s(t_h4s_nums_num,V_p)))).
fof(ah4s_arithmetics_NOTu_u_GREATERu_u_EQ, axiom, ![V_n, V_m]: (~ (p(s(t_bool,h4s_arithmetics_u_3eu_3d(s(t_h4s_nums_num,V_m),s(t_h4s_nums_num,V_n))))) <=> p(s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,h4s_nums_suc(s(t_h4s_nums_num,V_m))),s(t_h4s_nums_num,V_n)))))).
fof(ah4s_arithmetics_SUCu_u_ONEu_u_ADD, axiom, ![V_n]: s(t_h4s_nums_num,h4s_nums_suc(s(t_h4s_nums_num,V_n))) = s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,h4s_arithmetics_bit1(s(t_h4s_nums_num,h4s_arithmetics_zero))))),s(t_h4s_nums_num,V_n)))).
fof(ah4s_numerals_numeralu_u_distribu_c1, axiom, ![V_n]: s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_n),s(t_h4s_nums_num,h4s_nums_0))) = s(t_h4s_nums_num,V_n)).
fof(ah4s_numerals_numeralu_u_distribu_c2, axiom, ![V_n, V_m]: s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,V_n))),s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,V_m))))) = s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,h4s_numerals_iz(s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_n),s(t_h4s_nums_num,V_m)))))))).
fof(ah4s_numerals_numeralu_u_distribu_c17, axiom, ![V_n]: (s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,V_n))) = s(t_h4s_nums_num,h4s_nums_0) <=> s(t_h4s_nums_num,V_n) = s(t_h4s_nums_num,h4s_arithmetics_zero))).
fof(ah4s_numerals_numeralu_u_distribu_c27, axiom, ![V_n]: s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,V_n))),s(t_h4s_nums_num,h4s_nums_0))) = s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,V_n),s(t_h4s_nums_num,h4s_arithmetics_zero)))).
fof(ah4s_numerals_numeralu_u_distribu_c30, axiom, ![V_n]: (p(s(t_bool,h4s_arithmetics_u_3eu_3d(s(t_h4s_nums_num,h4s_nums_0),s(t_h4s_nums_num,V_n)))) <=> s(t_h4s_nums_num,V_n) = s(t_h4s_nums_num,h4s_nums_0))).
fof(ah4s_numerals_numeralu_u_addu_c0, axiom, ![V_n]: s(t_h4s_nums_num,h4s_numerals_iz(s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,h4s_arithmetics_zero),s(t_h4s_nums_num,V_n))))) = s(t_h4s_nums_num,V_n)).
fof(ah4s_numerals_numeralu_u_addu_c2, axiom, ![V_n, V_m]: s(t_h4s_nums_num,h4s_numerals_iz(s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,h4s_arithmetics_bit1(s(t_h4s_nums_num,V_n))),s(t_h4s_nums_num,h4s_arithmetics_bit1(s(t_h4s_nums_num,V_m))))))) = s(t_h4s_nums_num,h4s_arithmetics_bit2(s(t_h4s_nums_num,h4s_numerals_iz(s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,V_n),s(t_h4s_nums_num,V_m)))))))).
fof(ah4s_numerals_numeralu_u_equ_c1, axiom, ![V_n]: (s(t_h4s_nums_num,h4s_arithmetics_bit1(s(t_h4s_nums_num,V_n))) = s(t_h4s_nums_num,h4s_arithmetics_zero) <=> p(s(t_bool,f0)))).
fof(ah4s_numerals_numeralu_u_lteu_c1, axiom, ![V_n]: s(t_bool,h4s_arithmetics_u_3cu_3d(s(t_h4s_nums_num,h4s_arithmetics_bit1(s(t_h4s_nums_num,V_n))),s(t_h4s_nums_num,h4s_arithmetics_zero))) = s(t_bool,f0)).
fof(ah4s_predu_u_sets_EXTENSION, axiom, ![TV_u_27a]: ![V_t, V_s]: (s(t_fun(TV_u_27a,t_bool),V_s) = s(t_fun(TV_u_27a,t_bool),V_t) <=> ![V_x]: s(t_bool,h4s_bools_in(s(TV_u_27a,V_x),s(t_fun(TV_u_27a,t_bool),V_s))) = s(t_bool,h4s_bools_in(s(TV_u_27a,V_x),s(t_fun(TV_u_27a,t_bool),V_t))))).
fof(ah4s_predu_u_sets_INu_u_IMAGE, axiom, ![TV_u_27b,TV_u_27a]: ![V_y, V_s, V_f]: (p(s(t_bool,h4s_bools_in(s(TV_u_27b,V_y),s(t_fun(TV_u_27b,t_bool),h4s_predu_u_sets_image(s(t_fun(TV_u_27a,TV_u_27b),V_f),s(t_fun(TV_u_27a,t_bool),V_s)))))) <=> ?[V_x]: (s(TV_u_27b,V_y) = s(TV_u_27b,happ(s(t_fun(TV_u_27a,TV_u_27b),V_f),s(TV_u_27a,V_x))) & p(s(t_bool,h4s_bools_in(s(TV_u_27a,V_x),s(t_fun(TV_u_27a,t_bool),V_s))))))).
fof(ah4s_bags_BAGu_u_INN0, axiom, ![TV_u_27a]: ![V_n, V_e, V_b]: s(t_bool,h4s_bags_bagu_u_inn(s(TV_u_27a,V_e),s(t_h4s_nums_num,V_n),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))) = s(t_bool,h4s_arithmetics_u_3eu_3d(s(t_h4s_nums_num,happ(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b),s(TV_u_27a,V_e))),s(t_h4s_nums_num,V_n)))).
fof(ah4s_bags_BAGu_u_IN0, axiom, ![TV_u_27a]: ![V_e, V_b]: s(t_bool,h4s_bags_bagu_u_in(s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))) = s(t_bool,h4s_bags_bagu_u_inn(s(TV_u_27a,V_e),s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,h4s_arithmetics_bit1(s(t_h4s_nums_num,h4s_arithmetics_zero))))),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))).
fof(ah4s_bags_BAGu_u_cases, axiom, ![TV_u_27a]: ![V_b]: (s(t_fun(TV_u_27a,t_h4s_nums_num),V_b) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_emptyu_u_bag) | ?[V_b0, V_e]: s(t_fun(TV_u_27a,t_h4s_nums_num),V_b) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b0))))).
fof(ah4s_bags_BAGu_u_INu_u_BAGu_u_INSERT, axiom, ![TV_u_27a]: ![V_e2, V_e1, V_b]: (p(s(t_bool,h4s_bags_bagu_u_in(s(TV_u_27a,V_e1),s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e2),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))))) <=> (s(TV_u_27a,V_e1) = s(TV_u_27a,V_e2) | p(s(t_bool,h4s_bags_bagu_u_in(s(TV_u_27a,V_e1),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))))))).
fof(ah4s_bags_BAGu_u_INSERTu_u_NOTu_u_EMPTY, axiom, ![TV_u_27a]: ![V_x, V_b]: ~ (s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_x),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_emptyu_u_bag))).
fof(ah4s_bags_BAGu_u_INSERTu_u_ONEu_u_ONE, axiom, ![TV_u_27a]: ![V_x, V_b2, V_b1]: (s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_x),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b1))) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_x),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b2))) <=> s(t_fun(TV_u_27a,t_h4s_nums_num),V_b1) = s(t_fun(TV_u_27a,t_h4s_nums_num),V_b2))).
fof(ah4s_bags_BAGu_u_INSERTu_u_commutes, axiom, ![TV_u_27a]: ![V_e2, V_e1, V_b]: s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e1),s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e2),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))))) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e2),s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e1),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))))).
fof(ah4s_bags_BAGu_u_DELETE0, axiom, ![TV_u_27a]: ![V_e, V_b0, V_b]: (p(s(t_bool,h4s_bags_bagu_u_delete(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b0),s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))) <=> s(t_fun(TV_u_27a,t_h4s_nums_num),V_b0) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))))).
fof(ah4s_bags_BAGu_u_INu_u_BAGu_u_DELETE, axiom, ![TV_u_27a]: ![V_e, V_b]: (p(s(t_bool,h4s_bags_bagu_u_in(s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))) => ?[V_bu_27]: p(s(t_bool,h4s_bags_bagu_u_delete(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b),s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_bu_27)))))).
fof(ah4s_bags_BAGu_u_INSERTu_u_EQUAL, axiom, ![TV_u_27a]: ![V_b, V_a, V_N, V_M]: (s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_a),s(t_fun(TV_u_27a,t_h4s_nums_num),V_M))) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_b),s(t_fun(TV_u_27a,t_h4s_nums_num),V_N))) <=> ((s(t_fun(TV_u_27a,t_h4s_nums_num),V_M) = s(t_fun(TV_u_27a,t_h4s_nums_num),V_N) & s(TV_u_27a,V_a) = s(TV_u_27a,V_b)) | ?[V_k]: (s(t_fun(TV_u_27a,t_h4s_nums_num),V_M) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_b),s(t_fun(TV_u_27a,t_h4s_nums_num),V_k))) & s(t_fun(TV_u_27a,t_h4s_nums_num),V_N) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_a),s(t_fun(TV_u_27a,t_h4s_nums_num),V_k))))))).
fof(ah4s_bags_INu_u_SETu_u_OFu_u_BAG, axiom, ![TV_u_27a]: ![V_x, V_b]: s(t_bool,h4s_bools_in(s(TV_u_27a,V_x),s(t_fun(TV_u_27a,t_bool),h4s_bags_setu_u_ofu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))))) = s(t_bool,h4s_bags_bagu_u_in(s(TV_u_27a,V_x),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))).
fof(ah4s_bags_FINITEu_u_BAGu_u_INSERT, axiom, ![TV_u_27a]: ![V_b]: (p(s(t_bool,h4s_bags_finiteu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))) => ![V_e]: p(s(t_bool,h4s_bags_finiteu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))))))).
fof(ah4s_bags_STRONGu_u_FINITEu_u_BAGu_u_INDUCT, axiom, ![TV_u_27a]: ![V_P]: ((p(s(t_bool,happ(s(t_fun(t_fun(TV_u_27a,t_h4s_nums_num),t_bool),V_P),s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_emptyu_u_bag)))) & ![V_b]: ((p(s(t_bool,h4s_bags_finiteu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))) & p(s(t_bool,happ(s(t_fun(t_fun(TV_u_27a,t_h4s_nums_num),t_bool),V_P),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))))) => ![V_e]: p(s(t_bool,happ(s(t_fun(t_fun(TV_u_27a,t_h4s_nums_num),t_bool),V_P),s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))))))) => ![V_b]: (p(s(t_bool,h4s_bags_finiteu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))) => p(s(t_bool,happ(s(t_fun(t_fun(TV_u_27a,t_h4s_nums_num),t_bool),V_P),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))))))).
fof(ah4s_bags_FINITEu_u_BAGu_u_THMu_c0, axiom, ![TV_u_27a]: p(s(t_bool,h4s_bags_finiteu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_emptyu_u_bag))))).
fof(ah4s_bags_FINITEu_u_BAGu_u_THMu_c1, axiom, ![TV_u_27a]: ![V_e, V_b]: s(t_bool,h4s_bags_finiteu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))))) = s(t_bool,h4s_bags_finiteu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))).
fof(ah4s_bags_BAGu_u_CARDu_u_EMPTY, axiom, ![TV_u_27a]: s(t_h4s_nums_num,h4s_bags_bagu_u_card(s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_emptyu_u_bag))) = s(t_h4s_nums_num,h4s_nums_0)).
fof(ah4s_bags_BAGu_u_CARDu_u_THMu_c1, axiom, ![TV_u_27a]: ![V_b]: (p(s(t_bool,h4s_bags_finiteu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))) => ![V_e]: s(t_h4s_nums_num,h4s_bags_bagu_u_card(s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_insert(s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))))) = s(t_h4s_nums_num,h4s_arithmetics_u_2b(s(t_h4s_nums_num,h4s_bags_bagu_u_card(s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))),s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,h4s_arithmetics_bit1(s(t_h4s_nums_num,h4s_arithmetics_zero))))))))).
fof(ah4s_bags_BAGu_u_IMAGEu_u_DEF, axiom, ![TV_u_27a,TV_u_27b]: ![V_uu_1]: (![V_f, V_x, V_e0]: (p(s(t_bool,happ(s(t_fun(TV_u_27b,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27b,t_bool)),happ(s(t_fun(t_fun(TV_u_27b,TV_u_27a),t_fun(TV_u_27a,t_fun(TV_u_27b,t_bool))),V_uu_1),s(t_fun(TV_u_27b,TV_u_27a),V_f))),s(TV_u_27a,V_x))),s(TV_u_27b,V_e0)))) <=> s(TV_u_27a,happ(s(t_fun(TV_u_27b,TV_u_27a),V_f),s(TV_u_27b,V_e0))) = s(TV_u_27a,V_x)) => ![V_uu_0]: (![V_sb]: s(t_h4s_nums_num,happ(s(t_fun(t_fun(TV_u_27b,t_h4s_nums_num),t_h4s_nums_num),V_uu_0),s(t_fun(TV_u_27b,t_h4s_nums_num),V_sb))) = s(t_h4s_nums_num,h4s_bools_cond(s(t_bool,h4s_bags_finiteu_u_bag(s(t_fun(TV_u_27b,t_h4s_nums_num),V_sb))),s(t_h4s_nums_num,h4s_bags_bagu_u_card(s(t_fun(TV_u_27b,t_h4s_nums_num),V_sb))),s(t_h4s_nums_num,h4s_arithmetics_numeral(s(t_h4s_nums_num,h4s_arithmetics_bit1(s(t_h4s_nums_num,h4s_arithmetics_zero))))))) => ![V_f, V_b, V_x]: s(t_h4s_nums_num,happ(s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_image(s(t_fun(TV_u_27b,TV_u_27a),V_f),s(t_fun(TV_u_27b,t_h4s_nums_num),V_b))),s(TV_u_27a,V_x))) = s(t_h4s_nums_num,h4s_bools_let(s(t_fun(t_fun(TV_u_27b,t_h4s_nums_num),t_h4s_nums_num),V_uu_0),s(t_fun(TV_u_27b,t_h4s_nums_num),h4s_bags_bagu_u_filter(s(t_fun(TV_u_27b,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27b,t_bool)),happ(s(t_fun(t_fun(TV_u_27b,TV_u_27a),t_fun(TV_u_27a,t_fun(TV_u_27b,t_bool))),V_uu_1),s(t_fun(TV_u_27b,TV_u_27a),V_f))),s(TV_u_27a,V_x))),s(t_fun(TV_u_27b,t_h4s_nums_num),V_b)))))))).
fof(ah4s_bags_BAGu_u_EVERY0, axiom, ![TV_u_27a]: ![V_b, V_P]: (p(s(t_bool,h4s_bags_bagu_u_every(s(t_fun(TV_u_27a,t_bool),V_P),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))) <=> ![V_e]: (p(s(t_bool,h4s_bags_bagu_u_in(s(TV_u_27a,V_e),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))) => p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_P),s(TV_u_27a,V_e))))))).
fof(ah4s_bags_BAGu_u_FILTERu_u_EQu_u_EMPTY, axiom, ![TV_u_27a]: ![V_b, V_P]: (s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_filter(s(t_fun(TV_u_27a,t_bool),V_P),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b))) = s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_emptyu_u_bag) <=> p(s(t_bool,h4s_bags_bagu_u_every(s(t_fun(TV_u_27a,t_bool),h4s_combins_o(s(t_fun(t_bool,t_bool),d_not),s(t_fun(TV_u_27a,t_bool),V_P))),s(t_fun(TV_u_27a,t_h4s_nums_num),V_b)))))).
fof(ch4s_bags_SETu_u_OFu_u_BAGu_u_IMAGE, conjecture, ![TV_u_27a,TV_u_27b]: ![V_f, V_b]: s(t_fun(TV_u_27a,t_bool),h4s_bags_setu_u_ofu_u_bag(s(t_fun(TV_u_27a,t_h4s_nums_num),h4s_bags_bagu_u_image(s(t_fun(TV_u_27b,TV_u_27a),V_f),s(t_fun(TV_u_27b,t_h4s_nums_num),V_b))))) = s(t_fun(TV_u_27a,t_bool),h4s_predu_u_sets_image(s(t_fun(TV_u_27b,TV_u_27a),V_f),s(t_fun(TV_u_27b,t_bool),h4s_bags_setu_u_ofu_u_bag(s(t_fun(TV_u_27b,t_h4s_nums_num),V_b)))))).
