Curry – Howardova korespondence - Curry–Howard correspondence
Důkaz napsaný jako funkční program |
---|
plus_comm =zábava n m : nat =>nat_ind (zábava n0 : nat => n0 + m = m + n0) (plus_n_0 m) (zábava (y : nat) (H : y + m = m + y) => eq_ind (S (m + y)) (zábava n0 : nat => S (y + m) = n0) (f_equal S H) (m + S y) (plus_n_Sm m y)) n : pro všechny n m : nat, n + m = m + n |
Důkaz komutativity sčítání na přirozených číslech v asistentovi kontroly Coq. nat_ind znamená matematická indukce, eq_ind pro nahrazení rovných a f_equal za převzetí stejné funkce na obou stranách rovnosti. Dřívější věty jsou uváděny jako odkazy a . |
v teorie programovacího jazyka a teorie důkazů, Curry – Howardova korespondence (také známý jako Curry – Howardův izomorfismus nebo rovnocennost, nebo důkazy jako programy a propozice- nebo interpretace vzorců jako typů) je přímý vztah mezi počítačové programy a matematické důkazy.
Jde o zobecnění syntaktického analogie mezi systémy formální logiky a výpočetními výpočty, které poprvé objevil Američan matematik Haskell Curry a logik William Alvin Howard.[1] Právě souvislost mezi logikou a výpočtem se obvykle přisuzuje Currymu a Howardovi, ačkoli tato myšlenka souvisí s operativní interpretací intuicionistická logika dané v různých formulacích od L. E. J. Brouwer, Arend Heyting a Andrey Kolmogorov (vidět Brouwer – Heyting – Kolmogorovova interpretace )[2] a Stephen Kleene (vidět Realizovatelnost ). Vztah byl rozšířen o teorie kategorií jako třícestný Korespondence Curry – Howard – Lambek.
Původ, rozsah a důsledky
Počátky Curry – Howardova korespondence spočívá v několika pozorováních:
- V roce 1934 Kari podotýká, že typy kombinátorů lze považovat za axiomová schémata pro intuitivní implikační logika.[3]
- V roce 1958 poznamenává, že určitý druh kontrolní systém, označované jako Hilbertovy dedukční systémy, se shoduje na nějakém fragmentu s typovaným fragmentem standardu model výpočtu známý jako kombinační logika.[4]
- V roce 1969 Howarde podotýká, že další, „vyšší úroveň“ kontrolní systém, označované jako přirozený odpočet, lze přímo interpretovat v jeho intuitivní verze jako typová varianta model výpočtu známý jako lambda kalkul.[5]
Jinými slovy, Curryho-Howardova korespondence je pozorováním, že dvě rodiny zdánlivě nesouvisejících formalismů - jmenovitě systémy důkazů na jedné straně a modely výpočtu na straně druhé - jsou ve skutečnosti stejným druhem matematických objektů.
Pokud někdo abstrahuje od zvláštností formalizmu, vzniká následující zevšeobecnění: důkaz je program a vzorec, který dokazuje, je typ programu. Více neformálně to lze považovat za analogie že se uvádí, že návratový typ funkce (tj. typ hodnot vrácených funkcí) je analogický logické větě, s výhradou hypotéz odpovídajících typům hodnot argumentů předaných funkci; a že program pro výpočet této funkce je analogický důkazu této věty. Tím se nastaví forma logické programování na přísném základě: důkazy lze představovat jako programy, zejména jako lambdanebo důkazy mohou být běh.
Korespondence byla výchozím bodem velkého spektra nového výzkumu po jeho objevení, což vedlo zejména k nové třídě formální systémy navržen tak, aby fungoval jako kontrolní systém a jako napsaný funkční programovací jazyk. To zahrnuje Martin-Löf je intuicionistická teorie typů a Coquand je Počet konstrukcí, dva kameny, ve kterých jsou důkazy pravidelnými objekty diskurzu a ve kterých lze uvést vlastnosti důkazů stejným způsobem jako u libovolného programu. Tato oblast výzkumu se obvykle označuje jako moderní teorie typů.
Takový zadaný lambda kalkul odvozené z paradigmatu Curry – Howard vedlo k podobnému softwaru Coq ve kterém lze formalizovat, kontrolovat a spouštět důkazy považované za programy.
Opačný směr je použijte program k extrahování důkazu, vzhledem k jeho správnost —Oblasti výzkumu úzce související s kontrolní kód. To je možné pouze v případě, že programovací jazyk program, pro který je psán, je napsán velmi bohatě: vývoj systémů tohoto typu byl částečně motivován přáním, aby byla korespondence Curry – Howard prakticky relevantní.
Korespondence Curry – Howard také nastolila nové otázky týkající se výpočetního obsahu konceptů důkazů, které nebyly pokryty původními díly Curryho a Howarda. Zejména, klasická logika bylo prokázáno, že odpovídá schopnosti manipulovat s pokračování programů a symetrie následný počet vyjádřit dualitu mezi těmito dvěma strategie hodnocení známé jako call-by-name a call-by-value.
Spekulativně lze očekávat, že korespondence Curry – Howard povede k podstatnému unifikace mezi matematickou logikou a základní informatikou:
Logika a přirozená dedukce podle Hilberta jsou jen dva druhy systémů důkazů mezi velkou rodinou formalizmů. Alternativní syntaxe zahrnují následný počet, ochranné sítě, počet struktur atd. Pokud si člověk připustí korespondenci Curry – Howard jako obecný princip, že jakýkoli důkazní systém skrývá model výpočtu, měla by být možná teorie základní netypové výpočetní struktury těchto druhů důkazních systémů. Přirozenou otázkou pak je, zda lze o těchto základních výpočetních kalkulích říci něco matematicky zajímavého.
Naopak, kombinační logika a jednoduše zadaný lambda kalkul nejsou jediné modely výpočtu, buď. Girardův lineární logika byl vyvinut z jemné analýzy využití zdrojů v některých modelech lambda kalkulu; je tam napsaná verze Turingův stroj to by se chovalo jako důkazní systém? Zadané montážní jazyky jsou takovou instancí „nízkoúrovňových“ modelů výpočtu, které nesou typy.
Z důvodu možnosti psaní neukončovacích programů Turing-kompletní modely výpočtu (například jazyky s libovolným rekurzivní funkce ) je třeba vykládat opatrně, protože naivní aplikace korespondence vede k nekonzistentní logice. Nejlepším způsobem řešení libovolného výpočtu z logického hlediska je stále aktivně diskutovaná výzkumná otázka, ale jeden populární přístup je založen na použití monády oddělit prokazatelně ukončení od potenciálně nekončícího kódu (přístup, který také zobecňuje mnohem bohatší modely výpočtu,[6] a sám souvisí s modální logikou přirozeným rozšířením Curryho-Howardova izomorfismu[ext 1]). Radikálnější přístup, který obhajuje celkové funkční programování, je eliminovat neomezenou rekurzi (a vzdát se Turingova úplnost, i když si stále zachovává vysokou výpočetní složitost), s použitím více kontrolovaných korekční kdekoli je ve skutečnosti žádoucí nekončící chování.
Obecná formulace
Ve své obecnější formulaci je Curry-Howardova korespondence korespondencí mezi formálními důkazní kameny a systémy typu pro modely výpočtu. Zejména se rozděluje do dvou korespondencí. Jeden na úrovni vzorce a typy to je nezávislé na tom, který konkrétní kontrolní systém nebo model výpočtu je považován, a jeden na úrovni důkazy a programy který je tentokrát specifický pro konkrétní volbu systému kontroly a uvažovaného modelu výpočtu.
Na úrovni vzorců a typů korespondence říká, že implikace se chová stejně jako typ funkce, konjunkce jako typ „produktu“ (to může být nazýváno n-ticí, strukturou, seznamem nebo jiným termínem v závislosti na jazyce) ), disjunkce jako typ součtu (tento typ lze nazvat sjednocením), nepravdivý vzorec jako prázdný typ a skutečný vzorec jako typ singleton (jehož jediným členem je objekt null). Kvantifikátory odpovídají závislý funkční prostor nebo produkty (podle potřeby). To je shrnuto v následující tabulce:
Logická stránka | Programová stránka |
---|---|
univerzální kvantifikace | zobecněný typ produktu (Typ Π) |
existenční kvantifikace | zobecněný typ součtu (Σ typ) |
implikace | typ funkce |
spojení | typ produktu |
disjunkce | typ součtu |
skutečný vzorec | typ jednotky |
falešný vzorec | spodní typ |
Na úrovni důkazních systémů a modelů výpočtů korespondence ukazuje především identitu struktury, nejprve mezi některými konkrétními formulacemi systémů známých jako Dedukční systém ve stylu Hilberta a kombinační logika, a za druhé, mezi některými konkrétními formulacemi systémů známých jako přirozený odpočet a lambda kalkul.
Logická stránka | Programová stránka |
---|---|
Dedukční systém ve stylu Hilberta | typový systém pro kombinační logika |
přirozený odpočet | typový systém pro lambda kalkul |
Mezi přirozeným dedukčním systémem a lambda kalkulem existuje následující korespondence:
Logická stránka | Programová stránka |
---|---|
hypotézy | volné proměnné |
eliminace implikací (modus ponens) | aplikace |
implikace úvod | abstrakce |
Odpovídající systémy
Hilbertovy dedukční systémy a kombinační logika
Byla to na začátku jednoduchá poznámka v knize Curryho a Feyse z roku 1958 o kombinatorické logice: nejjednodušší typy pro základní kombinátory K a S kombinační logika překvapivě odpovídal příslušným schémata axiomu α → (β → α) a (α → (β → Γ)) → ((α → β) → (α → Γ)) použitý v Hilbertovy dedukční systémy. Z tohoto důvodu se tato schémata nyní často nazývají axiomy K a S. Jsou uvedeny příklady programů, které jsou v logice Hilbertovy stylu považovány za důkazy. níže.
Pokud se člověk omezuje na implikační intuicionistický fragment, jednoduchý způsob formalizace logiky v Hilbertově stylu je následující. Nechť Γ je konečná sbírka vzorců, považovaná za hypotézu. Pak δ je odvozitelné od Γ, označeno Γ ⊢ δ, v následujících případech:
- δ je hypotéza, tj. je to vzorec Γ,
- δ je příkladem schématu axiomu; tj. pod nejběžnějším systémem axiomů:
- δ má tvar α → (β → α), nebo
- δ má tvar (α → (β → Γ)) → ((α → β) → (α → Γ)),
- δ následuje dedukcí, tj. u některých α, oba α → δ a α jsou již odvozitelné od Γ (toto je pravidlo modus ponens )
To lze formalizovat pomocí odvozovací pravidla, stejně jako v levém sloupci následující tabulky.
Zadaná kombinační logika může být formulována pomocí podobné syntaxe: nechť Γ je konečná sbírka proměnných anotovaných jejich typy. Termín T (rovněž anotovaný svým typem) bude záviset na těchto proměnných [Γ ⊢ T:δ] když:
- T je jedna z proměnných v Γ,
- T je základní kombinátor; tj. pod nejběžnějším základem kombinátoru:
- T je K:α → (β → α) [kde α a β označit typy jeho argumentů], nebo
- T je S :(α → (β → Γ)) → ((α → β) → (α → Γ)),
- T je složení dvou dílčích podmínek, která závisí na proměnných v Γ.
Zde definovaná pravidla generování jsou uvedena v pravém sloupci níže. Curryho poznámka jednoduše uvádí, že oba sloupce jsou v korespondenci jedna ku jedné. K omezení korespondence intuicionistická logika znamená, že někteří klasický tautologie, jako Peirceův zákon ((α → β) → α) → α, jsou z korespondence vyloučeni.
Hilbertova intuitivní implikační logika | Jednoduše napsaná kombinační logika |
---|---|
Při pohledu na abstraktnější úrovni lze korespondenci přepracovat, jak je znázorněno v následující tabulce. Zvláště teorém o dedukci specifická pro Hilbertovu logiku odpovídá procesu eliminace abstrakce kombinační logiky.
Logická stránka | Programová stránka |
---|---|
předpoklad | proměnná |
axiomy | kombinátory |
modus ponens | aplikace |
teorém o dedukci | eliminace abstrakce |
Díky korespondenci lze výsledky kombinatorické logiky přenést do logiky ve stylu Hilberta a naopak. Například pojem snížení termínů v kombinační logice lze přenést do logiky ve stylu Hilberta a poskytuje způsob, jak kanonicky transformovat důkazy na jiné důkazy stejného tvrzení. Lze také přenést pojem běžných pojmů na pojem běžných důkazů, přičemž lze říci, že hypotézy axiomů nemusí být nikdy všechny odděleny (protože jinak může dojít ke zjednodušení).
Naopak neprokazatelnost v intuitivní logice Peirceův zákon lze přenést zpět do kombinatorické logiky: neexistuje žádný typovaný termín kombinační logiky, který je typovatelný typem
- ((α → β) → α) → α.
Lze také přenést výsledky týkající se úplnosti některých sad kombinátorů nebo axiomů. Například skutečnost, že kombinátor X představuje a jednobodový základ (rozšiřující) kombinační logiky znamená, že schéma jediného axiomu
- (((α → (β → Γ)) → ((α → β) → (α → Γ))) → ((δ → (ε → δ)) → ζ)) → ζ,
který je hlavní typ z X, je adekvátní náhradou za kombinaci schémat axiomu
- α → (β → α) a
- (α → (β → Γ)) → ((α → β) → (α → Γ)).
Přirozený odpočet a počet lambda
Po Kari zdůraznil syntaktickou korespondenci mezi Hilbertova dedukce a kombinační logika, Howarde výslovně v roce 1969 syntaktická analogie mezi programy jednoduše zadaný lambda kalkul a důkazy o přirozený odpočet. Níže levá strana formalizuje intuitivní implikační přirozenou dedukci jako počet sekvence (použití sekvencí je standardem v diskusích o Curry-Howardově izomorfismu, protože umožňuje jasnější formulaci pravidel dedukce) s implicitním oslabením a pravá strana ukazuje pravidla psaní lambda kalkul. Na levé straně Γ, Γ1 a Γ2 označují seřazené sekvence vzorců, zatímco na pravé straně označují sekvence pojmenovaných (tj. zadaných) vzorců se všemi různými názvy.
Intuicionistický implikační přirozený dedukce | Pravidla přiřazování typu lambda kalkulu |
---|---|
Abych parafrázoval korespondenci, dokázal jsem Γ ⊢ α znamená mít program, který při daných hodnotách s typy uvedenými v Γ vyrábí objekt typu α. Axiom odpovídá zavedení nové proměnné s novým neomezeným typem, → Já pravidlo odpovídá abstrakci funkce a → E pravidlo odpovídá aplikaci funkce. Všimněte si, že korespondence není přesná, pokud je kontext Γ chápán jako sada vzorců, například λ-podmínky λx.λy.X a λx.λy.y typu α → α → α by se v korespondenci nerozlišovaly. Jsou uvedeny příklady níže.
Howard ukázal, že korespondence se vztahuje i na další spojky logiky a dalších konstrukcí jednoduše zadaného lambda kalkulu. Při pohledu na abstraktní úrovni lze potom shrnout korespondenci, jak je znázorněno v následující tabulce. Zejména to také ukazuje, že pojem normálních forem v lambda kalkul zápasy Prawitz pojem normálního odpočtu v roce 2006; přirozený odpočet, z čehož vyplývá, že algoritmy pro problém osídlení typu lze proměnit v algoritmy pro rozhodování intuitivní prokazatelnost.
Logická stránka | Programová stránka |
---|---|
axiom | proměnná |
úvodní pravidlo | konstruktor |
eliminační pravidlo | destruktor |
normální odpočet | normální forma |
normalizace odpočtů | slabá normalizace |
prokazatelnost | problém osídlení typu |
intuitivní tautologie | obydlený typ |
Howardova korespondence se přirozeně vztahuje i na další rozšíření přirozený odpočet a jednoduše zadaný lambda kalkul. Zde je neúplný seznam:
- Girard-Reynolds Systém F jako společný jazyk pro výrokovou logiku druhého řádu i polymorfní lambda kalkul,
- logika vyššího řádu a Girardova Systém Fω
- indukční typy jako algebraický datový typ
- nutnost v modální logika a postupný výpočet[ext 2]
- možnost v modální logika a monadické typy pro efekty[ext 1]
- The λJá počet odpovídá příslušná logika.[7]
- Modalita místní pravdy (∇) v Grothendieckova topologie nebo ekvivalentní „laxní“ modalita (◯) Bentona, Biermana a de Paivy (1998) odpovídá logice CL popisující „typy výpočtu“.[8]
Klasické logické a řídicí operátory
V době Curryho a také v době Howarda se týkala pouze korespondence proof-as-programs intuicionistická logika, tj. logika, ve které zejména Peirceův zákon byl ne odvoditelný. Rozšíření korespondence k Peirceovu zákonu, a tedy k klasická logika vyšlo najevo z práce Griffina na operátorech psaní, které zachycují kontext hodnocení daného spuštění programu, takže tento kontext hodnocení může být později znovu nainstalován. Níže je uvedena základní korespondence ve stylu Curry – Howard pro klasickou logiku. Všimněte si korespondence mezi překlad dvojí negace slouží k mapování klasických důkazů na intuicionistickou logiku a styl pokračování-předávání překlad použitý k mapování výrazů lambda zahrnujících kontrolu na čisté výrazy lambda. Přesněji se týká překladů ve stylu pokračování předávání podle jména Kolmogorov Překlad dvojí negace a překlady ve stylu pokračování a předávání podle hodnoty se týkají jakéhosi překladu dvojí negace kvůli Kurodovi.
Logická stránka | Programová stránka |
---|---|
Peirceův zákon: ((α → β) → α) → α | pokračování hovoru s proudem |
překlad dvojí negace | překlad ve stylu pokračování-předávání |
Jemnější korespondence Curry – Howard existuje pro klasickou logiku, pokud definujeme klasickou logiku nikoli přidáním axiomu, jako je Peirceův zákon, ale umožněním několika závěrů v sekvencích. V případě klasické přirozené dedukce existuje korespondence proof-as-programs s typovými programy Parigotova λμ-počet.
Sekvenční počet
Korespondence proof-as-programs může být vyřešena pro formalismus známý jako Gentzen je následný počet ale nejedná se o korespondenci s dobře definovaným již existujícím modelem výpočtu, jako tomu bylo pro Hilbertův styl a přirozené dedukce.
Sekvenční počet je charakterizován přítomností pravidel levého úvodu, pravého úvodu a pravidla řezu, které lze eliminovat. Struktura následného počtu se vztahuje k počtu, jehož struktura je blízká jedné z některých abstraktní stroje. Neformální korespondence je následující:
Logická stránka | Programová stránka |
---|---|
eliminace řezu | redukce v podobě abstraktního stroje |
správná úvodní pravidla | konstruktory kódu |
levá úvodní pravidla | konstruktory vyhodnocovacích zásobníků |
priorita na pravé straně při eliminaci řezu | call-by-name snížení |
priorita na levé straně v eliminaci řezu | call-by-value snížení |
Související korespondence dokladů jako programů
Role de Bruijna
N. G. de Bruijn použil lambda notaci pro reprezentaci důkazů kontroly věty Automath, a představovaly návrhy jako „kategorie“ svých důkazů. Bylo to koncem šedesátých let ve stejném období, kdy Howard napsal svůj rukopis; de Bruijn pravděpodobně nevěděl o Howardově díle a korespondenci uvedl nezávisle (Sørensen & Urzyczyn [1998] 2006, s. 98–99). Někteří vědci mají tendenci používat termín Curry – Howard – de Bruijn korespondence místo korespondence Curry – Howard.
Interpretace BHK
The Interpretace BHK interpretuje intuitivní důkazy jako funkce, ale neurčuje třídu funkcí relevantních pro interpretaci. Pokud vezmeme lambda kalkul pro tuto třídu funkcí, pak Interpretace BHK říká to samé jako Howardova korespondence mezi přirozenou dedukcí a lambda kalkulem.
Realizovatelnost
Kleene je rekurzivní realizovatelnost rozdělí důkazy intuitivní aritmetiky do dvojice rekurzivní funkce a důkazu vzorce vyjadřujícího, že rekurzivní funkce „realizuje“, tj. správně vytvoří instanci disjunkce a existenciálních kvantifikátorů počátečního vzorce, aby se vzorec splnil.
Kreisel Upravená realizovatelnost platí pro intuitivní predikátovou logiku vyššího řádu a ukazuje, že jednoduše zadaný termín lambda indukčně extrahovaný z důkazu realizuje počáteční vzorec. V případě výrokové logiky se shoduje s tvrzením Howarda: extrahovaný termín lambda je samotný důkaz (viděný jako netypovaný termín lambda) a prohlášení o realizovatelnosti je parafrází skutečnosti, že extrahovaný termín lambda má typ, který má vzorec znamená (viděn jako typ).
Gödel je výklad dialectica realizuje (rozšíření) intuitivní aritmetiku s vypočítatelnými funkcemi. Souvislost s lambda kalkulem je nejasná, a to i v případě přirozené dedukce.
Korespondence Curry – Howard – Lambek
Joachim Lambek na začátku 70. let ukázal, že důkazy intuicionistické výrokové logiky a kombinátorů typovaného kombinační logika sdílet společnou teorii rovnic, která je jednou z kartézské uzavřené kategorie. Výraz Curry – Howard – Lambekova korespondence nyní někteří lidé používají k označení třícestného izomorfismu mezi intuicionistickou logikou, zadaným lambda kalkulem a kartézskými uzavřenými kategoriemi, přičemž objekty jsou interpretovány jako typy nebo propozice a morfismy jako termíny nebo důkazy. Korespondence funguje na rovnicové úrovni a nejedná se o vyjádření syntaktické identity struktur, jak je tomu u každé z Curryho a Howardových korespondencí: tj. Struktura dobře definovaného morfismu v kartézské uzavřené kategorii není srovnatelná s struktura důkazu příslušného úsudku v logice Hilbertovy nebo přirozené dedukce. Pro objasnění tohoto rozdílu je níže formulována základní syntaktická struktura kartézských uzavřených kategorií.
Objekty (typy) jsou definovány pomocí
- je objekt
- -li α a β jsou tedy objekty a jsou objekty.
Morfismy (termíny) jsou definovány pomocí
- , , , a jsou morfismy
- -li t je morfismus, λ t je morfismus
- -li t a u jsou morfismy, a jsou morfismy.
Dobře definované morfismy (zadané výrazy) jsou definovány následujícím způsobem pravidla psaní (ve kterém je obvyklá kategorická morfistická notace je nahrazen následný počet notace ).
Identita:
Složení:
Typ jednotky (koncový objekt ):
Kartézský součin:
Levá a pravá projekce:
Kari:
Nakonec rovnice kategorie jsou
- (pokud je správně napsaný)
Tyto rovnice znamenají následující -zákony:
Nyní existuje t takhle iff je prokazatelný v implicitní intuicionistické logice.
Příklady
Díky korespondenci Curry – Howard je typový výraz, jehož typ odpovídá logickému vzorci, analogický s důkazem tohoto vzorce. Zde jsou příklady.
Kombinátor identit vnímán jako důkaz α → α v logice Hilbertova stylu
Jako příklad zvažte důkaz věty α → α. v lambda kalkul, toto je typ funkce identity Já = λX.X a v kombinační logice se funkce identity získá aplikací S = λfgx.fx(gx) dvakrát do K. = λxy.X. To znamená, Já = ((S K.) K.). Jako popis důkazu se uvádí, že k prokázání lze použít následující kroky α → α:
- vytvořit instanci druhého schématu axiomu pomocí vzorců α, β → α a α získat doklad o (α → ((β → α) → α)) → ((α → (β → α)) → (α → α)),
- vytvořit instanci prvního schématu axiomu jednou pomocí α a β → α získat doklad o α → ((β → α) → α),
- vytvořit instanci prvního schématu axiomu podruhé pomocí α a β získat doklad o α → (β → α),
- použít modus ponens dvakrát a získat doklad o α → α
Obecně se postupuje tak, že kdykoli program obsahuje žádost o formulář (P Q), je třeba postupovat podle těchto kroků:
- Nejprve prokažte věty odpovídající typům P a Q.
- Od té doby P je aplikován na Q, typ P musí mít formu α → β a typ Q musí mít formu α pro některé α a β. Proto je možné oddělit závěr, β, prostřednictvím pravidla modus ponens.
Kombinátor kompozice vnímán jako důkaz (β → α) → (Γ → β) → Γ → α v logice Hilbertova stylu
Jako složitější příklad se podívejme na větu, která odpovídá B funkce. Typ B je (β → α) → (Γ → β) → Γ → α. B je ekvivalentní (S (K. S) K.). Toto je náš plán pro důkaz věty (β → α) → (Γ → β) → Γ → α.
Prvním krokem je konstrukce (K. S). Aby se stal předchůdcem K. axiom vypadá jako S axiom, množina α rovná (α → β → Γ) → (α → β) → α → Γ, a β rovná δ (aby se zabránilo kolizím proměnných):
- K. : α → β → α
- K.[α = (α → β → Γ) → (α → β) → α → Γ, β= δ]: (((α → β → Γ) → (α → β) → α → Γ) → δ → (α → β → Γ) → (α → β) → α → Γ
Vzhledem k tomu, že předchůdce zde je spravedlivý S, následník lze oddělit pomocí Modus Ponens:
- K S : δ → (α → β → Γ) → (α → β) → α → Γ
Toto je věta, která odpovídá typu (K. S). Nyní použijte S k tomuto výrazu. Brát S jak následuje
- S : (α → β → Γ) → (α → β) → α → Γ,
dát α = 8, β = α → β → Γ, a Γ = (α → β) → α → Γ, poddajný
- S[α = δ, β = α → β → Γ, Γ = (α → β) → α → Γ]: (δ → (α → β → Γ) → (α → β) → α → Γ) → (δ → (α → β → Γ)) → δ → (α → β) → α → Γ
a potom odpojte následující:
- S (KS) : (δ → α → β → Γ) → δ → (α → β) → α → Γ
Toto je vzorec pro typ (S (K. S)). Zvláštní případ této věty má δ = (β → Γ):
- S (KS)[5 = β → Γ]: ((β → Γ) → α → β → Γ) → (β → Γ) → (α → β) → α → Γ
Na tento poslední vzorec je třeba použít K.. Specializujte se K. opět, tentokrát nahrazením α s (β → Γ) a β s α:
- K. : α → β → α
- K.[α = β → Γ, β = α] : (β → Γ) → α → (β → Γ)
To je stejné jako předchůdce předchozího vzorce, takže se oddělí následek:
- S (KS) K. : (β → Γ) → (α → β) → α → Γ
Přepínání názvů proměnných α a y nám dává
- (β → α) → (Γ → β) → Γ → α
což bylo to, co se ukázalo.
Normální důkaz (β → α) → (Γ → β) → Γ → α v přirozené dedukci považované za λ-termín
Níže uvedený diagram dokazuje (β → α) → (Γ → β) → Γ → α v přirozené dedukci a ukazuje, jak to lze interpretovat jako λ-výraz λ A. λ b. λ G.(A (b G)) typu (β → α) → (Γ → β) → Γ → α.
a: β → α, b: γ → β, g: γ ⊢ b: γ → β a: β → α, b: γ → β, g: γ ⊢ g: γ ————————— —————————————————————————————————————————————————— ——————————————————————————————————————————— a: β → α, b : γ → β, g: γ ⊢ a: β → α a: β → α, b: γ → β, g: γ ⊢ bg: β ————————————————— —————————————————————————————————————————————————— ————— a: β → α, b: γ → β, g: γ ⊢ a (bg): α ———————————————————————— ————————————— a: β → α, b: γ → β ⊢ λ g. a (bg): γ → α ———————————————————————————————————————— a: β → α ⊢ λ b. λ g. a (bg): (γ → β) -> γ → α ——————————————————————————————————————— - ⊢ λ a. λ b. λ g. a (b g): (β → α) -> (γ → β) -> γ → α
Další aplikace
Nedávno byl izomorfismus navržen jako způsob, jak definovat oddíl prohledávaného prostoru v genetické programování.[9] Metoda indexuje sady genotypů (programové stromy vyvinuté systémem GP) podle jejich isomorfního důkazu Curry – Howard (označovaného jako druh).
Jak poznamenal INRIA ředitel výzkumu Bernard Lang,[10] korespondence Curry-Howard představuje argument proti patentovatelnosti softwaru: protože algoritmy jsou matematické důkazy, patentovatelnost prvního z nich by znamenala patentovatelnost druhého. Věta může být soukromým majetkem; matematik by musel za jeho použití zaplatit a důvěřovat společnosti, která jej prodává, ale svůj důkaz drží v tajnosti a odmítá odpovědnost za případné chyby.
Zobecnění
Zde uvedené korespondence jdou mnohem dále a hlouběji. Například kartézské uzavřené kategorie jsou zobecněny na uzavřené monoidní kategorie. The interní jazyk z těchto kategorií je lineární systém (souhlasí s lineární logika ), který zobecňuje lambda kalkul jednoduchého typu jako vnitřní jazyk kartézských uzavřených kategorií. Kromě toho lze prokázat, že odpovídají cobordismů,[11] které hrají zásadní roli v teorie strun.
Prozkoumána je také rozšířená sada rovnocennosti teorie homotopy, která se stala velmi aktivní oblastí výzkumu kolem roku 2013 a od roku 2018[Aktualizace] stále je.[12] Tady, teorie typů je rozšířen o axiom univalence („ekvivalence je ekvivalentní k rovnosti“), která umožňuje použít teorii typu homotopy jako základ pro celou matematiku (včetně teorie množin a klasická logika, poskytující nové způsoby, jak diskutovat o axiom volby a mnoho dalších věcí). To znamená, že korespondence Curry – Howard, že důkazy jsou prvky obydlených typů, je zobecněna na pojem homotopická ekvivalence důkazů (jako cesty ve vesmíru, typ identity nebo typ rovnosti teorie typu interpretovaná jako cesta).[13]
Reference
Tento článek obsahuje seznam obecných Reference, ale zůstává z velké části neověřený, protože postrádá dostatečné odpovídající vložené citace.Duben 2010) (Zjistěte, jak a kdy odstranit tuto zprávu šablony) ( |
- ^ Korespondence byla poprvé výslovně vyjádřena v Howard 1980. Viz například část 4.6, str.53 Gert Smolka a Jan Schwinghammer (2007-8), poznámky k přednášce v sémantice
- ^ Interpretace Brouwer – Heyting – Kolmogorov se také nazývá „důkazní výklad“: str. 161 Juliette Kennedy, Roman Kossak, vyd. 2011. Teorie množin, aritmetika a základy matematiky: věty, filozofie ISBN 978-1-107-00804-5
- ^ Curry 1934.
- ^ Curry & Feys 1958.
- ^ Howard 1980.
- ^ Moggi, Eugenio (1991), „Pojmy výpočtu a monády“ (PDF), Informace a výpočet, 93 (1): 55–92, doi:10.1016/0890-5401(91)90052-4
- ^ Sørenson, Morten; Urzyczyn, Paweł (1998), Přednášky o Curry-Howardově izomorfismu, CiteSeerX 10.1.1.17.7385
- ^ Goldblatt, „7.6 Grothendieckova topologie jako intuitivní modalita“ (PDF), Matematická modální logika: model její evoluce, str. 76–81. Uvedená „laxní“ modalita pochází z Benton; Bierman; de Paiva (1998), „Výpočetní typy z logické perspektivy“, Journal of Functional Programming, 8 (2): 177–193, CiteSeerX 10.1.1.258.6004, doi:10.1017 / s0956796898002998
- ^ F. Binard a A. Felty, „Genetické programování s polymorfními typy a funkcemi vyššího řádu.“ v Sborník z 10. výroční konference o genetických a evolučních výpočtech, stránky 1187 1194, 2008.[1]
- ^ "Článek". bat8.inria.fr. Citováno 2020-01-31.
- ^ John c. Baez a Mike zůstávají, “Fyzika, topologie, logika a výpočet: kámen Rosetta ", (2009) ArXiv 0903.0340 v Nové struktury pro fyziku, vyd. Bob Coecke, Přednášky z fyziky sv. 813, Springer, Berlin, 2011, s. 95–174.
- ^ „homotopy type theory - Google Trends“. trendy.google.com. Citováno 2018-01-26.
- ^ Teorie typu homotopy: Univalentní základy matematiky. (2013) Program Univalent Foundations. Institut pro pokročilé studium.
Klíčové odkazy
- Curry, HB (1934-09-20). "Funkčnost v kombinační logice". Sborník Národní akademie věd Spojených států amerických. 20 (11): 584–90. Bibcode:1934PNAS ... 20..584C. doi:10.1073 / pnas.20.11.584. ISSN 0027-8424. PMC 1076489. PMID 16577644.
- Curry, Haskell B; Feys, Robert (1958). Craig, William (ed.). Kombinovaná logika. Studie v logice a základech matematiky. 1. Nakladatelská společnost North-Holland. LCCN a59001593; se dvěma sekcemi od Craiga, Williama; viz odstavec 9E
- De Bruijn, Nicolaas (1968), Automath, jazyk pro matematiku, Katedra matematiky, Eindhoven University of Technology, TH-report 68-WSK-05. Přetištěno v revidované podobě se dvěma stránkami s komentářem v: Automation and Reasoning, sv. 2, Klasické práce o výpočetní logice 1967–1970Springer Verlag, 1983, s. 159–200.
- Howard, William A. (září 1980) [původní rukopis z roku 1969], „Konstrukce podle vzorců jako typů“, v Seldin, Jonathan P.; Hindley, J. Roger (eds.), H.B. Curry: Eseje o kombinatorické logice, lambda kalkulu a formalismu, Akademický tisk, str. 479–490, ISBN 978-0-12-349050-6.
Rozšíření korespondence
- ^ A b Pfenning, Frank; Davies, Rowan (2001), „Soudní rekonstrukce modální logiky“ (PDF), Matematické struktury v informatice, 11 (4): 511–540, CiteSeerX 10.1.1.43.1611, doi:10.1017 / S0960129501003322
- ^ Davies, Rowan; Pfenning, Frank (2001), „Modální analýza postupných výpočtů“ (PDF), Deník ACM, 48 (3): 555–604, CiteSeerX 10.1.1.3.5442, doi:10.1145/382780.382785, S2CID 52148006
- Griffin, Timothy G. (1990), „The Formulas-as-Types Pojem kontroly“, Konf. Rekordní 17. výroční ACM Symp. o zásadách programovacích jazyků, POPL '90, San Francisco, CA, USA, 17. – 19. ledna 1990, str. 47–57, doi:10.1145/96709.96714, ISBN 978-0-89791-343-0, S2CID 3005134.
- Parigot, Michel (1992), „Lambda-mu-počet: Algoritmická interpretace klasické přirozené dedukce“, Mezinárodní konference o logickém programování a automatickém uvažování: LPAR '92 Proceedings, Petrohrad, Rusko, Přednášky v informatice, 624, Springer-Verlag, s. 190–201, ISBN 978-3-540-55727-2.
- Herbelin, Hugo (1995), „Lambda-Calculus Structure Isomorphic to Gentzen-Style Sequent Structure Structure“, Pacholski, Leszek; Tiuryn, Jerzy (eds.), Computer Science Logic, 8. mezinárodní workshop, CSL '94, Kazimierz, Polsko, 25. – 30. Září 1994, Selected Papers, Přednášky v informatice, 933, Springer-Verlag, str. 61–75, ISBN 978-3-540-60017-6.
- Gabbay, Dov; de Queiroz, Ruy (1992). "Rozšíření Curryho-Howardovy interpretace na lineární, relevantní a další logiku zdrojů". Journal of Symbolic Logic. The Journal of Symbolic Logic. 57. str. 1319–1365. doi:10.2307/2275370. JSTOR 2275370.. (Plná verze příspěvku prezentovaného na Logické kolokvium '90, Helsinky. Abstrakt v JSL 56(3):1139–1140, 1991.)
- de Queiroz, Ruy; Gabbay, Dov (1994), „Rovnost ve značených dedukčních systémech a funkční interpretace výrokové rovnosti“, Dekker, Paul; Stokhof, Martin (eds.), Sborník devátého amsterdamského kolokvia, ILLC/Department of Philosophy, University of Amsterdam, pp. 547–565, ISBN 978-90-74795-07-4.
- de Queiroz, Ruy; Gabbay, Dov (1995), "The Functional Interpretation of the Existential Quantifier", Bulletin of the Interest Group in Pure and Applied Logics, 3, pp. 243–290. (Full version of a paper presented at Logic Colloquium '91, Uppsala. Abstrakt v JSL 58(2):753–754, 1993.)
- de Queiroz, Ruy; Gabbay, Dov (1997), "The Functional Interpretation of Modal Necessity", in de Rijke, Maarten (ed.), Advances in Intensional Logic, Applied Logic Series, 7, Springer-Verlag, pp. 61–91, ISBN 978-0-7923-4711-8.
- de Queiroz, Ruy; Gabbay, Dov (1999), "Labelled Natural Deduction", in Ohlbach, Hans-Juergen; Reyle, Uwe (eds.), Logic, Language and Reasoning. Essays in Honor of Dov Gabbay, Trendy v logice, 7, Kluwer, pp. 173–250, ISBN 978-0-7923-5687-5.
- de Oliveira, Anjolina; de Queiroz, Ruy (1999), "A Normalization Procedure for the Equational Fragment of Labelled Natural Deduction", Logic Journal of the Interest Group in Pure and Applied Logics, 7, Oxford University Press, pp. 173–215. (Full version of a paper presented at 2nd WoLLIC'95, Recife. Abstrakt v Journal of the Interest Group in Pure and Applied Logics 4(2):330–332, 1996.)
- Poernomo, Iman; Crossley, John; Wirsing; Martin (2005), Adapting Proofs-as-Programs: The Curry–Howard Protocol, Monographs in Computer Science, Springer, ISBN 978-0-387-23759-6, concerns the adaptation of proofs-as-programs program synthesis to coarse-grain and imperative program development problems, via a method the authors call the Curry–Howard protocol. Includes a discussion of the Curry–Howard correspondence from a Computer Science perspective.
- de Queiroz, Ruy J.G.B.; de Oliveira, Anjolina (2011), "The Functional Interpretation of Direct Computations", Elektronické poznámky v teoretické informatice, Elsevier, 269: 19–40, doi:10.1016/j.entcs.2011.03.003. (Full version of a paper presented at LSFA 2010, Natal, Brazil.)
Filozofické interpretace
- de Queiroz, Ruy J.G.B. (1994), "Normalisation and language-games", Dialectica, 48, pp. 83–123. (Early version presented at Logic Colloquium '88, Padova. Abstrakt v JSL 55:425, 1990.)
- de Queiroz, Ruy J.G.B. (2001), "Meaning, function, purpose, usefulness, consequences – interconnected concepts", Logic Journal of the Interest Group in Pure and Applied Logics, 9, pp. 693–734. (Early version presented at Fourteenth International Wittgenstein Symposium (Centenary Celebration) held in Kirchberg/Wechsel, August 13–20, 1989.)
- de Queiroz, Ruy J.G.B. (2008), "On Reduction Rules, Meaning-as-use, and Proof-theoretic Semantics", Studia Logica, 90 (2): 211–247, doi:10.1007/s11225-008-9150-5, S2CID 11321602.
Synthetic papers
- De Bruijn, Nicolaas Govert (1995), "On the roles of types in mathematics" (PDF), in Groote, Philippe de (ed.), De Groote 1995, pp. 27–54, the contribution of de Bruijn by himself.
- Geuvers, Herman (1995), "The Calculus of Constructions and Higher Order Logic", De Groote 1995, pp. 139–191, contains a synthetic introduction to the Curry–Howard correspondence.
- Gallier, Jean H. (1995), "On the Correspondence between Proofs and Lambda-Terms" (PDF), De Groote 1995, pp. 55–138, contains a synthetic introduction to the Curry–Howard correspondence.
- Wadler, Philip (2014), "Propositions as Types" (PDF), Komunikace ACM, 58 (12): 75–84, doi:10.1145/2699407, S2CID 11957500
Knihy
- De Groote, Philippe, ed. (1995), The Curry–Howard Isomorphism, Cahiers du Centre de Logique (Université catholique de Louvain), 8, Academia-Bruylant, ISBN 978-2-87209-363-2, reproduces the seminal papers of Curry-Feys and Howard, a paper by de Bruijn and a few other papers.
- Sørensen, Morten Heine; Urzyczyn, Paweł (2006) [1998], Lectures on the Curry–Howard isomorphism„Studium logiky a základy matematiky, 149, Elsevierova věda, CiteSeerX 10.1.1.17.7385, ISBN 978-0-444-52077-7, notes on proof theory and type theory, that includes a presentation of the Curry–Howard correspondence, with a focus on the formulae-as-types correspondence
- Girard, Jean-Yves (1987–1990), Proof and Types, Cambridge Tracts in Theoretical Computer Science, 7, Translated by and with appendices by Lafont, Yves and Taylor, Paul, Cambridge University Press, ISBN 0-521-37181-3, archivovány z originál dne 2008-04-18, notes on proof theory with a presentation of the Curry–Howard correspondence.
- Thompson, Simon (1991), Type Theory and Functional Programming Addison – Wesley, ISBN 0-201-41667-0.
- Poernomo, Iman; Crossley, John; Wirsing; Martin (2005), Adapting Proofs-as-Programs: The Curry–Howard Protocol, Monographs in Computer Science, Springer, ISBN 978-0-387-23759-6, concerns the adaptation of proofs-as-programs program synthesis to coarse-grain and imperative program development problems, via a method the authors call the Curry–Howard protocol. Includes a discussion of the Curry–Howard correspondence from a Computer Science perspective.
- Binard, F.; Felty, A. (2008), "Genetic programming with polymorphic types and higher-order functions" (PDF), Proceedings of the 10th annual conference on Genetic and evolutionary computation, Association for Computing Machinery, pp. 1187–94, doi:10.1145/1389095.1389330, ISBN 9781605581309, S2CID 3669630
- de Queiroz, Ruy J.G.B.; de Oliveira, Anjolina G.; Gabbay, Dov M. (2011), The Functional Interpretation of Logical Deduction, Advances in Logic, 5, Imperial College Press/World Scientific, ISBN 978-981-4360-95-1.
Další čtení
- Johnstone, P.T. (2002), "D4.2 λ-Calculus and cartesian closed categories", Sketches of an Elephant, A Topos Theory Compendium, 2, Clarendon Press, pp. 951–962, ISBN 978-0-19-851598-2 — gives a kategorický view of "what happens" in the Curry–Howard correspondence.
externí odkazy
- Howard on Curry-Howard
- The Curry–Howard Correspondence in Haskell
- The Monad Reader 6: Adventures in Classical-Land: Curry–Howard in Haskell, Pierce's law.