%   ORIGINAL: h4/alist/alist__to__fmap__PERM
% 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/TRUTH: T
% Assm: h4/bool/IMP__CLAUSES_c4: !t. t ==> F <=> ~t
% Assm: h4/bool/NOT__CLAUSES_c0: !t. ~ ~t <=> t
% Assm: h4/bool/EQ__CLAUSES_c1: !t. (t <=> T) <=> t
% Assm: h4/bool/RIGHT__OR__OVER__AND: !C B A. B /\ C \/ A <=> (B \/ A) /\ (C \/ A)
% 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/sat/pth__ni1: !q p. ~(p ==> q) ==> p
% Assm: h4/sat/pth__ni2: !q p. ~(p ==> q) ==> ~q
% Assm: h4/sorting/PERM__TRANS: !z y x. h4/sorting/PERM x y /\ h4/sorting/PERM y z ==> h4/sorting/PERM x z
% Assm: h4/sorting/PERM__SYM: !l2 l1. h4/sorting/PERM l1 l2 <=> h4/sorting/PERM l2 l1
% Assm: h4/sorting/ALL__DISTINCT__PERM: !l2 l1. h4/sorting/PERM l1 l2 ==> (h4/list/ALL__DISTINCT l1 <=> h4/list/ALL__DISTINCT l2)
% Assm: h4/sorting/PERM__MAP: !l2 l1 f. h4/sorting/PERM l1 l2 ==> h4/sorting/PERM (h4/list/MAP f l1) (h4/list/MAP f l2)
% Assm: h4/alist/alist__to__fmap__to__alist__PERM: !al. h4/list/ALL__DISTINCT (h4/list/MAP h4/pair/FST al) ==> h4/sorting/PERM (h4/alist/fmap__to__alist (h4/alist/alist__to__fmap al)) al
% Assm: h4/alist/PERM__fmap__to__alist: !fm2 fm1. h4/sorting/PERM (h4/alist/fmap__to__alist fm1) (h4/alist/fmap__to__alist fm2) <=> fm1 = fm2
% Goal: !l2 l1. h4/sorting/PERM l1 l2 /\ h4/list/ALL__DISTINCT (h4/list/MAP h4/pair/FST l1) ==> h4/alist/alist__to__fmap l1 = h4/alist/alist__to__fmap l2
%   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_TRUTH]: 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_EQu_u_CLAUSESu_c1]: !t. (t <=> T) <=> t
% Assm [h4s_bools_RIGHTu_u_ORu_u_OVERu_u_AND]: !C B A. B /\ C \/ A <=> (B \/ A) /\ (C \/ A)
% 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_sats_pthu_u_ni1]: !q p. ~(p ==> q) ==> p
% Assm [h4s_sats_pthu_u_ni2]: !q p. ~(p ==> q) ==> ~q
% Assm [h4s_sortings_PERMu_u_TRANS]: !z y x. h4/sorting/PERM x y /\ h4/sorting/PERM y z ==> h4/sorting/PERM x z
% Assm [h4s_sortings_PERMu_u_SYM]: !l2 l1. h4/sorting/PERM l1 l2 <=> h4/sorting/PERM l2 l1
% Assm [h4s_sortings_ALLu_u_DISTINCTu_u_PERM]: !l2 l1. h4/sorting/PERM l1 l2 ==> (h4/list/ALL__DISTINCT l1 <=> h4/list/ALL__DISTINCT l2)
% Assm [h4s_sortings_PERMu_u_MAP]: !l2 l1 f. h4/sorting/PERM l1 l2 ==> h4/sorting/PERM (h4/list/MAP f l1) (h4/list/MAP f l2)
% Assm [h4s_alists_alistu_u_tou_u_fmapu_u_tou_u_alistu_u_PERM]: !al. h4/list/ALL__DISTINCT (h4/list/MAP h4/pair/FST al) ==> h4/sorting/PERM (h4/alist/fmap__to__alist (h4/alist/alist__to__fmap al)) al
% Assm [h4s_alists_PERMu_u_fmapu_u_tou_u_alist]: !fm2 fm1. h4/sorting/PERM (h4/alist/fmap__to__alist fm1) (h4/alist/fmap__to__alist fm2) <=> fm1 = fm2
% Goal: !l2 l1. h4/sorting/PERM l1 l2 /\ h4/list/ALL__DISTINCT (h4/list/MAP h4/pair/FST l1) ==> h4/alist/alist__to__fmap l1 = h4/alist/alist__to__fmap l2
fof(aHLu_TRUTH, axiom, p(s(t_bool,t))).
fof(aHLu_FALSITY, axiom, ~ (p(s(t_bool,f)))).
fof(aHLu_BOOLu_CASES, axiom, ![V_t]: (s(t_bool,V_t) = s(t_bool,t) | s(t_bool,V_t) = s(t_bool,f))).
fof(aHLu_EXT, axiom, ![TV_Q270969,TV_Q270965]: ![V_f, V_g]: (![V_x]: s(TV_Q270965,happ(s(t_fun(TV_Q270969,TV_Q270965),V_f),s(TV_Q270969,V_x))) = s(TV_Q270965,happ(s(t_fun(TV_Q270969,TV_Q270965),V_g),s(TV_Q270969,V_x))) => s(t_fun(TV_Q270969,TV_Q270965),V_f) = s(t_fun(TV_Q270969,TV_Q270965),V_g))).
fof(ah4s_bools_TRUTH, axiom, 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,f))) <=> ~ (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_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_RIGHTu_u_ORu_u_OVERu_u_AND, axiom, ![V_C, V_B, 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_A))) & (p(s(t_bool,V_C)) | p(s(t_bool,V_A)))))).
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,f))))).
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,f))) <=> ((p(s(t_bool,V_A)) => p(s(t_bool,f))) => (~ (p(s(t_bool,V_B))) => p(s(t_bool,f)))))).
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,f))) <=> (p(s(t_bool,V_A)) => (~ (p(s(t_bool,V_B))) => p(s(t_bool,f)))))).
fof(ah4s_sats_ANDu_u_INV2, axiom, ![V_A]: ((~ (p(s(t_bool,V_A))) => p(s(t_bool,f))) => ((p(s(t_bool,V_A)) => p(s(t_bool,f))) => p(s(t_bool,f))))).
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_sats_pthu_u_ni1, axiom, ![V_q, V_p]: (~ ((p(s(t_bool,V_p)) => p(s(t_bool,V_q)))) => p(s(t_bool,V_p)))).
fof(ah4s_sats_pthu_u_ni2, axiom, ![V_q, V_p]: (~ ((p(s(t_bool,V_p)) => p(s(t_bool,V_q)))) => ~ (p(s(t_bool,V_q))))).
fof(ah4s_sortings_PERMu_u_TRANS, axiom, ![TV_u_27a]: ![V_z, V_y, V_x]: ((p(s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(TV_u_27a),V_x),s(t_h4s_lists_list(TV_u_27a),V_y)))) & p(s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(TV_u_27a),V_y),s(t_h4s_lists_list(TV_u_27a),V_z))))) => p(s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(TV_u_27a),V_x),s(t_h4s_lists_list(TV_u_27a),V_z)))))).
fof(ah4s_sortings_PERMu_u_SYM, axiom, ![TV_u_27a]: ![V_l2, V_l1]: s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(TV_u_27a),V_l1),s(t_h4s_lists_list(TV_u_27a),V_l2))) = s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(TV_u_27a),V_l2),s(t_h4s_lists_list(TV_u_27a),V_l1)))).
fof(ah4s_sortings_ALLu_u_DISTINCTu_u_PERM, axiom, ![TV_u_27a]: ![V_l2, V_l1]: (p(s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(TV_u_27a),V_l1),s(t_h4s_lists_list(TV_u_27a),V_l2)))) => s(t_bool,h4s_lists_allu_u_distinct(s(t_h4s_lists_list(TV_u_27a),V_l1))) = s(t_bool,h4s_lists_allu_u_distinct(s(t_h4s_lists_list(TV_u_27a),V_l2))))).
fof(ah4s_sortings_PERMu_u_MAP, axiom, ![TV_u_27b,TV_u_27a]: ![V_l2, V_l1, V_f]: (p(s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(TV_u_27a),V_l1),s(t_h4s_lists_list(TV_u_27a),V_l2)))) => p(s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(TV_u_27b),h4s_lists_map(s(t_fun(TV_u_27a,TV_u_27b),V_f),s(t_h4s_lists_list(TV_u_27a),V_l1))),s(t_h4s_lists_list(TV_u_27b),h4s_lists_map(s(t_fun(TV_u_27a,TV_u_27b),V_f),s(t_h4s_lists_list(TV_u_27a),V_l2)))))))).
fof(ah4s_alists_alistu_u_tou_u_fmapu_u_tou_u_alistu_u_PERM, axiom, ![TV_u_27a,TV_u_27b]: ![V_al]: (p(s(t_bool,h4s_lists_allu_u_distinct(s(t_h4s_lists_list(TV_u_27a),h4s_lists_map(s(t_fun(t_h4s_pairs_prod(TV_u_27a,TV_u_27b),TV_u_27a),h4s_pairs_fst),s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),V_al)))))) => p(s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),h4s_alists_fmapu_u_tou_u_alist(s(t_h4s_finiteu_u_maps_fmap(TV_u_27a,TV_u_27b),h4s_alists_alistu_u_tou_u_fmap(s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),V_al))))),s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),V_al)))))).
fof(ah4s_alists_PERMu_u_fmapu_u_tou_u_alist, axiom, ![TV_u_27a,TV_u_27b]: ![V_fm2, V_fm1]: (p(s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),h4s_alists_fmapu_u_tou_u_alist(s(t_h4s_finiteu_u_maps_fmap(TV_u_27a,TV_u_27b),V_fm1))),s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),h4s_alists_fmapu_u_tou_u_alist(s(t_h4s_finiteu_u_maps_fmap(TV_u_27a,TV_u_27b),V_fm2)))))) <=> s(t_h4s_finiteu_u_maps_fmap(TV_u_27a,TV_u_27b),V_fm1) = s(t_h4s_finiteu_u_maps_fmap(TV_u_27a,TV_u_27b),V_fm2))).
fof(ch4s_alists_alistu_u_tou_u_fmapu_u_PERM, conjecture, ![TV_u_27a,TV_u_27b]: ![V_l2, V_l1]: ((p(s(t_bool,h4s_sortings_perm(s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),V_l1),s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),V_l2)))) & p(s(t_bool,h4s_lists_allu_u_distinct(s(t_h4s_lists_list(TV_u_27a),h4s_lists_map(s(t_fun(t_h4s_pairs_prod(TV_u_27a,TV_u_27b),TV_u_27a),h4s_pairs_fst),s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),V_l1))))))) => s(t_h4s_finiteu_u_maps_fmap(TV_u_27a,TV_u_27b),h4s_alists_alistu_u_tou_u_fmap(s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),V_l1))) = s(t_h4s_finiteu_u_maps_fmap(TV_u_27a,TV_u_27b),h4s_alists_alistu_u_tou_u_fmap(s(t_h4s_lists_list(t_h4s_pairs_prod(TV_u_27a,TV_u_27b)),V_l2))))).
