Library GeoCoq.Elements.OriginalProofs.proposition_23C
Require Export GeoCoq.Elements.OriginalProofs.proposition_23B.
Section Euclid.
Context `{Ax:euclidean_neutral_ruler_compass}.
Lemma proposition_23C :
forall A B C D E P,
neq A B -> nCol D C E -> nCol A B P ->
exists X Y, Out A B Y /\ CongA X A Y D C E /\ OS X P A B.
Proof.
intros.
assert (neq B A) by (conclude lemma_inequalitysymmetric).
assert (~ eq P A).
{
intro.
assert (eq A P) by (conclude lemma_equalitysymmetric).
assert (Col A B P) by (conclude_def Col ).
contradict.
}
let Tf:=fresh in
assert (Tf:exists Q, (BetS P A Q /\ Cong A Q P A)) by (conclude postulate_extension);destruct Tf as [Q];spliter.
assert (eq A A) by (conclude cn_equalityreflexive).
assert (Col A B A) by (conclude_def Col ).
assert (TS P A B Q) by (conclude_def TS ).
assert (~ Col A B Q).
{
intro.
assert (Col P A Q) by (conclude_def Col ).
assert (Col Q A B) by (forward_using lemma_collinearorder).
assert (Col Q A P) by (forward_using lemma_collinearorder).
assert (neq A Q) by (forward_using lemma_betweennotequal).
assert (neq Q A) by (conclude lemma_inequalitysymmetric).
assert (Col A B P) by (conclude lemma_collinear4).
contradict.
}
let Tf:=fresh in
assert (Tf:exists F G, (Out A B G /\ CongA F A G D C E /\ TS F A B Q)) by (conclude proposition_23B);destruct Tf as [F[G]];spliter.
let Tf:=fresh in
assert (Tf:exists J, (BetS F J Q /\ Col A B J /\ nCol A B F)) by (conclude_def TS );destruct Tf as [J];spliter.
assert (OS F P A B) by (conclude_def OS ).
close.
Qed.
End Euclid.
Section Euclid.
Context `{Ax:euclidean_neutral_ruler_compass}.
Lemma proposition_23C :
forall A B C D E P,
neq A B -> nCol D C E -> nCol A B P ->
exists X Y, Out A B Y /\ CongA X A Y D C E /\ OS X P A B.
Proof.
intros.
assert (neq B A) by (conclude lemma_inequalitysymmetric).
assert (~ eq P A).
{
intro.
assert (eq A P) by (conclude lemma_equalitysymmetric).
assert (Col A B P) by (conclude_def Col ).
contradict.
}
let Tf:=fresh in
assert (Tf:exists Q, (BetS P A Q /\ Cong A Q P A)) by (conclude postulate_extension);destruct Tf as [Q];spliter.
assert (eq A A) by (conclude cn_equalityreflexive).
assert (Col A B A) by (conclude_def Col ).
assert (TS P A B Q) by (conclude_def TS ).
assert (~ Col A B Q).
{
intro.
assert (Col P A Q) by (conclude_def Col ).
assert (Col Q A B) by (forward_using lemma_collinearorder).
assert (Col Q A P) by (forward_using lemma_collinearorder).
assert (neq A Q) by (forward_using lemma_betweennotequal).
assert (neq Q A) by (conclude lemma_inequalitysymmetric).
assert (Col A B P) by (conclude lemma_collinear4).
contradict.
}
let Tf:=fresh in
assert (Tf:exists F G, (Out A B G /\ CongA F A G D C E /\ TS F A B Q)) by (conclude proposition_23B);destruct Tf as [F[G]];spliter.
let Tf:=fresh in
assert (Tf:exists J, (BetS F J Q /\ Col A B J /\ nCol A B F)) by (conclude_def TS );destruct Tf as [J];spliter.
assert (OS F P A B) by (conclude_def OS ).
close.
Qed.
End Euclid.