story contradiction

pull/54/head
Jon Eugster 2 years ago
parent 93114620c4
commit 421606aaed

@ -8,3 +8,9 @@ import TestGame.Levels.Contradiction.L06_Summary
Game "TestGame" Game "TestGame"
World "Contradiction" World "Contradiction"
Title "Widerspruch" Title "Widerspruch"
Introduction "
Ihr begebt euch auf die Suche nach *Oddeus*. Nach etwas rumfragen, kommt ihr tatsächlich an
eine Dornenfestung und nachdem ihr erklärt habt, wer ihr seit, werdet ihr auf eine Audienz
gebeten.
"

@ -15,56 +15,46 @@ Title "Have"
Introduction Introduction
" "
Manchmal, wollen wir nicht am aktuellen Goal arbeiten, sondern zuerst ein **Oddeus**: Willkommen Reisende! Ich muss eingestehen ich bin in Gedanken noch
Zwischenresultat beweisen, welches wir dann benützen können. an etwas, könnt ihr mir bei diesem widersprüchlichen Problem helfen?
Mit `have [Name] : [Aussage]` kann man ein Zwischenresultat erstellen,
dass man anschliessen beweisen muss.
Wenn du zum Beispiel die Annahmen `(h : A → ¬ B)` und `(ha : A)` hast, kannst
du mit
```
have g : ¬ B
apply h
assumption
```
eine neue Annahme `(g : ¬ B)` erstellen. Danach beweist du zuerst diese Annahme,
bevor du dann mit dem Beweis forfährst.
" "
Statement -- Manchmal, wollen wir nicht am aktuellen Goal arbeiten, sondern zuerst ein
"Angenommen, man hat eine Implikation $A \\Rightarrow \\neg B$ und weiss, dass -- Zwischenresultat beweisen, welches wir dann benützen können.
$A \\land B$ wahr ist. Zeige, dass dies zu einem Widerspruch führt."
(A B : Prop) (h : A → ¬ B) (k : A ∧ B) : False := by
rcases k with ⟨h₁, h₂⟩
have h₃ : ¬ B
apply h
assumption
contradiction
Hint (A : Prop) (B : Prop) (h : A → ¬ B) (k : A ∧ B) : False => -- Mit `have [Name] : [Aussage]` kann man ein Zwischenresultat erstellen,
" Fang mal damit an, das UND in den Annahmen mit `rcases` aufzuteilen. -- dass man anschliessen beweisen muss.
"
Hint (A : Prop) (B : Prop) (h : A → ¬ B) (k : A) (f : B) : False => -- Wenn du zum Beispiel die Annahmen `(h : A → ¬ B)` und `(ha : A)` hast, kannst
" -- du mit
Auf Deutsch: \"Als Zwischenresultat haben wir `¬ B`.\" -- ```
-- have g : ¬ B
-- apply h
-- assumption
-- ```
-- eine neue Annahme `(g : ¬ B)` erstellen. Danach beweist du zuerst diese Annahme,
-- bevor du dann mit dem Beweis forfährst.
In Lean : Statement (A B : Prop) (h : A → ¬ B) (k : A ∧ B) : False := by
Hint "**Du**: Also als erstes Teile ich wohl mal das Und (`∧`) auf."
rcases k with ⟨h₁, h₂⟩
Hint "**Du**: Aber jetzt…
``` **Robo**: Du könntest dir ein passendes Zwischenresultat zurechtlegen, das dir hilft:
have k : ¬ B Mach mal `have g : ¬ B`!"
[Beweis von k] have g : ¬ B
``` · Hint "**Du**: Was und jetzt hab ich einfach angenommen das sei richtig?
"
-- example (n : ) : n.succ + 2 = n + 3 := by **Robo**: Ne, jetzt musst du das zuerst beweisen bevor du es dann benützen kannst."
-- ring_nf Hint (hidden := true) "**Robo**: `apply` scheint passend zu sein."
apply h
assumption
· Hint (hidden := true) "**Du**: Und wie war das nochmals wenn zwei Annahmen sich widersprechen?
Conclusion "" **Robo**: `contradiction`."
contradiction
NewTactic «have» NewTactic «have»
DisabledTactic «suffices» DisabledTactic «suffices»
NewDefinition Even Odd Conclusion "*Oddeus*: Das stimmt wohl."
NewLemma not_even not_odd

@ -15,52 +15,49 @@ Title "Suffices"
Introduction Introduction
" "
Die Taktik `suffices` funktioniert genau gleich wie `have`, *Oddeus*' Partner meldet sich.
vertauscht aber die beiden Beweisblöcke:
``` **Partner**: Ich habe letzthin was änliches gesehen, aber irgendwie verdreht.
suffices h : [Aussage] "
[Beweis des Goals (mithilfe von h)]
[Beweis der Aussage h]
```
Auf Deutsch entspricht `suffices g : [Aussage]` dem Ausdruck
\"Es genügt zu zeigen, dass `[Aussage]` wahr ist.\"
Man kann `have` und `suffices` nach belieben vertauschen. Bevorzugt, wählt man es so, -- Die Taktik `suffices` funktioniert genau gleich wie `have`,
dass der erste Beweisblock der kürzere ist. Zum Beispiel wäre bei der vorigen Aufgabe -- vertauscht aber die beiden Beweisblöcke:
`suffices` schöner gewesen:
" -- ```
-- suffices h : [Aussage]
-- [Beweis des Goals (mithilfe von h)]
-- [Beweis der Aussage h]
-- ```
-- Auf Deutsch entspricht `suffices g : [Aussage]` dem Ausdruck
-- \"Es genügt zu zeigen, dass `[Aussage]` wahr ist.\"
-- Man kann `have` und `suffices` nach belieben vertauschen. Bevorzugt, wählt man es so,
-- dass der erste Beweisblock der kürzere ist. Zum Beispiel wäre bei der vorigen Aufgabe
-- `suffices` schöner gewesen:
Statement Statement
"Angenommen, man hat eine Implikation $A \\Rightarrow \\neg B$ und weiss, dass "Angenommen, man hat eine Implikation $A \\Rightarrow \\neg B$ und weiss, dass
$A \\land B$ wahr ist. Zeige, dass dies zu einem Widerspruch führt." $A \\land B$ wahr ist. Zeige, dass dies zu einem Widerspruch führt."
(A B : Prop) (h : A → ¬ B) (k : A ∧ B) : False := by (A B : Prop) (h : A → ¬ B) (k₁ : A) (k₂ : B) : False := by
rcases k with ⟨h₁, h₂⟩ Hint "**Robo**: Ich weiss was er meint! Anstatt `have` kannst du auch `suffices`
suffices k : ¬ B brauchen. Das funktioniert genau gleich, aussert dass dann die beiden Goals vertauscht sind.
**Du**: Also nach `suffices g : ¬B` muss ich dann zuerst zeigen, wie man mit `g` den Beweis
abschliesst bevor ich `g` beweise?
**Robo**: Genau! Verwendende `have` und `suffices` einfach nach gutdünken."
suffices g : ¬ B
Hint "**Robo**: Also hier beendest du den Beweis angenommen {g} sei wahr."
contradiction contradiction
Hint "**Robo**: Und hier beweist du das Zwischenresultat."
apply h apply h
assumption assumption
Hint (A : Prop) (B : Prop) (h : A → ¬ B) (k : A ∧ B) : False => NewTactic «suffices»
" Fang mal damit an, das UND in den Annahmen mit `rcases` aufzuteilen. DisabledTactic «have»
"
Hint (A : Prop) (B : Prop) (h : A → ¬ B) (k : A) (f : B) : False =>
" Auf Deutsch: \"Es genügt `¬ B` zu zeigen, da dies zu einem direkten Widerspruch führt.\"
In Lean : Conclusion "*Oddeus* nimmt den Brief, schaut ihn an und, rollt ihn zusammen.
``` **Oddeus**: Ich verstehe meine Schwester nie. Kommt, vielleicht könnt ihr mir helfen.
suffices k : ¬ B
contradiction
[...]
```
"
Conclusion "" Und er führt euch durch seinen Rosengarten."
NewTactic «suffices»
DisabledTactic «have»
NewDefinition Even Odd
NewLemma not_even not_odd

@ -15,41 +15,51 @@ Level 3
Title "Per Widerspruch" Title "Per Widerspruch"
Introduction Introduction
" "**Oddeus**: Ich verstehe *Evenine* einfach nicht. Ich will euch auch gleich zeigen,
Eine sehr nützliche Beweismethode ist per Widerspruch. was sie mir letzthin geschrieben hat, aber zuerst schaut einmal unseren
wunderschönen Absurda-Tempel an!
Wir habe schon gesehen, dass `contradiction` einen Widerspruch in den Annahmen
sucht, und damit jegliches beweisen kann.
Um dorthin zu kommen, können wir `by_contra h` brauchen, welches das aktuelle Damit kommt ihr vor einen sehr hohen Turm, der ausschliesslich aus Dornenranken gewachsen
Goal auf `False` setzt und die Negierung des Goals als Annahme hinzufügt. scheint.
Insbesondere braucht man `by_contra h` meistens, wenn im Goal eine Negierung **Oddeus**: Versteht ihr, was hier über dem Eingang steht?
steht:
" "
Statement -- Eine sehr nützliche Beweismethode ist per Widerspruch.
"Angenommen $B$ ist falsch und es gilt $A \\Rightarrow B$. Zeige, dass $A$ falsch sein
muss." -- Wir habe schon gesehen, dass `contradiction` einen Widerspruch in den Annahmen
(A B : Prop) (g : A → B) (b : ¬ B) : ¬ A := by -- sucht, und damit jegliches beweisen kann.
by_contra a
suffices b : B
contradiction
apply g
assumption
-- Um dorthin zu kommen, können wir `by_contra h` brauchen, welches das aktuelle
-- Goal auf `False` setzt und die Negierung des Goals als Annahme hinzufügt.
HiddenHint (A : Prop) (B : Prop) (h : A → B) (b : ¬ B) : ¬ A => -- Insbesondere braucht man `by_contra h` meistens, wenn im Goal eine Negierung
"`by_contra h` nimmt das Gegenteil des Goal als Annahme `(h : A)` und setzt das -- steht:
Goal auf `False`."
Hint (A : Prop) (B : Prop) (h : A → B) (b : ¬ B) (a : A) : False => Statement (A B : Prop) (g : A → B) (b : ¬ B) : ¬ A := by
"Jetzt kannst du mit `suffices` oder `have` Fortschritt machen." Hint "**Robo**: Ein `¬` im Goal heisst häufig, dass du einen Widerspruchsbeweis führen
möchtest.
HiddenHint (A : Prop) (B : Prop) (h : A → B) (b : ¬ B) (a : A) : False => **Du**: Und wie mach ich das? Mit `contradiction`?
"Zum Beispiel `suffices hb : B`."
**Robo**: Mit `by_contra h` fängst du einen an. Mit `contradiction` schliesst du ihn dann
später ab."
by_contra h
Hint "**Robo**: Jetzt hast du also eine Annahme `{h} : ¬ {A}`, und damit musst du einen
Widerspruch herbeileiten.
Ein Methode ist, dass du jetzt mit `suffices` sagts, zu was du denn gerne den Widerspruch
haben möchtest, zum Beispiel `suffices k : B`
"
suffices k : B
Hint "**Du**: Ah und jetzt kann ich einfach sagen dass sich die Anahmen `{B}` und `¬{B}`
widersprechen."
contradiction
Hint "**Robo**: Und jetzt kannst du noch das Ergebnis zeigen, das zu einem Widerspruch
geführt hat."
apply g
assumption
Conclusion "" NewTactic by_contra
NewTactic by_contra contradiction apply assumption Conclusion "**Oddeus**: Sehr gut, kommt mit hinein!"

@ -16,34 +16,36 @@ Title "Per Widerspruch"
Introduction Introduction
" "
Als Übung zu `by_contra` und dem bisher gelernten, zeige folgendes Lemma welches *Oddeus* Geht zu einem Regal mit vielen Dokumenten und beginnt zu suchen.
wir für die Kontraposition brauchen werden:
**Oddeus**: Ich hab's gleich. Hier ist eine Notiz meiner Gelehrter, die mir
mit solchen kryptischen Nachrichten helfen wollten.
Auf dem Pergament steht das ein Lemma mit dem Namen `not_imp_not`:
" "
Statement not_imp_not Statement not_imp_not (A B : Prop) : A → B ↔ (¬ B → ¬ A) := by
"$A \\Rightarrow B$ ist äquivalent zu $\\neg B \\Rightarrow \\neg A$." Hint "**Du**: Ich glaube, dafür kenn ich das meiste schon."
(A B : Prop) : A → B ↔ (¬ B → ¬ A) := by Hint (hidden := true) "**Robo**: Fang doch mal mit `constructor` an."
constructor constructor
intro h b intro h b
by_contra a by_contra a
Hint "**Robo**: Zur Erinnerung, hier würde ich mit `suffices g : B` einen Widerspruch
herbeiführen."
suffices b : B suffices b : B
contradiction contradiction
apply h apply h
assumption assumption
intro h a intro h a
Hint "**Robo**: Hier würde ich ebenfalls einen Widerspruch anfangen."
by_contra b by_contra b
Hint (hidden := true) "**Robo**: `suffices g : ¬ A` sieht nach einer guten Option aus."
suffices g : ¬ A suffices g : ¬ A
contradiction contradiction
apply h apply h
assumption assumption
-- TODO: Forbidden Tactics: apply, rw DisabledTactic rw
-- TODO: forbidden Lemma: not_not DisabledLemma not_not
HiddenHint (A : Prop) (B : Prop) : A → B ↔ (¬ B → ¬ A) =>
""
Conclusion ""
NewTactic contradiction constructor intro by_contra apply assumption Conclusion "**Du**: Und wie hilft uns das jetzt, was steht denn in dem Brief?"

@ -14,53 +14,56 @@ Title "Kontraposition"
Introduction Introduction
" "
Ein Beweis durch Kontraposition benützt im Grunde das eben bewiesene Lemma *Oddeus* reicht euch das Papier.
``` **Du**: Da steht etwas über `contrapose` hier…
lemma not_imp_not (A B : Prop) : (A → B) ↔ (¬ B → ¬ A) := by
[...]
```
Dazu gibt es die Taktik `contrapose`, welche eine Implikation im Goal **Oddeus**: Das ist doch klar eine Aggression uns gegenüber!
entsprechend umdreht.
Wir erinnern hier an die Taktik `revert h`, die aus der Annahme `h` eine Implikation **Robo**: Wartet mal, vielleicht wollte euch eure Schwester einfach von ihren neuen
im Goal erstellt. Endeckungen zeigen. Schaut, darunter ist eine Aufgabe.
"
Im Gegensatz dazu kann man auch einen Beweis durch Kontraposition führen. -- Ein Beweis durch Kontraposition benützt im Grunde das eben bewiesene Lemma
Das ist kein Widerspruch, sondern benützt dass `A → B` und `(¬ B) → (¬ A)`
logisch equivalent sind.
Wenn das Goal eine Implikation ist, kann man `contrapose` anwenden. -- ```
" -- lemma not_imp_not (A B : Prop) : (A → B) ↔ (¬ B → ¬ A) := by
-- [...]
-- ```
Statement -- Dazu gibt es die Taktik `contrapose`, welche eine Implikation im Goal
"Ist n² ungerade, so ist auch n ungerade. Beweise durch Kontraposition." -- entsprechend umdreht.
(n : ) (h : Odd (n ^ 2)): Odd n := by
revert h
contrapose
rw [not_odd]
rw [not_odd]
apply even_square
HiddenHint (n : ) (h : Odd (n ^ 2)) : Odd n => -- Wir erinnern hier an die Taktik `revert h`, die aus der Annahme `h` eine Implikation
"Um `contrapose` anzuwenden, brauchen wir eine Implikation `Odd (n ^ 2) → Odd n` im -- im Goal erstellt.
Goal. Benutze `revert h`!"
Hint (n : ) : Odd (n ^ 2) → Odd n => -- Im Gegensatz dazu kann man auch einen Beweis durch Kontraposition führen.
"Mit `contrapose` kann man die Implikation zu -- Das ist kein Widerspruch, sondern benützt dass `A → B` und `(¬ B) → (¬ A)`
`¬ (Not n) → ¬ (Odd n^2)` umkehren." -- logisch equivalent sind.
Hint (n : ) : ¬Odd n → ¬Odd (n ^ 2) => "Erinnere dich an das Lemma `not_odd`." -- Wenn das Goal eine Implikation ist, kann man `contrapose` anwenden.
HiddenHint (n : ) : ¬Odd n → ¬Odd (n ^ 2) => "Dieses kann mit `rw` gebraucht werden." Statement (n : ) (h : Odd (n ^ 2)): Odd n := by
Hint "**Oddeus**: Wie soll das den gehen?
Hint (n : ) : Even n → ¬Odd (n ^ 2) => **Robo**: `contrapose` benutzt das Lemma eurer Gelehrter, `not_imp_not`. Also es wandelt
"rw [not_odd] muss hier zweimal angewendet werden." ein Goal `A → B` zu `¬B → ¬A ` um.
**Du**: Aber das Goal ist doch gar keine Implikation?
**Robo**: Mit `revert {h}` kannst du die Annahme `{h}` als Implikationsannahme ins Goal
schieben."
revert h
Hint "*Oddeus*: Ob man jetzt wohl dieses `contrapose` benutzen kann?"
contrapose
Hint (hidden := true) "**Du**: Warte mal, jetzt kann man wohl `not_odd` verwenden…"
rw [not_odd]
rw [not_odd]
Hint "**Robo**: Und den Rest hast du bei *Evenine* als Lemma gezeigt!"
apply even_square
Hint (n : ) : Even n → Even (n ^ 2) => NewTactic contrapose
"Diese Aussage hast du bereits als Lemma bewiesen, schau mal in der Bibliothek." DisabledTactic by_contra
NewTactic contrapose rw apply Conclusion "**Oddeus**: Ah ich sehe, die Aussage ist, dass wir das nur zusammen lösen konnten.
NewDefinition Even Odd Ich danke euch, darauf wäre ich nie gekommen."
NewLemma not_even not_odd even_square

@ -14,63 +14,41 @@ Title "Contradiction"
Introduction Introduction
" "
**Du**: Sag mal Robo, das hätte ich aber auch als Widerspruch anstatt Kontraposition
beweisen können?
**Robo**: Klar. `contrapose` ist eine Kontraposition, `by_contra` ein Widerspruchsbeweis.
Probiers doch einfach!
In diesem Kapitel hast du also folgende Taktiken kennengelernt: In diesem Kapitel hast du also folgende Taktiken kennengelernt:
| | Taktik | Beispiel |
|:------|:----------------|:-------------------------------------------------------|
| 16 | `have` | Zwischenresultat annehmen. |
| 17 | `suffices` | Zwischenresultat annehmen. |
| 18 | `by_contra` | Widerspruch. (startet einen Widerspruch) |
| *3* | `contradiction` | *(Schliesst einen Widerspruchsbeweis)* |
| 19 | `contrapose` | Contraposition. |
| *9* | `revert` | Nützlich um danach `contrapose` anzuwenden. |
Als Vergleich zwischen Beweisen \"per Widerspruch\" Als Vergleich zwischen Beweisen \"per Widerspruch\"
und \"per Kontraposition\", beweise die Gleiche Aufgabe indem und \"per Kontraposition\", beweise die Gleiche Aufgabe indem
du mit `by_contra` einen Widerspruch suchst. du mit `by_contra` einen Widerspruch suchst.
" "
Statement Statement (n : ) (h : Odd (n ^ 2)) : Odd n := by
"Ist n² ungerade, so ist auch n ungerade. Beweise durch Widerspruch." Hint "**Robo**: Fang diesmal mit `by_contra g` an!"
(n : ) (h : Odd (n ^ 2)) : Odd n := by
by_contra g by_contra g
Hint "**Robo**: Jetzt würde ich einen Widerspruch zu `Odd (n ^ 2)` führen."
Hint "**Robo**: Also `suffices g : ¬ Odd (n ^ 2)`."
suffices d : ¬ Odd (n ^ 2) suffices d : ¬ Odd (n ^ 2)
contradiction contradiction
rw [not_odd] at * rw [not_odd] at *
apply even_square apply even_square
assumption assumption
HiddenHint (n : ) (h : Odd (n^2)) : Odd n => DisabledTactic contrapose revert
"Schreibe `by_contra h₁` um einen Beweis durch Widerspruch zu starten."
Hint (n : ) (g : ¬ Odd n) (h : Odd (n^2)) : False =>
"
Am sinnvollsten ist es, hier einen Widerspruch zu `Odd (n^2)` zu suchen.
Dafür kannst du
```
suffices k : ¬ Odd (n ^ 2)
contradiction
```
benützen.
"
HiddenHint (n : ) (g : ¬ Odd (n^2)) (h : Odd (n^2)) : False =>
"Hier brauchst du nur `contradiction`."
Hint (n : ) (g : ¬ Odd n) (h : Odd (n^2)) : ¬ Odd (n^2) => Conclusion "**Robo**: Bravo! Hier nochmals ein Überblick, was wir jetzt alles auf diesem
"Das Zwischenresultat `¬Odd (n^2)` muss auch bewiesen werden. Mond gelernt haben:
Hier ist wieder das Lemma `not_Odd` hilfreich."
HiddenHint (n : ) (g : ¬ Odd n) (h : Odd (n^2)) : Even (n^2) => | | Taktik | Beispiel |
"Mit `rw [not_Odd] at *` kannst du im Goal und allen Annahmen gleichzeitig umschreiben." |:------|:----------------|:-------------------------------------------------------|
| 177 | `have` | Zwischenresultat annehmen. |
Hint (n: ) (h : Odd (n ^ 2)) (g : Even n) : Even (n ^ 2) => | 18 | `suffices` | Zwischenresultat annehmen. |
"Diese Aussage hast du bereits als Lemma bewiesen." | 19 | `by_contra` | Widerspruch. (startet einen Widerspruch) |
| *3* | `contradiction` | *(Schliesst einen Widerspruchsbeweis)* |
HiddenHint (n: ) (h : Odd (n ^ 2)) (g : Even n) : Even (n ^ 2) => | 20 | `contrapose` | Kontraposition. |
"Probiers mit `apply ...`" | *9* | `revert` | Nützlich um danach `contrapose` anzuwenden. |
"
NewTactic contradiction by_contra rw apply assumption -- TODO: suffices, have
NewDefinition Even Odd
NewLemma not_odd not_even even_square

Loading…
Cancel
Save