Curry-Howard-Isomorphismus

aus Wikipedia, der freien Enzyklopädie
Dies ist die aktuelle Version dieser Seite, zuletzt bearbeitet am 19. September 2017 um 19:51 Uhr durch imported>LoRo(2491690) (→‎Beweisbeispiel: colon eingefügt).
(Unterschied) ← Nächstältere Version | Aktuelle Version (Unterschied) | Nächstjüngere Version → (Unterschied)

Als Curry-Howard-Isomorphismus (auch Curry-Howard-Korrespondenz) bezeichnet man die Interpretation von Typen als logische Aussagen und von Termen eines bestimmten Typs als Beweise der zum Typ gehörenden Aussage; und umgekehrt. Benannt ist er nach den Mathematikern Haskell Brooks Curry und William Alvin Howard.

Halb-formale Beschreibung

Der Begriff der Wahrheit wird ausgetauscht mit dem Begriff der Beweisbarkeit, folgt also dem intuitionistischen Verständnis von Mathematik. Eine Aussage ist beweisbar, wenn es einen Term gibt, der den zur Aussage passenden Typ hat.

Einfache Junktoren

Ein Beweis für eine Konjunktion ist ein Paar von Beweisen, für sowohl als auch .

Ein Beweis für eine Disjunktion ist ein Term aus der disjunkten Vereinigung von und , .

Beweise für Implikationen sind totale Funktionen des Typs .

Die logische Negation wird üblicherweise als Abkürzung für definiert, wobei unter dem Curry-Howard-Isomorphismus dem leeren Typ entspricht.

Quantoren

Eine universell quantifizierte Aussage wird zu einer Funktion, bei der der Typ des Funktionswertes vom Wert des Funktionsarguments abhängig ist. Hier trifft man also auf dependent types.

Der Beweis einer existenziell quantifizierten Aussage muss zwei Dinge liefern: ein -Element , und einen Beweis für .

Beweisbeispiel

Der Satz vom ausgeschlossenen Dritten gilt in konstruktiven Logikkalkülen normalerweise nicht (würde er gelten, wäre jede Aussage entscheidbar, was entweder Ausdrucksschwäche oder Inkonsistenz nach sich zieht). Eine Version mit doppelter Negation unterhalb der Allquantisierung über Aussagen lässt sich jedoch durch Angabe eines Beweisterms belegen. Gesucht ist, für beliebige Aussagen , ein Beweis für

,

was unter Curry-Howard und mit Auflösung der Negationsabkürzung ein Term des Typs

wird. Der Lambda-Ausdruck

stellt einen Term des gewünschten Typs dar, wobei und die Injektionen in den zweistelligen Summentyp sind.

Praktische Anwendungen

Verfügbare und benutzbare Beweisassistenten/Programmiersprachen wie Coq, Epigram und Agda machen vom Curry-Howard-Isomorphismus Gebrauch, indem sie es gestatten, Beweise als Programme und Aussagen als Typen anzugeben. Der Typprüfer übernimmt dabei die Aufgabe, die angegebenen Beweise zu verifizieren.

Quellen