Library GeoCoq.Elements.OriginalProofs.lemma_lessthanadditive

Require Export GeoCoq.Elements.OriginalProofs.lemma_lessthancongruence2.
Require Export GeoCoq.Elements.OriginalProofs.lemma_ray4.
Require Export GeoCoq.Elements.OriginalProofs.lemma_layoffunique.
Require Export GeoCoq.Elements.OriginalProofs.lemma_trichotomy2.
Require Export GeoCoq.Elements.OriginalProofs.lemma_outerconnectivity.

Section Euclid.

Context `{Ax:euclidean_neutral}.

Lemma lemma_lessthanadditive :
    A B C D E F,
   Lt A B C D BetS A B E BetS C D F Cong B E D F
   Lt A E C F.
Proof.
intros.
let Tf:=fresh in
assert (Tf: b, (BetS C b D Cong C b A B)) by (conclude_def Lt );destruct Tf as [b];spliter.
assert (Cong A B C b) by (conclude lemma_congruencesymmetric).
assert (neq C b) by (forward_using lemma_betweennotequal).
assert (neq b C) by (conclude lemma_inequalitysymmetric).
assert (neq B E) by (forward_using lemma_betweennotequal).
let Tf:=fresh in
assert (Tf: e, (BetS C b e Cong b e B E)) by (conclude postulate_extension);destruct Tf as [e];spliter.
assert (Cong B E b e) by (conclude lemma_congruencesymmetric).
assert (Cong A E C e) by (conclude lemma_sumofparts).
assert (Cong e D e D) by (conclude cn_congruencereflexive).
assert (BetS e b C) by (conclude axiom_betweennesssymmetry).
assert (BetS C b F) by (conclude lemma_3_6b).
assert (¬ BetS b F e).
 {
 intro.
 assert (Cong b F b F) by (conclude cn_congruencereflexive).
 assert (Lt b F b e) by (conclude_def Lt ).
 assert (Cong F D F D) by (conclude cn_congruencereflexive).
 assert (BetS b D F) by (conclude lemma_3_6a).
 assert (BetS F D b) by (conclude axiom_betweennesssymmetry).
 assert (Lt F D F b) by (conclude_def Lt ).
 assert (Cong F b b F) by (conclude cn_equalityreverse).
 assert (Lt F D b F) by (conclude lemma_lessthancongruence).
 assert (Cong F D D F) by (conclude cn_equalityreverse).
 assert (Lt D F b F) by (conclude lemma_lessthancongruence2).
 assert (Cong b e D F) by (conclude lemma_congruencetransitive).
 assert (Cong D F b e) by (conclude lemma_congruencesymmetric).
 assert (Lt b e b F) by (conclude lemma_lessthancongruence2).
 let Tf:=fresh in
 assert (Tf: q, (BetS b q F Cong b q b e)) by (conclude_def Lt );destruct Tf as [q];spliter.
 assert (neq b q) by (forward_using lemma_betweennotequal).
 assert (neq b F) by (forward_using lemma_betweennotequal).
 assert (Out b F q) by (conclude lemma_ray4).
 assert (Out b F e) by (conclude lemma_ray4).
 assert (eq q e) by (conclude lemma_layoffunique).
 assert (BetS b e F) by (conclude cn_equalitysub).
 assert (BetS F e F) by (conclude lemma_3_6a).
 assert (¬ BetS F e F) by (conclude axiom_betweennessidentity).
 contradict.
 }
assert (¬ eq F e).
 {
 intro.
 assert (Cong b F B E) by (conclude cn_equalitysub).
 assert (BetS b D F) by (conclude lemma_3_6a).
 assert (BetS F D b) by (conclude axiom_betweennesssymmetry).
 assert (Cong F D F D) by (conclude cn_congruencereflexive).
 assert (Lt F D F b) by (conclude_def Lt ).
 assert (Cong F b b F) by (conclude cn_equalityreverse).
 assert (Lt F D b F) by (conclude lemma_lessthancongruence).
 assert (Cong D F B E) by (conclude lemma_congruencesymmetric).
 assert (Cong F D B E) by (forward_using lemma_congruenceflip).
 assert (Lt B E b F) by (conclude lemma_lessthancongruence2).
 assert (Cong b F b e) by (conclude lemma_congruencetransitive).
 assert (Lt B E b e) by (conclude lemma_lessthancongruence).
 assert (Lt B E B E) by (conclude lemma_lessthancongruence).
 assert (¬ Lt B E B E) by (conclude lemma_trichotomy2).
 contradict.
 }
assert (¬ ¬ BetS b e F).
 {
 intro.
 assert (eq F e) by (conclude lemma_outerconnectivity).
 contradict.
 }
assert (BetS C e F) by (conclude lemma_3_7a).
assert (Cong A E C e) by (conclude lemma_sumofparts).
assert (Cong C e A E) by (conclude lemma_congruencesymmetric).
assert (Lt A E C F) by (conclude_def Lt ).
close.
Qed.

End Euclid.