Library orthocenter

Require Import circumcenter.
Require Import quadrilaterals_inter_dec.

Section Orthocenter.

Context `{MT:Tarski_2D_euclidean}.
Context `{EqDec:EqDecidability Tpoint}.
Context `{InterDec:InterDecidability Tpoint Col}.

Orthocenter
C'est une appliquette Java créée avec GeoGebra ( www.geogebra.org) - Il semble que Java ne soit pas installé sur votre ordinateur, merci d'aller sur www.java.com

Definition is_orthocenter H A B C :=
 ¬ Col A B C
  A1, B1, Perp A A1 B C Perp B B1 A C Col H A A1 Col H B B1.

Lemma construct_intersection : A B C X1 X2 X3,
 ¬ Col A B C
 Par A C B X1Par A B C X2Par B C A X3
  E, Col E A X3 Col E B X1.
Proof with finish.
intros A B C X1 X2 X3 HNC HPar1 HPar2 HPar3.
apply not_par_inter_exists.
intro HNPar; apply HNC.
assert (HFalsePar : Par B C A C)
  by (apply (parallel_trans B C B X1 A C); finish; apply (parallel_trans B C A X3 B); finish).
apply par_id_2...
Qed.

Lemma not_col_par_col2_diff : A B C D E F,
  ¬ Col A B CPar A B C DCol C D ECol A E FA E.
Proof.
intros A B C D E F HNC HPar HC1 HC2.
intro; subst.
apply HNC; apply not_strict_par1 with D E; finish.
Qed.

Lemma construct_triangle : A B C,
  ¬ Col A B C D, E, F,
  Col B D F Col A E F Col C D E
  Par A B C D Par A C B D Par B C A E
  Par A B C E Par A C B F Par B C A F
  D E D F E F.
Proof.
intros A B C HNC.
assert_diffs; rename H2 into HAB; rename H1 into HBC; rename H4 into HAC.

elim (parallel_existence_spec A B C HAB);intros X1 [HX1 HX1'].
elim (parallel_existence_spec A C B HAC);intros X2 [HX2 HX2'].
elim (parallel_existence_spec B C A HBC);intros X3 [HX3 HX3'].

assert (T : D, Col D B X2 Col D C X1) by (apply construct_intersection with A X3; finish); DecompExAnd T D.
assert (T : E, Col E A X3 Col E C X1) by (apply construct_intersection with B X2; finish); DecompExAnd T E.
assert (T : F, Col F A X3 Col F B X2) by (apply construct_intersection with C X1; finish); DecompExAnd T F.

assert (A E) by (apply not_col_par_col2_diff with B C X1 X3; finish).
assert (A F) by (apply not_col_par_col2_diff with C B X2 X3; finish).
assert (B D) by (apply not_col_par_col2_diff with A C X1 X2; finish).
assert (B F) by (apply not_col_par_col2_diff with C A X3 X2; finish).
assert (C D) by (apply not_col_par_col2_diff with A B X2 X1; finish).
assert (C E) by (apply not_col_par_col2_diff with B A X3 X1; finish).

assert (Par A B C D) by (apply par_col_par with X1; finish).
assert (Par A C B D) by (apply par_col_par with X2; finish).
assert (Par B C A E) by (apply par_col_par with X3; finish).
assert (Par A B C E) by (apply par_col_par with X1; finish).
assert (Par A C B F) by (apply par_col_par with X2; finish).
assert (Par B C A F) by (apply par_col_par with X3; finish).

assert (¬ (D = E D = F)).

  intro; spliter; treat_equalities.
  assert_paras.
  assert_nparas.
  permutation_intro_in_hyps.
  contradiction.

D; E; F.
assert_diffs.
deduce_cols.
repeat split; try cols; finish; clear_cols; untag_hyps.

intro; subst.
assert (E F) by (intro; subst; intuition).
apply HNC; apply col_permutation_1; apply not_strict_par1 with E A; sfinish.

intro; subst.
assert (E F) by (intro; subst; intuition).
apply HNC; apply col_permutation_2; apply not_strict_par1 with E C; sfinish.

intro; subst.
assert (D F) by (intro; subst; intuition).
apply HNC; apply not_strict_par1 with D B; sfinish.
Qed.

Lemma diff_not_col_col_par4_mid: A B C D E,
  D E¬ Col A B CCol C D EPar A B C D
  Par A B C EPar A E B CPar A C B Dis_midpoint C D E.
Proof.
intros A B C D E HD HNC HC HPar1 HPar2 HPar3 HPar4.
assert (HPara1 : Parallelogram_strict A B C E) by (apply parallel_2_plg; finish).
assert (HPara2 : Parallelogram_strict C A B D) by (apply parallel_2_plg; finish).
assert_congs.
apply cong_col_mid; Col; eCong.
Qed.

Lemma altitude_is_perp_bisect : A B C O A1 E F,
  A OE FPerp A A1 B CCol O A1 ACol A E FPar B C A Eis_midpoint A E F
  perp_bisect A O E F.
Proof with finish.
intros.
apply perp_mid_perp_bisect...
apply perp_sym.
apply par_perp_perp with B C.
apply par_col_par with A...
apply perp_col1 with A1...
Qed.

Lemma altitude_intersect:
  A A1 B B1 C C1 O: Tpoint,
 ¬ Col A B C
 Perp A A1 B CPerp B B1 A CPerp C C1 A B
 Col O A A1Col O B B1
 Col O C C1.
Proof with finish.
intros A A1 B B1 C C1 O HNC HPerp1 HPerp2 HPerp3 HC1 HC2.
assert (HT := HNC).
apply construct_triangle in HT.
destruct HT as [D [E [F HT]]].
spliter.

assert (is_midpoint A E F) by (apply diff_not_col_col_par4_mid with B C; finish).
assert (is_midpoint B D F) by (apply diff_not_col_col_par4_mid with A C; finish).
assert (is_midpoint C D E) by (apply diff_not_col_col_par4_mid with A B; finish).

assert_diffs.
cases_equality A O.

  treat_equalities; apply col_permutation_4; apply perp_perp_col with A B...
  apply perp_right_comm; apply perp_col1 with B1...

cases_equality B O.

  treat_equalities; apply col_permutation_4; apply perp_perp_col with A B...
  apply perp_col1 with A1...

cases_equality C O.

  subst; Col.

assert (perp_bisect A O E F) by (apply altitude_is_perp_bisect with B C A1; finish).
assert (perp_bisect B O D F) by (apply altitude_is_perp_bisect with A C B1; finish).

assert (Perp O C D E).

  apply circumcenter_intersect with F A B; finish.
  apply perp_bisect_sym_1; assumption.
  apply perp_bisect_sym_1; assumption.

assert (Perp C1 C D E).

  apply perp_sym; apply par_perp_perp with A B...
  apply par_symmetry; apply par_col_par_2 with C...

apply col_permutation_2; apply perp_perp_col with D E...
Qed.

End Orthocenter.