Library GeoCoq.Elements.OriginalProofs.lemma_crossbar
Require Export GeoCoq.Elements.OriginalProofs.lemma_raystrict.
Require Export GeoCoq.Elements.OriginalProofs.lemma_collinear4.
Require Export GeoCoq.Elements.OriginalProofs.lemma_lessthancongruence.
Section Euclid.
Context `{Ax:euclidean_neutral}.
Lemma lemma_crossbar :
∀ A B C E U V,
Triangle A B C → BetS A E C → Out B A U → Out B C V →
∃ X, Out B E X ∧ BetS U X V.
Proof.
intros.
assert (nCol A B C) by (conclude_def Triangle ).
assert (¬ eq B E).
{
intro.
assert (¬ BetS A B C).
{
intro.
assert (Col A B C) by (conclude_def Col ).
contradict.
}
assert (BetS A B C) by (conclude cn_equalitysub).
contradict.
}
assert (¬ eq B A).
{
intro.
assert (eq A B) by (conclude lemma_equalitysymmetric).
assert (Col A B C) by (conclude_def Col ).
contradict.
}
assert (¬ eq B C).
{
intro.
assert (Col A B C) by (conclude_def Col ).
contradict.
}
assert (neq B U) by (conclude lemma_raystrict).
assert (neq B V) by (conclude lemma_raystrict).
let Tf:=fresh in
assert (Tf:∃ P, (BetS B A P ∧ Cong A P B U)) by (conclude postulate_extension);destruct Tf as [P];spliter.
let Tf:=fresh in
assert (Tf:∃ Q, (BetS B C Q ∧ Cong C Q B V)) by (conclude postulate_extension);destruct Tf as [Q];spliter.
assert (¬ Col B Q A).
{
intro.
assert (Col Q B A) by (forward_using lemma_collinearorder).
assert (Col B C Q) by (conclude_def Col ).
assert (Col Q B C) by (forward_using lemma_collinearorder).
assert (neq B Q) by (forward_using lemma_betweennotequal).
assert (neq Q B) by (conclude lemma_inequalitysymmetric).
assert (Col B A C) by (conclude lemma_collinear4).
assert (Col A B C) by (forward_using lemma_collinearorder).
contradict.
}
let Tf:=fresh in
assert (Tf:∃ F, (BetS A F Q ∧ BetS B E F)) by (conclude postulate_Pasch_outer);destruct Tf as [F];spliter.
assert (BetS Q F A) by (conclude axiom_betweennesssymmetry).
assert (¬ Col B P Q).
{
intro.
assert (Col P B Q) by (forward_using lemma_collinearorder).
assert (Col B A P) by (conclude_def Col ).
assert (Col P B A) by (forward_using lemma_collinearorder).
assert (neq B P) by (forward_using lemma_betweennotequal).
assert (neq P B) by (conclude lemma_inequalitysymmetric).
assert (Col B Q A) by (conclude lemma_collinear4).
contradict.
}
let Tf:=fresh in
assert (Tf:∃ W, (BetS Q W P ∧ BetS B F W)) by (conclude postulate_Pasch_outer);destruct Tf as [W];spliter.
assert (BetS P W Q) by (conclude axiom_betweennesssymmetry).
assert (BetS B E W) by (conclude lemma_3_6b).
let Tf:=fresh in
assert (Tf:∃ J, (BetS J B U ∧ BetS J B A)) by (conclude_def Out );destruct Tf as [J];spliter.
assert (Cong A P P A) by (conclude cn_equalityreverse).
assert (Cong B U A P) by (conclude lemma_congruencesymmetric).
assert (Cong B U P A) by (conclude lemma_congruencetransitive).
assert (Cong P A B U) by (conclude lemma_congruencesymmetric).
assert (BetS P A B) by (conclude axiom_betweennesssymmetry).
assert (Lt B U P B) by (conclude_def Lt ).
assert (Cong P B B P) by (conclude cn_equalityreverse).
assert (Lt B U B P) by (conclude lemma_lessthancongruence).
let Tf:=fresh in
assert (Tf:∃ S, (BetS B S P ∧ Cong B S B U)) by (conclude_def Lt );destruct Tf as [S];spliter.
assert (BetS J B P) by (conclude lemma_3_7b).
assert (BetS J B S) by (conclude axiom_innertransitivity).
assert (neq J B) by (forward_using lemma_betweennotequal).
assert (eq S U) by (conclude lemma_extensionunique).
assert (BetS B U P) by (conclude cn_equalitysub).
assert (BetS Q W P) by (conclude axiom_betweennesssymmetry).
let Tf:=fresh in
assert (Tf:∃ K, (BetS K B V ∧ BetS K B C)) by (conclude_def Out );destruct Tf as [K];spliter.
assert (Cong B Q Q B) by (conclude cn_equalityreverse).
assert (Cong B V C Q) by (conclude lemma_congruencesymmetric).
assert (Cong C Q Q C) by (conclude cn_equalityreverse).
assert (Cong B V Q C) by (conclude lemma_congruencetransitive).
assert (Cong Q C B V) by (conclude lemma_congruencesymmetric).
assert (BetS Q C B) by (conclude axiom_betweennesssymmetry).
assert (Lt B V Q B) by (conclude_def Lt ).
assert (Cong Q B B Q) by (conclude cn_equalityreverse).
assert (Lt B V B Q) by (conclude lemma_lessthancongruence).
let Tf:=fresh in
assert (Tf:∃ R, (BetS B R Q ∧ Cong B R B V)) by (conclude_def Lt );destruct Tf as [R];spliter.
assert (BetS K B Q) by (conclude lemma_3_7b).
assert (BetS K B R) by (conclude axiom_innertransitivity).
assert (neq K B) by (forward_using lemma_betweennotequal).
assert (eq R V) by (conclude lemma_extensionunique).
assert (BetS B V Q) by (conclude cn_equalitysub).
assert (¬ Col Q P B).
{
intro.
assert (Col B P Q) by (forward_using lemma_collinearorder).
contradict.
}
let Tf:=fresh in
assert (Tf:∃ M, (BetS Q M U ∧ BetS B M W)) by (conclude postulate_Pasch_inner);destruct Tf as [M];spliter.
assert (BetS U M Q) by (conclude axiom_betweennesssymmetry).
assert (BetS Q V B) by (conclude axiom_betweennesssymmetry).
assert (¬ Col U Q B).
{
intro.
assert (Col B U P) by (conclude_def Col ).
assert (Col B U Q) by (forward_using lemma_collinearorder).
assert (neq B U) by (forward_using lemma_betweennotequal).
assert (Col U P Q) by (conclude lemma_collinear4).
assert (Col U Q P) by (forward_using lemma_collinearorder).
assert (Col U B P) by (forward_using lemma_collinearorder).
assert (Col U B Q) by (forward_using lemma_collinearorder).
assert (neq U B) by (conclude lemma_inequalitysymmetric).
assert (Col B P Q) by (conclude lemma_collinear4).
assert (Col Q P B) by (forward_using lemma_collinearorder).
contradict.
}
rename_H H;
let Tf:=fresh in
assert (Tf:∃ H, (BetS U H V ∧ BetS B H M)) by (conclude postulate_Pasch_inner);destruct Tf as [H];spliter.
assert (¬ eq E B).
{
intro.
assert (eq B E) by (conclude lemma_equalitysymmetric).
contradict.
}
let Tf:=fresh in
assert (Tf:∃ N, (BetS E B N ∧ Cong B N B E)) by (conclude postulate_extension);destruct Tf as [N];spliter.
assert (BetS N B E) by (conclude axiom_betweennesssymmetry).
assert (BetS B H W) by (conclude lemma_3_6b).
assert (BetS N B W) by (conclude lemma_3_7b).
assert (BetS N B H) by (conclude axiom_innertransitivity).
assert (Out B E H) by (conclude_def Out ).
close.
Qed.
End Euclid.
Require Export GeoCoq.Elements.OriginalProofs.lemma_collinear4.
Require Export GeoCoq.Elements.OriginalProofs.lemma_lessthancongruence.
Section Euclid.
Context `{Ax:euclidean_neutral}.
Lemma lemma_crossbar :
∀ A B C E U V,
Triangle A B C → BetS A E C → Out B A U → Out B C V →
∃ X, Out B E X ∧ BetS U X V.
Proof.
intros.
assert (nCol A B C) by (conclude_def Triangle ).
assert (¬ eq B E).
{
intro.
assert (¬ BetS A B C).
{
intro.
assert (Col A B C) by (conclude_def Col ).
contradict.
}
assert (BetS A B C) by (conclude cn_equalitysub).
contradict.
}
assert (¬ eq B A).
{
intro.
assert (eq A B) by (conclude lemma_equalitysymmetric).
assert (Col A B C) by (conclude_def Col ).
contradict.
}
assert (¬ eq B C).
{
intro.
assert (Col A B C) by (conclude_def Col ).
contradict.
}
assert (neq B U) by (conclude lemma_raystrict).
assert (neq B V) by (conclude lemma_raystrict).
let Tf:=fresh in
assert (Tf:∃ P, (BetS B A P ∧ Cong A P B U)) by (conclude postulate_extension);destruct Tf as [P];spliter.
let Tf:=fresh in
assert (Tf:∃ Q, (BetS B C Q ∧ Cong C Q B V)) by (conclude postulate_extension);destruct Tf as [Q];spliter.
assert (¬ Col B Q A).
{
intro.
assert (Col Q B A) by (forward_using lemma_collinearorder).
assert (Col B C Q) by (conclude_def Col ).
assert (Col Q B C) by (forward_using lemma_collinearorder).
assert (neq B Q) by (forward_using lemma_betweennotequal).
assert (neq Q B) by (conclude lemma_inequalitysymmetric).
assert (Col B A C) by (conclude lemma_collinear4).
assert (Col A B C) by (forward_using lemma_collinearorder).
contradict.
}
let Tf:=fresh in
assert (Tf:∃ F, (BetS A F Q ∧ BetS B E F)) by (conclude postulate_Pasch_outer);destruct Tf as [F];spliter.
assert (BetS Q F A) by (conclude axiom_betweennesssymmetry).
assert (¬ Col B P Q).
{
intro.
assert (Col P B Q) by (forward_using lemma_collinearorder).
assert (Col B A P) by (conclude_def Col ).
assert (Col P B A) by (forward_using lemma_collinearorder).
assert (neq B P) by (forward_using lemma_betweennotequal).
assert (neq P B) by (conclude lemma_inequalitysymmetric).
assert (Col B Q A) by (conclude lemma_collinear4).
contradict.
}
let Tf:=fresh in
assert (Tf:∃ W, (BetS Q W P ∧ BetS B F W)) by (conclude postulate_Pasch_outer);destruct Tf as [W];spliter.
assert (BetS P W Q) by (conclude axiom_betweennesssymmetry).
assert (BetS B E W) by (conclude lemma_3_6b).
let Tf:=fresh in
assert (Tf:∃ J, (BetS J B U ∧ BetS J B A)) by (conclude_def Out );destruct Tf as [J];spliter.
assert (Cong A P P A) by (conclude cn_equalityreverse).
assert (Cong B U A P) by (conclude lemma_congruencesymmetric).
assert (Cong B U P A) by (conclude lemma_congruencetransitive).
assert (Cong P A B U) by (conclude lemma_congruencesymmetric).
assert (BetS P A B) by (conclude axiom_betweennesssymmetry).
assert (Lt B U P B) by (conclude_def Lt ).
assert (Cong P B B P) by (conclude cn_equalityreverse).
assert (Lt B U B P) by (conclude lemma_lessthancongruence).
let Tf:=fresh in
assert (Tf:∃ S, (BetS B S P ∧ Cong B S B U)) by (conclude_def Lt );destruct Tf as [S];spliter.
assert (BetS J B P) by (conclude lemma_3_7b).
assert (BetS J B S) by (conclude axiom_innertransitivity).
assert (neq J B) by (forward_using lemma_betweennotequal).
assert (eq S U) by (conclude lemma_extensionunique).
assert (BetS B U P) by (conclude cn_equalitysub).
assert (BetS Q W P) by (conclude axiom_betweennesssymmetry).
let Tf:=fresh in
assert (Tf:∃ K, (BetS K B V ∧ BetS K B C)) by (conclude_def Out );destruct Tf as [K];spliter.
assert (Cong B Q Q B) by (conclude cn_equalityreverse).
assert (Cong B V C Q) by (conclude lemma_congruencesymmetric).
assert (Cong C Q Q C) by (conclude cn_equalityreverse).
assert (Cong B V Q C) by (conclude lemma_congruencetransitive).
assert (Cong Q C B V) by (conclude lemma_congruencesymmetric).
assert (BetS Q C B) by (conclude axiom_betweennesssymmetry).
assert (Lt B V Q B) by (conclude_def Lt ).
assert (Cong Q B B Q) by (conclude cn_equalityreverse).
assert (Lt B V B Q) by (conclude lemma_lessthancongruence).
let Tf:=fresh in
assert (Tf:∃ R, (BetS B R Q ∧ Cong B R B V)) by (conclude_def Lt );destruct Tf as [R];spliter.
assert (BetS K B Q) by (conclude lemma_3_7b).
assert (BetS K B R) by (conclude axiom_innertransitivity).
assert (neq K B) by (forward_using lemma_betweennotequal).
assert (eq R V) by (conclude lemma_extensionunique).
assert (BetS B V Q) by (conclude cn_equalitysub).
assert (¬ Col Q P B).
{
intro.
assert (Col B P Q) by (forward_using lemma_collinearorder).
contradict.
}
let Tf:=fresh in
assert (Tf:∃ M, (BetS Q M U ∧ BetS B M W)) by (conclude postulate_Pasch_inner);destruct Tf as [M];spliter.
assert (BetS U M Q) by (conclude axiom_betweennesssymmetry).
assert (BetS Q V B) by (conclude axiom_betweennesssymmetry).
assert (¬ Col U Q B).
{
intro.
assert (Col B U P) by (conclude_def Col ).
assert (Col B U Q) by (forward_using lemma_collinearorder).
assert (neq B U) by (forward_using lemma_betweennotequal).
assert (Col U P Q) by (conclude lemma_collinear4).
assert (Col U Q P) by (forward_using lemma_collinearorder).
assert (Col U B P) by (forward_using lemma_collinearorder).
assert (Col U B Q) by (forward_using lemma_collinearorder).
assert (neq U B) by (conclude lemma_inequalitysymmetric).
assert (Col B P Q) by (conclude lemma_collinear4).
assert (Col Q P B) by (forward_using lemma_collinearorder).
contradict.
}
rename_H H;
let Tf:=fresh in
assert (Tf:∃ H, (BetS U H V ∧ BetS B H M)) by (conclude postulate_Pasch_inner);destruct Tf as [H];spliter.
assert (¬ eq E B).
{
intro.
assert (eq B E) by (conclude lemma_equalitysymmetric).
contradict.
}
let Tf:=fresh in
assert (Tf:∃ N, (BetS E B N ∧ Cong B N B E)) by (conclude postulate_extension);destruct Tf as [N];spliter.
assert (BetS N B E) by (conclude axiom_betweennesssymmetry).
assert (BetS B H W) by (conclude lemma_3_6b).
assert (BetS N B W) by (conclude lemma_3_7b).
assert (BetS N B H) by (conclude axiom_innertransitivity).
assert (Out B E H) by (conclude_def Out ).
close.
Qed.
End Euclid.