|
|
|
@ -14,35 +14,68 @@ Title "Widerspruch"
|
|
|
|
|
|
|
|
|
|
Introduction
|
|
|
|
|
"
|
|
|
|
|
Zwei wichtige Beweisformen sind per Widerspruch und per Kontraposition. Hier
|
|
|
|
|
schauen wir beide an und auch den Unterschied.
|
|
|
|
|
|
|
|
|
|
Um einen Beweis per Widerspruch zu führen, kann man mit `by_contra h` annehmen,
|
|
|
|
|
dass das Gegenteil des Goals wahr sei, und dann einen Widerspruch erzeugen.
|
|
|
|
|
|
|
|
|
|
**Bemerkung:** Besonders beim Beweis durch Widerspruch ist es hilfreich, wenn man
|
|
|
|
|
Zwischenresultate erstellen kann.
|
|
|
|
|
`suffices h₁ : ¬(odd (n ^ 2))` erstellt zwei neue Goals:
|
|
|
|
|
|
|
|
|
|
1) Ein Beweis, wieso es genügt `¬(odd (n ^ 2))` zu zeigen (\"weil das einen Widerspruch zu
|
|
|
|
|
`h` bewirkt\").
|
|
|
|
|
2) Einen Beweis des Zwischenresultats `suffices h₁ : ¬(odd (n ^ 2))`
|
|
|
|
|
|
|
|
|
|
Alternativ macht `have h₁ : ¬(odd (n ^ 2))` genau das gleiche, vertauscht aber die
|
|
|
|
|
Beweise (1) und (2), so dass man zuerst `h₁` beweist, und dann den eigentlichen Beweis
|
|
|
|
|
fortsetzt.
|
|
|
|
|
"
|
|
|
|
|
|
|
|
|
|
Statement
|
|
|
|
|
"Ist n² ungerade, so ist auch n ungerade. Beweise durch Widerspruch."
|
|
|
|
|
(n : ℕ) (h : odd (n ^ 2)) : odd n := by
|
|
|
|
|
by_contra g
|
|
|
|
|
rw [not_odd] at g
|
|
|
|
|
|
|
|
|
|
suffices ¬ odd (n ^ 2) by contradiction -- TODO: I don't like this
|
|
|
|
|
suffices d : ¬ odd (n ^ 2) -- TODO: I don't like this
|
|
|
|
|
contradiction
|
|
|
|
|
|
|
|
|
|
rw [not_odd] at g
|
|
|
|
|
rw [not_odd]
|
|
|
|
|
apply even_square
|
|
|
|
|
assumption
|
|
|
|
|
|
|
|
|
|
Message : false =>
|
|
|
|
|
"Es gibt mehrere Möglichkeiten, wie man nach einem `by_contra` weitergeht.
|
|
|
|
|
Message (n : ℕ) (h : odd (n^2)) : odd n =>
|
|
|
|
|
"Schreibe `by_contra h₁` um einen Beweis durch Widerspruch zu starten."
|
|
|
|
|
|
|
|
|
|
Hier wollen wir einen Widerspruch zu `h` machen. Wir machen das mit
|
|
|
|
|
`suffices ¬ odd (n ^ 2) by contradiction`, worauf man dann nur noch `¬ odd (n ^ 2)`
|
|
|
|
|
zeigen muss."
|
|
|
|
|
Message (n : ℕ) (g : ¬ odd n) (h : odd (n^2)) : False =>
|
|
|
|
|
"Nun *genügt es zu zeigen, dass* `¬odd (n ^ 2)` wahr ist,
|
|
|
|
|
denn dann erhalten wir einen Widerspruch zu `h`.
|
|
|
|
|
|
|
|
|
|
Hint (n : ℕ) : ¬ (odd (n ^ 2)) =>
|
|
|
|
|
"Das Lemma `not_odd` ist hilfreich."
|
|
|
|
|
Benütze dafür `suffices h₂ : ¬odd (n ^ 2)`.
|
|
|
|
|
"
|
|
|
|
|
|
|
|
|
|
Message (n : ℕ) (g : ¬ odd (n^2)) (h : odd (n^2)) : False =>
|
|
|
|
|
"Hier musst du rechtfertigen, wieso das genügt. In unserem Fall, weil
|
|
|
|
|
dadurch einen Widerspruch entsteht."
|
|
|
|
|
|
|
|
|
|
Hint (n : ℕ) (g : ¬ odd (n^2)) (h : odd (n^2)) : False =>
|
|
|
|
|
"Also `contradiction`..."
|
|
|
|
|
|
|
|
|
|
Message (n : ℕ) (g : ¬ odd n) (h : odd (n^2)) : ¬ odd (n^2) =>
|
|
|
|
|
"Das Zwischenresultat `¬odd (n^2)` muss auch bewiesen werden.
|
|
|
|
|
Hier ist wieder das Lemma `not_odd` hilfreich."
|
|
|
|
|
|
|
|
|
|
Hint (n : ℕ) (g : ¬ odd n) (h : odd (n^2)) : even (n^2) =>
|
|
|
|
|
"Mit `rw [not_odd] at *` kannst du im Goal und allen Annahmen gleichzeitig umschreiben."
|
|
|
|
|
|
|
|
|
|
Message (n: ℕ) (h : odd (n ^ 2)) (g : even n) : even (n ^ 2) =>
|
|
|
|
|
"Das haben wir schon gezeigt. Mit `apply even_square` kannst du das Lemma anwenden."
|
|
|
|
|
"Diese Aussage hast du bereits als Lemma bewiesen."
|
|
|
|
|
|
|
|
|
|
Hint (n: ℕ) (h : odd (n ^ 2)) (g : even n) : even (n ^ 2) =>
|
|
|
|
|
"Probiers mit `apply ...`"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Tactics contradiction by_contra rw apply assumption -- TODO: suffices
|
|
|
|
|
Tactics contradiction by_contra rw apply assumption -- TODO: suffices, have
|
|
|
|
|
|
|
|
|
|
Lemmas odd even not_odd not_even even_square
|
|
|
|
|