%   ORIGINAL: h4/tc/subTC__thm
% 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/ETA__AX: !t. (\x. t x) = t
% Assm: h4/bool/TRUTH: T
% Assm: h4/bool/IMP__ANTISYM__AX: !t2 t1. (t1 ==> t2) ==> (t2 ==> t1) ==> (t1 <=> t2)
% Assm: h4/bool/AND__CLAUSES_c0: !t. T /\ t <=> t
% Assm: h4/bool/AND__CLAUSES_c1: !t. t /\ T <=> t
% Assm: h4/bool/OR__CLAUSES_c0: !t. T \/ t <=> T
% Assm: h4/bool/EQ__CLAUSES_c1: !t. (t <=> T) <=> t
% Assm: h4/relation/RTC__lifts__invariants: !R P. (!x y. P x /\ R x y ==> P y) ==> (!x y. P x /\ h4/relation/RTC R x y ==> P y)
% Assm: h4/relation/O__DEF: !z x R2 R1. h4/relation/O R1 R2 x z <=> (?y. R2 x y /\ R1 y z)
% Assm: h4/relation/RUNION0: !y x R2 R1. h4/relation/RUNION R1 R2 x y <=> R1 x y \/ R2 x y
% Assm: h4/tc/DRESTR: !s b a R. h4/tc/_5E_7C R s a b <=> h4/bool/IN a s /\ R a b
% Assm: h4/tc/RRESTR: !s b a R. h4/tc/_7C_5E R s a b <=> h4/bool/IN b s /\ R a b
% Assm: h4/tc/BRESTR: !s R. h4/tc/_5E_7C_5E R s = h4/tc/_7C_5E (h4/tc/_5E_7C R s) s
% Assm: h4/tc/subTC0: !y x s R. h4/tc/subTC R s x y <=> R x y \/ (?a b. h4/relation/RTC (h4/tc/_5E_7C_5E R s) a b /\ h4/bool/IN a s /\ h4/bool/IN b s /\ R x a /\ R b y)
% Goal: !s R. h4/tc/subTC R s = h4/relation/RUNION R (h4/relation/O R (h4/relation/O (h4/tc/_5E_7C (h4/relation/RTC (h4/tc/_5E_7C_5E R s)) s) R))
%   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_ETAu_u_AX]: !t x. happ t x = happ t x
% Assm [h4s_bools_TRUTH]: T
% Assm [h4s_bools_IMPu_u_ANTISYMu_u_AX]: !t2 t1. (t1 ==> t2) ==> (t2 ==> t1) ==> (t1 <=> t2)
% Assm [h4s_bools_ANDu_u_CLAUSESu_c0]: !t. T /\ t <=> t
% Assm [h4s_bools_ANDu_u_CLAUSESu_c1]: !t. t /\ T <=> t
% Assm [h4s_bools_ORu_u_CLAUSESu_c0]: !t. T \/ t <=> T
% Assm [h4s_bools_EQu_u_CLAUSESu_c1]: !t. (t <=> T) <=> t
% Assm [h4s_relations_RTCu_u_liftsu_u_invariants]: !R P. (!x y. happ P x /\ happ (happ R x) y ==> happ P y) ==> (!x y. happ P x /\ happ (happ (h4/relation/RTC R) x) y ==> happ P y)
% Assm [h4s_relations_Ou_u_DEF]: !z x R2 R1. happ (happ (h4/relation/O R1 R2) x) z <=> (?y. happ (happ R2 x) y /\ happ (happ R1 y) z)
% Assm [h4s_relations_RUNION0]: !y x R2 R1. happ (happ (h4/relation/RUNION R1 R2) x) y <=> happ (happ R1 x) y \/ happ (happ R2 x) y
% Assm [h4s_tcs_DRESTR]: !s b a R. happ (happ (h4/tc/_5E_7C R s) a) b <=> h4/bool/IN a s /\ happ (happ R a) b
% Assm [h4s_tcs_RRESTR]: !s b a R. happ (happ (h4/tc/_7C_5E R s) a) b <=> h4/bool/IN b s /\ happ (happ R a) b
% Assm [h4s_tcs_BRESTR]: !s R. h4/tc/_5E_7C_5E R s = h4/tc/_7C_5E (h4/tc/_5E_7C R s) s
% Assm [h4s_tcs_subTC0]: !y x s R. happ (happ (h4/tc/subTC R s) x) y <=> happ (happ R x) y \/ (?a b. happ (happ (h4/relation/RTC (h4/tc/_5E_7C_5E R s)) a) b /\ h4/bool/IN a s /\ h4/bool/IN b s /\ happ (happ R x) a /\ happ (happ R b) y)
% Goal: !s R. h4/tc/subTC R s = h4/relation/RUNION R (h4/relation/O R (h4/relation/O (h4/tc/_5E_7C (h4/relation/RTC (h4/tc/_5E_7C_5E R s)) s) R))
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_Q189448,TV_Q189444]: ![V_f, V_g]: (![V_x]: s(TV_Q189444,happ(s(t_fun(TV_Q189448,TV_Q189444),V_f),s(TV_Q189448,V_x))) = s(TV_Q189444,happ(s(t_fun(TV_Q189448,TV_Q189444),V_g),s(TV_Q189448,V_x))) => s(t_fun(TV_Q189448,TV_Q189444),V_f) = s(t_fun(TV_Q189448,TV_Q189444),V_g))).
fof(ah4s_bools_ETAu_u_AX, axiom, ![TV_u_27b,TV_u_27a]: ![V_t, V_x]: s(TV_u_27b,happ(s(t_fun(TV_u_27a,TV_u_27b),V_t),s(TV_u_27a,V_x))) = s(TV_u_27b,happ(s(t_fun(TV_u_27a,TV_u_27b),V_t),s(TV_u_27a,V_x)))).
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_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_c1, axiom, ![V_t]: ((p(s(t_bool,V_t)) & p(s(t_bool,t))) <=> p(s(t_bool,V_t)))).
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_EQu_u_CLAUSESu_c1, axiom, ![V_t]: (s(t_bool,V_t) = s(t_bool,t) <=> p(s(t_bool,V_t)))).
fof(ah4s_relations_RTCu_u_liftsu_u_invariants, axiom, ![TV_u_27a]: ![V_R, V_P]: (![V_x, V_y]: ((p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_P),s(TV_u_27a,V_x)))) & p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(TV_u_27a,V_x))),s(TV_u_27a,V_y))))) => p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_P),s(TV_u_27a,V_y))))) => ![V_x, V_y]: ((p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_P),s(TV_u_27a,V_x)))) & p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_relations_rtc(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R))),s(TV_u_27a,V_x))),s(TV_u_27a,V_y))))) => p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),V_P),s(TV_u_27a,V_y))))))).
fof(ah4s_relations_Ou_u_DEF, axiom, ![TV_u_27g,TV_u_27h,TV_u_27k]: ![V_z, V_x, V_R2, V_R1]: (p(s(t_bool,happ(s(t_fun(TV_u_27k,t_bool),happ(s(t_fun(TV_u_27g,t_fun(TV_u_27k,t_bool)),h4s_relations_o(s(t_fun(TV_u_27h,t_fun(TV_u_27k,t_bool)),V_R1),s(t_fun(TV_u_27g,t_fun(TV_u_27h,t_bool)),V_R2))),s(TV_u_27g,V_x))),s(TV_u_27k,V_z)))) <=> ?[V_y]: (p(s(t_bool,happ(s(t_fun(TV_u_27h,t_bool),happ(s(t_fun(TV_u_27g,t_fun(TV_u_27h,t_bool)),V_R2),s(TV_u_27g,V_x))),s(TV_u_27h,V_y)))) & p(s(t_bool,happ(s(t_fun(TV_u_27k,t_bool),happ(s(t_fun(TV_u_27h,t_fun(TV_u_27k,t_bool)),V_R1),s(TV_u_27h,V_y))),s(TV_u_27k,V_z))))))).
fof(ah4s_relations_RUNION0, axiom, ![TV_u_27a,TV_u_27b]: ![V_y, V_x, V_R2, V_R1]: (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)),h4s_relations_runion(s(t_fun(TV_u_27a,t_fun(TV_u_27b,t_bool)),V_R1),s(t_fun(TV_u_27a,t_fun(TV_u_27b,t_bool)),V_R2))),s(TV_u_27a,V_x))),s(TV_u_27b,V_y)))) <=> (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)),V_R1),s(TV_u_27a,V_x))),s(TV_u_27b,V_y)))) | 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)),V_R2),s(TV_u_27a,V_x))),s(TV_u_27b,V_y))))))).
fof(ah4s_tcs_DRESTR, axiom, ![TV_u_27a]: ![V_s, V_b, V_a, V_R]: (p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_u_5eu_7c(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_bool),V_s))),s(TV_u_27a,V_a))),s(TV_u_27a,V_b)))) <=> (p(s(t_bool,h4s_bools_in(s(TV_u_27a,V_a),s(t_fun(TV_u_27a,t_bool),V_s)))) & p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(TV_u_27a,V_a))),s(TV_u_27a,V_b))))))).
fof(ah4s_tcs_RRESTR, axiom, ![TV_u_27a]: ![V_s, V_b, V_a, V_R]: (p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_u_7cu_5e(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_bool),V_s))),s(TV_u_27a,V_a))),s(TV_u_27a,V_b)))) <=> (p(s(t_bool,h4s_bools_in(s(TV_u_27a,V_b),s(t_fun(TV_u_27a,t_bool),V_s)))) & p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(TV_u_27a,V_a))),s(TV_u_27a,V_b))))))).
fof(ah4s_tcs_BRESTR, axiom, ![TV_u_27a]: ![V_s, V_R]: s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_u_5eu_7cu_5e(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_bool),V_s))) = s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_u_7cu_5e(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_u_5eu_7c(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_bool),V_s))),s(t_fun(TV_u_27a,t_bool),V_s)))).
fof(ah4s_tcs_subTC0, axiom, ![TV_u_27a]: ![V_y, V_x, V_s, V_R]: (p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_subtc(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_bool),V_s))),s(TV_u_27a,V_x))),s(TV_u_27a,V_y)))) <=> (p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(TV_u_27a,V_x))),s(TV_u_27a,V_y)))) | ?[V_a, V_b]: (p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_relations_rtc(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_u_5eu_7cu_5e(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_bool),V_s))))),s(TV_u_27a,V_a))),s(TV_u_27a,V_b)))) & (p(s(t_bool,h4s_bools_in(s(TV_u_27a,V_a),s(t_fun(TV_u_27a,t_bool),V_s)))) & (p(s(t_bool,h4s_bools_in(s(TV_u_27a,V_b),s(t_fun(TV_u_27a,t_bool),V_s)))) & (p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(TV_u_27a,V_x))),s(TV_u_27a,V_a)))) & p(s(t_bool,happ(s(t_fun(TV_u_27a,t_bool),happ(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(TV_u_27a,V_b))),s(TV_u_27a,V_y))))))))))).
fof(ch4s_tcs_subTCu_u_thm, conjecture, ![TV_u_27a]: ![V_s, V_R]: s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_subtc(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_bool),V_s))) = s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_relations_runion(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_relations_o(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_relations_o(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_u_5eu_7c(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_relations_rtc(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),h4s_tcs_u_5eu_7cu_5e(s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R),s(t_fun(TV_u_27a,t_bool),V_s))))),s(t_fun(TV_u_27a,t_bool),V_s))),s(t_fun(TV_u_27a,t_fun(TV_u_27a,t_bool)),V_R)))))))).
