https://de.wikipedia.org/w/index.php?action=history&feed=atom&title=Diskussion%3AFunktionale_Programmierung
Diskussion:Funktionale Programmierung - Versionsgeschichte
2025-05-29T03:28:03Z
Versionsgeschichte dieser Seite in Wikipedia
MediaWiki 1.45.0-wmf.2
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=243597636&oldid=prev
SignaturBot: Bot: Signaturnachtrag für Beitrag von 84.166.43.135: "Neuer Abschnitt /* Imperativ! */"
2024-03-31T00:18:45Z
<p>Bot: Signaturnachtrag für Beitrag von <a href="/wiki/Spezial:Beitr%C3%A4ge/84.166.43.135" title="Spezial:Beiträge/84.166.43.135">84.166.43.135</a>: "Neuer Abschnitt <span class="autocomment">Imperativ!: </span>"</p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 31. März 2024, 03:18 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 685:</td>
<td colspan="2" class="diff-lineno">Zeile 685:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>== Imperativ! ==</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>== Imperativ! ==</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>„[https://de.wikipedia.org/wiki/Funktionale_Programmierung#Listen Sei ein beliebiger Datentyp]“ schreit doch geradezu nach einem „!“! 🥸 Mir scheint, da wurde etwas zu sehr rekursiv wegoptimiert. 🥸</div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>„[https://de.wikipedia.org/wiki/Funktionale_Programmierung#Listen Sei ein beliebiger Datentyp]“ schreit doch geradezu nach einem „!“! 🥸 Mir scheint, da wurde etwas zu sehr rekursiv wegoptimiert. 🥸<ins style="font-weight: bold; text-decoration: none;"> {{unsigniert|84.166.43.135|01:13, 31. Mär. 2024 (CET)}}</ins></div></td>
</tr>
</table>
SignaturBot
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=243597596&oldid=prev
84.166.43.135: Neuer Abschnitt /* Imperativ! */
2024-03-31T00:13:30Z
<p>Neuer Abschnitt <span class="autocomment">Imperativ!</span></p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 31. März 2024, 03:13 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 682:</td>
<td colspan="2" class="diff-lineno">Zeile 682:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Klar, wenn man zu Kategorien übergeht, in denen die Pfeile <em>partielle</em> Funktionen sind (hier sind aber auch mindestens zwei Ausprägungen möglich), </div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Klar, wenn man zu Kategorien übergeht, in denen die Pfeile <em>partielle</em> Funktionen sind (hier sind aber auch mindestens zwei Ausprägungen möglich), </div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: werden manchmal zumindest die Trägerobjekte vereinigt (in Haskell etwa gibt es soetwas wie <math>A^*</math> eigentlich <em>gar nicht</em>, in ML schon; ein <code>unfold</code> in ML kann aber auch nicht Totalität garantieren, und dann wird anderes komisch, etc.). --[[Benutzer:Daniel5Ko|Daniel5Ko]] ([[Benutzer Diskussion:Daniel5Ko|Diskussion]]) 02:00, 16. Dez. 2022 (CET)</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: werden manchmal zumindest die Trägerobjekte vereinigt (in Haskell etwa gibt es soetwas wie <math>A^*</math> eigentlich <em>gar nicht</em>, in ML schon; ein <code>unfold</code> in ML kann aber auch nicht Totalität garantieren, und dann wird anderes komisch, etc.). --[[Benutzer:Daniel5Ko|Daniel5Ko]] ([[Benutzer Diskussion:Daniel5Ko|Diskussion]]) 02:00, 16. Dez. 2022 (CET)</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>== Imperativ! ==</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>„[https://de.wikipedia.org/wiki/Funktionale_Programmierung#Listen Sei ein beliebiger Datentyp]“ schreit doch geradezu nach einem „!“! 🥸 Mir scheint, da wurde etwas zu sehr rekursiv wegoptimiert. 🥸</div></td>
</tr>
</table>
84.166.43.135
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=228907918&oldid=prev
Daniel5Ko: /* Frust-Artikel */ Oh, Lean-Unterstützung scheint es inzwischen zu geben.
2022-12-16T10:36:37Z
<p><span class="autocomment">Frust-Artikel: </span> Oh, Lean-Unterstützung scheint es inzwischen zu geben.</p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 16. Dezember 2022, 12:36 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 659:</td>
<td colspan="2" class="diff-lineno">Zeile 659:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Für eine Menge <math>A</math> hätten wir beim Funktor für die A-Listensignatur, <math>S \mapsto 1 + A\times S</math> in <math>\mathrm{Set}</math> einerseits die Menge der endlichen Listen <math>A^*</math> über <math>A</math> und andererseits die Menge der endlichen oder unendlichen Listen <math>A^\infty</math> über <math>A</math>.</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Für eine Menge <math>A</math> hätten wir beim Funktor für die A-Listensignatur, <math>S \mapsto 1 + A\times S</math> in <math>\mathrm{Set}</math> einerseits die Menge der endlichen Listen <math>A^*</math> über <math>A</math> und andererseits die Menge der endlichen oder unendlichen Listen <math>A^\infty</math> über <math>A</math>.</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Die Kategorie(nklasse), über die man spricht, wenn man in Lean 3 nur "normale" Funktionsdefinitionen verwendet, ist ausreichend <math>\mathrm{Set}</math>-like, um auf die Unterschiede aufmerksam zu werden: </div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Die Kategorie(nklasse), über die man spricht, wenn man in Lean 3 nur "normale" Funktionsdefinitionen verwendet, ist ausreichend <math>\mathrm{Set}</math>-like, um auf die Unterschiede aufmerksam zu werden: </div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight lang="<del style="font-weight: bold; text-decoration: none;">text</del>"></div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight lang="<ins style="font-weight: bold; text-decoration: none;">lean</ins>"></div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def list.fold{A S : Type}(f : option (A × S) → S): list A → S</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def list.fold{A S : Type}(f : option (A × S) → S): list A → S</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| [] := f none</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| [] := f none</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| (a::as) := f $ some (a, list.fold as) </syntaxhighlight></div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| (a::as) := f $ some (a, list.fold as) </syntaxhighlight></div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>::: Entsprechendes mit <code>unfold</code>, <syntaxhighlight lang="<del style="font-weight: bold; text-decoration: none;">text</del>">def list.unfold{A S : Type}(f : S → option (A × S)): S → list A := ???</syntaxhighlight> geht nicht. Man muss ein paar zusätzliche Forderungen stellen, wenn man tatsächlich <code>list A</code> als Ergebnis haben will, etwa etwas mit einer wohlfundierten Relation: </div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Entsprechendes mit <code>unfold</code>, <syntaxhighlight lang="<ins style="font-weight: bold; text-decoration: none;">lean</ins>">def list.unfold{A S : Type}(f : S → option (A × S)): S → list A := ???</syntaxhighlight> geht nicht. Man muss ein paar zusätzliche Forderungen stellen, wenn man tatsächlich <code>list A</code> als Ergebnis haben will, etwa etwas mit einer wohlfundierten Relation: </div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight lang="<del style="font-weight: bold; text-decoration: none;">text</del>"></div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight lang="<ins style="font-weight: bold; text-decoration: none;">lean</ins>"></div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def list.unfold{A S : Type}{R : S → S → Prop}</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def list.unfold{A S : Type}{R : S → S → Prop}</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div> (wf: well_founded R)</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div> (wf: well_founded R)</div></td>
</tr>
<tr>
<td colspan="2" class="diff-lineno">Zeile 675:</td>
<td colspan="2" class="diff-lineno">Zeile 675:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>end</syntaxhighlight></div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>end</syntaxhighlight></div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Oder man verwendet statt <math>A^*</math> (<code>list A</code>) eben passendererweise <math>A^\infty</math> (hier <code>stream A</code>):</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Oder man verwendet statt <math>A^*</math> (<code>list A</code>) eben passendererweise <math>A^\infty</math> (hier <code>stream A</code>):</div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight lang="<del style="font-weight: bold; text-decoration: none;">text</del>"></div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight lang="<ins style="font-weight: bold; text-decoration: none;">lean</ins>"></div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def stream(A : Type) := {f : ℕ → option A // ∀ n, f n = none → f (n+1) = none } -- oder wie auch immer man das Konzept formalisieren möchte.</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def stream(A : Type) := {f : ℕ → option A // ∀ n, f n = none → f (n+1) = none } -- oder wie auch immer man das Konzept formalisieren möchte.</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
</table>
Daniel5Ko
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=228905778&oldid=prev
Lómelinde: eigentlich :Kategorie:Wikipedia:Seite mit Syntaxhervorhebungsfehlern fehlende Pflichtangabe lang="…" ? siehe auch Hilfe:Syntaxhighlight#Parameter
2022-12-16T09:10:20Z
<p>eigentlich <a href="/wiki/Kategorie:Wikipedia:Seite_mit_Syntaxhervorhebungsfehlern" title="Kategorie:Wikipedia:Seite mit Syntaxhervorhebungsfehlern">Kategorie:Wikipedia:Seite mit Syntaxhervorhebungsfehlern</a> fehlende Pflichtangabe lang="…" ? siehe auch <a href="/wiki/Hilfe:Syntaxhighlight#Parameter" title="Hilfe:Syntaxhighlight">Hilfe:Syntaxhighlight#Parameter</a></p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 16. Dezember 2022, 11:10 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 121:</td>
<td colspan="2" class="diff-lineno">Zeile 121:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>Zusätzlich fehlt mir persönlich noch ein Hinweis auf den - praktischen - Unterschied von funktionalen Programmiersprachen. z.B. leichter für parallele Ausführungen optimierbar sind, oder der Programmierer damit einen höheren Grad an Parallelität verwalten kann, als in in Prozuduralen/Objektorienten möglich wäre.</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>Zusätzlich fehlt mir persönlich noch ein Hinweis auf den - praktischen - Unterschied von funktionalen Programmiersprachen. z.B. leichter für parallele Ausführungen optimierbar sind, oder der Programmierer damit einen höheren Grad an Parallelität verwalten kann, als in in Prozuduralen/Objektorienten möglich wäre.</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div><small>(''Vorstehender [[Wikipedia:Signatur|nicht signierter]] Beitrag stammt von'' [[Benutzer:84.144.236.24|84.144.236.24]] ([[Benutzer Diskussion:84.144.236.24|Diskussion]] • [[Spezial:Contributions/84.144.236.24|Beiträge]]) 00:40, 27. Jun 2006)<del style="font-weight: bold; text-decoration: none;">{{{3|}}}</del></small></div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div><small>(''Vorstehender [[Wikipedia:Signatur|nicht signierter]] Beitrag stammt von'' [[Benutzer:84.144.236.24|84.144.236.24]] ([[Benutzer Diskussion:84.144.236.24|Diskussion]] • [[Spezial:Contributions/84.144.236.24|Beiträge]]) 00:40, 27. Jun 2006)</small></div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>:OO-Weiterentwicklungen werden im FPL-Bereich meist als eher überflüssig angesehen. Die besonderen Vorzüge von OO (Kapselung, polymorphe Container) werden durch andere Sprachmittel erreicht (Modularisierung, Closures statt Daten in den Containern).</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>:OO-Weiterentwicklungen werden im FPL-Bereich meist als eher überflüssig angesehen. Die besonderen Vorzüge von OO (Kapselung, polymorphe Container) werden durch andere Sprachmittel erreicht (Modularisierung, Closures statt Daten in den Containern).</div></td>
</tr>
<tr>
<td colspan="2" class="diff-lineno">Zeile 167:</td>
<td colspan="2" class="diff-lineno">Zeile 167:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>Könnten wir die Debatte, ob nur ''rein'' funktionale Sprachen als solche bezeichnet werden, vielleicht durch eine Aufstellung entschärfen, etwa so:</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>Könnten wir die Debatte, ob nur ''rein'' funktionale Sprachen als solche bezeichnet werden, vielleicht durch eine Aufstellung entschärfen, etwa so:</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>{| class="<del style="font-weight: bold; text-decoration: none;">prettytable</del>"</div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>{| class="<ins style="font-weight: bold; text-decoration: none;">wikitable</ins>"</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! Sprache</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! Sprache</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! HOFs</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! HOFs</div></td>
</tr>
<tr>
<td colspan="2" class="diff-lineno">Zeile 174:</td>
<td colspan="2" class="diff-lineno">Zeile 174:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! imperativ</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! imperativ</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>|-</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>|-</div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>|colspan="5"<del style="font-weight: bold; text-decoration: none;"> </del>| ''Rein funktionale Sprachen''</div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>|colspan="5"| ''Rein funktionale Sprachen''</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>|-</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>|-</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! Lisp</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! Lisp</div></td>
</tr>
<tr>
<td colspan="2" class="diff-lineno">Zeile 188:</td>
<td colspan="2" class="diff-lineno">Zeile 188:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| nein</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| nein</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>|-</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>|-</div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>|colspan="5"<del style="font-weight: bold; text-decoration: none;"> </del>| ''Funktionale Sprachen''</div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>|colspan="5"| ''Funktionale Sprachen''</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>|-</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>|-</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! Python</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>! Python</div></td>
</tr>
<tr>
<td colspan="2" class="diff-lineno">Zeile 659:</td>
<td colspan="2" class="diff-lineno">Zeile 659:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Für eine Menge <math>A</math> hätten wir beim Funktor für die A-Listensignatur, <math>S \mapsto 1 + A\times S</math> in <math>\mathrm{Set}</math> einerseits die Menge der endlichen Listen <math>A^*</math> über <math>A</math> und andererseits die Menge der endlichen oder unendlichen Listen <math>A^\infty</math> über <math>A</math>.</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Für eine Menge <math>A</math> hätten wir beim Funktor für die A-Listensignatur, <math>S \mapsto 1 + A\times S</math> in <math>\mathrm{Set}</math> einerseits die Menge der endlichen Listen <math>A^*</math> über <math>A</math> und andererseits die Menge der endlichen oder unendlichen Listen <math>A^\infty</math> über <math>A</math>.</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Die Kategorie(nklasse), über die man spricht, wenn man in Lean 3 nur "normale" Funktionsdefinitionen verwendet, ist ausreichend <math>\mathrm{Set}</math>-like, um auf die Unterschiede aufmerksam zu werden: </div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Die Kategorie(nklasse), über die man spricht, wenn man in Lean 3 nur "normale" Funktionsdefinitionen verwendet, ist ausreichend <math>\mathrm{Set}</math>-like, um auf die Unterschiede aufmerksam zu werden: </div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight></div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight<ins style="font-weight: bold; text-decoration: none;"> lang="text"</ins>></div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def list.fold{A S : Type}(f : option (A × S) → S): list A → S</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def list.fold{A S : Type}(f : option (A × S) → S): list A → S</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| [] := f none</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| [] := f none</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| (a::as) := f $ some (a, list.fold as) </syntaxhighlight></div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>| (a::as) := f $ some (a, list.fold as) </syntaxhighlight></div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>::: Entsprechendes mit <code>unfold</code>, <syntaxhighlight>def list.unfold{A S : Type}(f : S → option (A × S)): S → list A := ???</syntaxhighlight> geht nicht. Man muss ein paar zusätzliche Forderungen stellen, wenn man tatsächlich <code>list A</code> als Ergebnis haben will, etwa etwas mit einer wohlfundierten Relation: </div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Entsprechendes mit <code>unfold</code>, <syntaxhighlight<ins style="font-weight: bold; text-decoration: none;"> lang="text"</ins>>def list.unfold{A S : Type}(f : S → option (A × S)): S → list A := ???</syntaxhighlight> geht nicht. Man muss ein paar zusätzliche Forderungen stellen, wenn man tatsächlich <code>list A</code> als Ergebnis haben will, etwa etwas mit einer wohlfundierten Relation: </div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight></div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight<ins style="font-weight: bold; text-decoration: none;"> lang="text"</ins>></div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def list.unfold{A S : Type}{R : S → S → Prop}</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def list.unfold{A S : Type}{R : S → S → Prop}</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div> (wf: well_founded R)</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div> (wf: well_founded R)</div></td>
</tr>
<tr>
<td colspan="2" class="diff-lineno">Zeile 675:</td>
<td colspan="2" class="diff-lineno">Zeile 675:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>end</syntaxhighlight></div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>end</syntaxhighlight></div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Oder man verwendet statt <math>A^*</math> (<code>list A</code>) eben passendererweise <math>A^\infty</math> (hier <code>stream A</code>):</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Oder man verwendet statt <math>A^*</math> (<code>list A</code>) eben passendererweise <math>A^\infty</math> (hier <code>stream A</code>):</div></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight></div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight<ins style="font-weight: bold; text-decoration: none;"> lang="text"</ins>></div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def stream(A : Type) := {f : ℕ → option A // ∀ n, f n = none → f (n+1) = none } -- oder wie auch immer man das Konzept formalisieren möchte.</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>def stream(A : Type) := {f : ℕ → option A // ∀ n, f n = none → f (n+1) = none } -- oder wie auch immer man das Konzept formalisieren möchte.</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
</table>
Lómelinde
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=228900378&oldid=prev
Daniel5Ko: /* Frust-Artikel */ Tyop
2022-12-16T01:16:58Z
<p><span class="autocomment">Frust-Artikel: </span> Tyop</p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 16. Dezember 2022, 03:16 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 654:</td>
<td colspan="2" class="diff-lineno">Zeile 654:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: VG --[[Benutzer:PerfektesChaos|PerfektesChaos]] 17:58, 15. Dez. 2022 (CET)</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: VG --[[Benutzer:PerfektesChaos|PerfektesChaos]] 17:58, 15. Dez. 2022 (CET)</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>::: Vielleicht noch zur Ergänzung, um die Kritik am "kategorientheoretischen Teil" etwas konkreter werden zu lassen: Was ein Katamorphismus lässt sich ja recht kurz definieren ([https://ncatlab.org/nlab/show/catamorphism]): Gegeben einen Endofunktor <math>F</math>, ist ein Katamorphismus einfach der einzige F-Algebra-Homomorphismus von der initialen F-Algebra (wir nehmen mal an, dass es die gibt) zu einer anderen F-Algebra.</div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Vielleicht noch zur Ergänzung, um die Kritik am "kategorientheoretischen Teil" etwas konkreter werden zu lassen: Was ein Katamorphismus<ins style="font-weight: bold; text-decoration: none;"> ist,</ins> lässt sich ja recht kurz definieren ([https://ncatlab.org/nlab/show/catamorphism]): Gegeben einen Endofunktor <math>F</math>, ist ein Katamorphismus einfach der einzige F-Algebra-Homomorphismus von der initialen F-Algebra (wir nehmen mal an, dass es die gibt) zu einer anderen F-Algebra.</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Tatsächlich dual dazu wäre: ein Anamorphismus ist der einzige F-Koalgebra-Homomorphismus von einer anderen F-Koalgebra zur terminalen F-Koalgebra. </div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Tatsächlich dual dazu wäre: ein Anamorphismus ist der einzige F-Koalgebra-Homomorphismus von einer anderen F-Koalgebra zur terminalen F-Koalgebra. </div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Nun stimmen in den meisten Kategorien die Trägerobjekte von initialen F-Algebren und terminalen F-Koalgebren natürlich nicht überein.</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Nun stimmen in den meisten Kategorien die Trägerobjekte von initialen F-Algebren und terminalen F-Koalgebren natürlich nicht überein.</div></td>
</tr>
</table>
Daniel5Ko
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=228900303&oldid=prev
Daniel5Ko: /* Frust-Artikel */
2022-12-16T01:00:28Z
<p><span class="autocomment">Frust-Artikel</span></p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 16. Dezember 2022, 03:00 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 653:</td>
<td colspan="2" class="diff-lineno">Zeile 653:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Nebenbei bemerkt ist „[[Zustandslosigkeit]]“ ein Riesenthema in der IT und hat nichts mit Computer-Hardware zu tun.</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: Nebenbei bemerkt ist „[[Zustandslosigkeit]]“ ein Riesenthema in der IT und hat nichts mit Computer-Hardware zu tun.</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: VG --[[Benutzer:PerfektesChaos|PerfektesChaos]] 17:58, 15. Dez. 2022 (CET)</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::: VG --[[Benutzer:PerfektesChaos|PerfektesChaos]] 17:58, 15. Dez. 2022 (CET)</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Vielleicht noch zur Ergänzung, um die Kritik am "kategorientheoretischen Teil" etwas konkreter werden zu lassen: Was ein Katamorphismus lässt sich ja recht kurz definieren ([https://ncatlab.org/nlab/show/catamorphism]): Gegeben einen Endofunktor <math>F</math>, ist ein Katamorphismus einfach der einzige F-Algebra-Homomorphismus von der initialen F-Algebra (wir nehmen mal an, dass es die gibt) zu einer anderen F-Algebra.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Tatsächlich dual dazu wäre: ein Anamorphismus ist der einzige F-Koalgebra-Homomorphismus von einer anderen F-Koalgebra zur terminalen F-Koalgebra. </div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Nun stimmen in den meisten Kategorien die Trägerobjekte von initialen F-Algebren und terminalen F-Koalgebren natürlich nicht überein.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Für eine Menge <math>A</math> hätten wir beim Funktor für die A-Listensignatur, <math>S \mapsto 1 + A\times S</math> in <math>\mathrm{Set}</math> einerseits die Menge der endlichen Listen <math>A^*</math> über <math>A</math> und andererseits die Menge der endlichen oder unendlichen Listen <math>A^\infty</math> über <math>A</math>.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Die Kategorie(nklasse), über die man spricht, wenn man in Lean 3 nur "normale" Funktionsdefinitionen verwendet, ist ausreichend <math>\mathrm{Set}</math>-like, um auf die Unterschiede aufmerksam zu werden: </div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight></div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>def list.fold{A S : Type}(f : option (A × S) → S): list A → S</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>| [] := f none</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>| (a::as) := f $ some (a, list.fold as) </syntaxhighlight></div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Entsprechendes mit <code>unfold</code>, <syntaxhighlight>def list.unfold{A S : Type}(f : S → option (A × S)): S → list A := ???</syntaxhighlight> geht nicht. Man muss ein paar zusätzliche Forderungen stellen, wenn man tatsächlich <code>list A</code> als Ergebnis haben will, etwa etwas mit einer wohlfundierten Relation: </div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight></div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>def list.unfold{A S : Type}{R : S → S → Prop}</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div> (wf: well_founded R)</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div> (f : S → option (A × S))(M : ∀ {s as}, f s = some as → R as.2 s): S → list A </div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:= wf.fix $ λ s rec, </div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>begin </div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div> cases e: f s with as e,</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div> exact [],</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div> exact as.1 :: rec as.2 (M e),</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>end</syntaxhighlight></div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Oder man verwendet statt <math>A^*</math> (<code>list A</code>) eben passendererweise <math>A^\infty</math> (hier <code>stream A</code>):</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: <syntaxhighlight></div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>def stream(A : Type) := {f : ℕ → option A // ∀ n, f n = none → f (n+1) = none } -- oder wie auch immer man das Konzept formalisieren möchte.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>def stream.unfold{A S : Type}(α : S → option(A × S)): S → stream A := [...] </syntaxhighlight></div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Das geht.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Klar, wenn man zu Kategorien übergeht, in denen die Pfeile <em>partielle</em> Funktionen sind (hier sind aber auch mindestens zwei Ausprägungen möglich), </div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: werden manchmal zumindest die Trägerobjekte vereinigt (in Haskell etwa gibt es soetwas wie <math>A^*</math> eigentlich <em>gar nicht</em>, in ML schon; ein <code>unfold</code> in ML kann aber auch nicht Totalität garantieren, und dann wird anderes komisch, etc.). --[[Benutzer:Daniel5Ko|Daniel5Ko]] ([[Benutzer Diskussion:Daniel5Ko|Diskussion]]) 02:00, 16. Dez. 2022 (CET)</div></td>
</tr>
</table>
Daniel5Ko
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=228889691&oldid=prev
PerfektesChaos: /* Frust-Artikel */ Senf
2022-12-15T16:58:35Z
<p><span class="autocomment">Frust-Artikel: </span> Senf</p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 15. Dezember 2022, 18:58 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 641:</td>
<td colspan="2" class="diff-lineno">Zeile 641:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>:--[[Benutzer:Daniel5Ko|Daniel5Ko]] ([[Benutzer Diskussion:Daniel5Ko|Diskussion]]) 03:34, 15. Dez. 2022 (CET)</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>:--[[Benutzer:Daniel5Ko|Daniel5Ko]] ([[Benutzer Diskussion:Daniel5Ko|Diskussion]]) 03:34, 15. Dez. 2022 (CET)</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::Danke. Mal sehen was noch kommt. --[[Benutzer:West of House|West of House]] ([[Benutzer Diskussion:West of House|Diskussion]]) 06:45, 15. Dez. 2022 (CET)</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>::Danke. Mal sehen was noch kommt. --[[Benutzer:West of House|West of House]] ([[Benutzer Diskussion:West of House|Diskussion]]) 06:45, 15. Dez. 2022 (CET)</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Das mit den Zuständen dürfte ein einziges Missverständnis sein.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:::* Es geht nicht darum, ob klassische oder Quantencomputer in ihrer Hardware Zustände kennen würden.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:::* Es geht darum, dass bei funktionaler Programmierung die Zwischenzustände innerhalb der Evaluierung unbekannt sind. Sie stecken im System, ich komme nicht dran, und sie gehen mich auch nichts an, und ich könnte auch nichts damit anfangen.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:::* Es gibt nur die Startwerte und das Resultat.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:::* Das ist anders als bei Prozeduren, wo ich zu Beginn und zum Ende einer Funktion Parameter und Rückgabewert loggen könnte. Weil ich den Algorithmus kenne, kann ich daran verfolgen, was genau meine Prozedur abarbeitet. Das klappt hier nicht.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Ich finde die Zusammenstellung der Beispiele sehr informativ.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:::* Sie entspricht den Hallo-Welt-Beispielen und gibt einen Eindruck in Syntax und Notation an einem trivialen und übersichtlichen Beispielproblem. So wie „Hallo Welt“ sagen auch kein Riesending wäre, aber ein Assemblerprogramm dazu zu bringen das auf einen Monitor zu schreiben ist eine Herausforderung.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:::* Ich selbst schreibe seit 40 Jahren mit Lisp und Tücke, äh, Lambda, und kann mit Haskell umgehen. Die Menge der Probleme, bei denen ich sowas einsetzen und dauerhaft Anderen zumuten würde, ist jedoch mikroskopisch.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Den Abschnitt mit der Abgrenzung von imperativen, prozeduralen Programmierung finde ich extrem wichtig. Es ist die wesentliche Hürde, die man erstmal überwinden muss – vergiss alle deine Vorstellungen, die du aus der prozeduralen Welt mitbringst, und fange bei Null an neu zu denken. Sonst wird das nix.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: Nebenbei bemerkt ist „[[Zustandslosigkeit]]“ ein Riesenthema in der IT und hat nichts mit Computer-Hardware zu tun.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::: VG --[[Benutzer:PerfektesChaos|PerfektesChaos]] 17:58, 15. Dez. 2022 (CET)</div></td>
</tr>
</table>
PerfektesChaos
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=228870977&oldid=prev
West of House: /* Frust-Artikel */ Antwort
2022-12-15T05:45:52Z
<p><span class="autocomment">Frust-Artikel: </span> Antwort</p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 15. Dezember 2022, 07:45 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 640:</td>
<td colspan="2" class="diff-lineno">Zeile 640:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>:* Die Frage, ob Computer zustandslos sind, hat mit Programmiersprachen wenig zu tun.</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>:* Die Frage, ob Computer zustandslos sind, hat mit Programmiersprachen wenig zu tun.</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>:--[[Benutzer:Daniel5Ko|Daniel5Ko]] ([[Benutzer Diskussion:Daniel5Ko|Diskussion]]) 03:34, 15. Dez. 2022 (CET)</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>:--[[Benutzer:Daniel5Ko|Daniel5Ko]] ([[Benutzer Diskussion:Daniel5Ko|Diskussion]]) 03:34, 15. Dez. 2022 (CET)</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>::Danke. Mal sehen was noch kommt. --[[Benutzer:West of House|West of House]] ([[Benutzer Diskussion:West of House|Diskussion]]) 06:45, 15. Dez. 2022 (CET)</div></td>
</tr>
</table>
West of House
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=228869607&oldid=prev
Daniel5Ko: /* Frust-Artikel */
2022-12-15T02:34:46Z
<p><span class="autocomment">Frust-Artikel</span></p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 15. Dezember 2022, 04:34 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 635:</td>
<td colspan="2" class="diff-lineno">Zeile 635:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>Ich bin gespannt, ob es Meinungen zu meiner (bewusst polemischen!) Darstellung gibt. --[[Benutzer:West of House|West of House]] ([[Benutzer Diskussion:West of House|Diskussion]]) 16:51, 14. Dez. 2022 (CET)</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>Ich bin gespannt, ob es Meinungen zu meiner (bewusst polemischen!) Darstellung gibt. --[[Benutzer:West of House|West of House]] ([[Benutzer Diskussion:West of House|Diskussion]]) 16:51, 14. Dez. 2022 (CET)</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:Ein paar Meinungen:</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:* Der "kategorientheoretische Teil" ist nicht solide.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:* Die Frage, ob Computer zustandslos sind, hat mit Programmiersprachen wenig zu tun.</div></td>
</tr>
<tr>
<td colspan="2" class="diff-empty diff-side-deleted"></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>:--[[Benutzer:Daniel5Ko|Daniel5Ko]] ([[Benutzer Diskussion:Daniel5Ko|Diskussion]]) 03:34, 15. Dez. 2022 (CET)</div></td>
</tr>
</table>
Daniel5Ko
https://de.wikipedia.org/w/index.php?title=Diskussion:Funktionale_Programmierung&diff=228854873&oldid=prev
West of House: /* Frust-Artikel */
2022-12-14T15:57:19Z
<p><span class="autocomment">Frust-Artikel</span></p>
<table style="background-color: #fff; color: #202122;" data-mw="interface">
<col class="diff-marker" />
<col class="diff-content" />
<col class="diff-marker" />
<col class="diff-content" />
<tr class="diff-title" lang="de">
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">← Nächstältere Version</td>
<td colspan="2" style="background-color: #fff; color: #202122; text-align: center;">Version vom 14. Dezember 2022, 17:57 Uhr</td>
</tr><tr>
<td colspan="2" class="diff-lineno">Zeile 634:</td>
<td colspan="2" class="diff-lineno">Zeile 634:</td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>Die größte enzyklopädische Unfall ist allerdings der Abschnitt "Beispiele", denn Lernende suchen immer nach und profitieren am meisten von Beispielen. Leider aber nicht von diesen. Hier hat jeder "X"-Fan-Boy seine Version einer konzeptionell irrelevanten Kreisflächenberechnung in seiner Programmiersprache "X" vorgelegt. Keines der zentralen Konzepte der FP außer "Funktion" und "Funktionsanwendung" findet hier Verwendung. Dieser ganze Herr-Lehrer-ich-weiß-was-Abschnitt ist m.E. hilflos und wertlos. Das XSL-Beispiel ist wenigstens noch komisch, weil ich nicht wusste, dass man einen so banalen Algorithmus derart wortreich entblättern kann.</div></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><div>Die größte enzyklopädische Unfall ist allerdings der Abschnitt "Beispiele", denn Lernende suchen immer nach und profitieren am meisten von Beispielen. Leider aber nicht von diesen. Hier hat jeder "X"-Fan-Boy seine Version einer konzeptionell irrelevanten Kreisflächenberechnung in seiner Programmiersprache "X" vorgelegt. Keines der zentralen Konzepte der FP außer "Funktion" und "Funktionsanwendung" findet hier Verwendung. Dieser ganze Herr-Lehrer-ich-weiß-was-Abschnitt ist m.E. hilflos und wertlos. Das XSL-Beispiel ist wenigstens noch komisch, weil ich nicht wusste, dass man einen so banalen Algorithmus derart wortreich entblättern kann.</div></td>
</tr>
<tr>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
<td class="diff-marker"></td>
<td style="background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;"><br /></td>
</tr>
<tr>
<td class="diff-marker" data-marker="−"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;"><div>Ich bin gespannt, ob es Meinungen<del style="font-weight: bold; text-decoration: none;"> dazu</del> zu meiner (bewusst polemischen!) Darstellung gibt. --[[Benutzer:West of House|West of House]] ([[Benutzer Diskussion:West of House|Diskussion]]) 16:51, 14. Dez. 2022 (CET)</div></td>
<td class="diff-marker" data-marker="+"></td>
<td style="color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;"><div>Ich bin gespannt, ob es Meinungen zu meiner (bewusst polemischen!) Darstellung gibt. --[[Benutzer:West of House|West of House]] ([[Benutzer Diskussion:West of House|Diskussion]]) 16:51, 14. Dez. 2022 (CET)</div></td>
</tr>
</table>
West of House