Nombres réels 1 : la structure de corps des réels
Les propriétés fondamentales du corps des réels
- les réels forment un corps : il y a une addition et une multiplication
qui sont telles que
- l'addition est commutative, associative et a pour élément neutre 0
- tout réel a un opposé
- la multiplication est commutative, associative et a pour élément neutre 1
- tout réel non nul a un inverse
- la multiplication est distributive sur l'addition
- 1 et 0 sont différents
- les réels forment un corps ordonné : il y a un ordre, noté <, qui est total, compatible avec l'addition et la multiplication par un réel positif
- les réels satisfont la propriété de la borne supérieure
R est un corps commutatif
Addition des réels
L'addition doit être commutative, associative, et avoir un élément neutre
noté 0
Check Rplus_comm. (* commutativité, brique 1 *)
Check Rplus_assoc. (* associativité, brique 2 *)
Check Rplus_0_l. (* 0 est élément neutre à gauche, brique 3 *)
Theorem Rplus_0_r : ∀ (r : R), r + 0 = r.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Un opposé d'un réel x est un réel y tel que x + y = 0.
En fait, on peut prouver que l'opposé, quand il existe, est unique.
Exercice : Prouver le théorème suivant.
Theorem oppose_unique : ∀ x y z : R, x + y = 0 ∧ x + z = 0 → y = z.
(* Avant de se lancer tête baissée, voici une preuve mathématique
Soient x, y et z trois réels tels que
(Hy) x + y = 0 et
(Hz) x + z = 0.
On veut montrer y = z.
Il suffit de montrer y = z + 0, donc d'après Hy, de montrer
y = z + (x + y).
Or, z + (x + y) = (x + z) + y = 0 + y d'après Hz.
CQFD.
*)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
(* Avant de se lancer tête baissée, voici une preuve mathématique
Soient x, y et z trois réels tels que
(Hy) x + y = 0 et
(Hz) x + z = 0.
On veut montrer y = z.
Il suffit de montrer y = z + 0, donc d'après Hy, de montrer
y = z + (x + y).
Or, z + (x + y) = (x + z) + y = 0 + y d'après Hz.
CQFD.
*)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Cet opposé, étant unique, peut avoir sa propre notation et vous la
connaissez bien sûr, l'opposé de x est noté -x et notre 4ème "brique"
dit que tout réel en a un.
Theorem Rplus_opp_r : ∀ (r : R), r + (- r) = 0.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Theorem Rplus_eq_reg_l: ∀ r r1 r2 : R, r + r1 = r + r2 → r1 = r2.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
En guise d'application, une petite équation du premier degré :
Exercice : Prouver le théorème suivant.
Indice : attention, avec tous ces rewrite, on a tendance à oublier que apply existe.
Theorem double_fixpoint_0 : ∀ (x : R), x + x = x → x = 0.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
On utilise l'opposé pour définir la soustraction :
Print Rminus.
La multiplication doit également être associative, commutative
et avoir un élément neutre, ici, évidemment noté 1.
Check Rmult_assoc. (* associativité, brique 5 *)
Check Rmult_comm. (* commutativité, brique 6 *)
Check Rmult_1_r. (* 1 est neutre à droite, brique 7 *)
Check Rmult_comm. (* commutativité, brique 6 *)
Check Rmult_1_r. (* 1 est neutre à droite, brique 7 *)
Theorem Rmult_1_l : ∀ (r : R), 1 × r = r.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
De plus, la multiplication doit être distributive sur l'addition.
Theorem Rmult_plus_distr_r : ∀ (r1 r2 r3 : R),
(r1 + r2) × r3 = r1 × r3 + r2 × r3.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
(r1 + r2) × r3 = r1 × r3 + r2 × r3.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
On peut maintenant montrer que 0 est absorbant pour la multiplication.
Exercice : Prouver le théorème suivant.
Avant de se lancer sur la preuve formelle, on cherche une preuve en
mathématiques plus informelles.
(* Preuve mathématique (arrière):
Pour prouver r * 0 = 0, d'après, double_fixpoint_0, il suffit de prouver que
r * 0 + r * 0 = r * 0.
Or, par distributivité, r * 0 + r * 0 = r * (0 + 0) = r * 0. CQFD. *)
Proof. (* Maintenant la preuve formelle. *)
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Pour prouver r * 0 = 0, d'après, double_fixpoint_0, il suffit de prouver que
r * 0 + r * 0 = r * 0.
Or, par distributivité, r * 0 + r * 0 = r * (0 + 0) = r * 0. CQFD. *)
Proof. (* Maintenant la preuve formelle. *)
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Theorem Rmult_0_l : ∀ (r : R), 0 × r = 0.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Dans un corps, 0 et 1 doivent être distincts.
Et enfin tout élément x non nul a un inverse.
Cet inverse est unique (même preuve que pour l'unicité de l'opposé et c'est
normal...) et est noté en mathématiques 1 / x, en Coq / x.
Theorem Rinv_r : ∀ (r : R), r ≠ 0 → r × / r = 1.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
L'existence d'un inverse permet de simplifier les produits dans les
égalités.
Exercice : Prouver le théorème suivant.
Theorem Rmult_eq_reg_l :
∀ r r1 r2 : R, r × r1 = r × r2 → r ≠ 0 → r1 = r2.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
∀ r r1 r2 : R, r × r1 = r × r2 → r ≠ 0 → r1 = r2.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Exercice papier-crayon.
Le théorème précédent est-il encore vrai sans la condition sur r ? Si oui, le prouver, si non, trouver un contre-exemple.Exercice : Prouver le théorème suivant.
Theorem Rmult_integral: ∀ r1 r2 : R, r1 × r2 = 0 → r1 = 0 ∨ r2 = 0.
Proof.
(* Indice : considérer les cas r1 = 0 et r1 <> 0 avec le tiers exclu :
destruct (classic (r1 = 0)) as [H1 | H1] *)
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Indice : considérer les cas r1 = 0 et r1 <> 0 avec le tiers exclu :
destruct (classic (r1 = 0)) as [H1 | H1] *)
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Theorem Rinv_neq_0_compat: ∀ r : R, r ≠ 0 → / r ≠ 0.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Ce théorème a un nom barbare pour quelque chose de très simple...
Le produit de deux réels non nuls est non nul.
Exercice : Prouver le théorème suivant.
Theorem Rmult_integral_contrapositive_currified :
∀ (r1 r2 : R), r1 ≠ 0 → r2 ≠ 0 → r1 × r2 ≠ 0.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
∀ (r1 r2 : R), r1 ≠ 0 → r2 ≠ 0 → r1 × r2 ≠ 0.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Theorem Rinv_inv' : ∀ (r : R), r ≠ 0 → / / r = r.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Theorem Rinv_mult' :
∀ (r1 r2 : R), r1 ≠ 0 → r2 ≠ 0 → / (r1 × r2) = / r2 × / r1.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
Theorem Rinv_mult' :
∀ (r1 r2 : R), r1 ≠ 0 → r2 ≠ 0 → / (r1 × r2) = / r2 × / r1.
Proof.
(* Remplir la preuve ici *)
Admitted. (* Remplacer cette ligne par Qed. *)
La division est définie à partir de la multiplication et de l'inverse :
Print Rdiv.