Logika vypočítatelnosti - Computability logic

Logika vypočítatelnosti (CoL) je výzkumný program a matematický rámec pro přestavbu logiky jako systematické formální teorie vypočítatelnost, naproti tomu klasická logika což je formální teorie pravdy. To bylo představeno a tak pojmenováno Giorgi Japaridze v roce 2003.[1]

V klasické logice představují vzorce pravdivé / nepravdivé výroky. V CoL představují vzorce výpočetní problémy. V klasické logice platnost vzorce závisí pouze na jeho formě, nikoli na jeho významu. V CoL znamená platnost být vždy vypočítatelný. Obecněji řečeno, klasická logika nám říká, kdy pravdivost daného tvrzení vždy vyplývá z pravdivosti dané sady dalších tvrzení. Podobně nám CoL říká, kdy je vypočítatelnost daného problému A vždy vyplývá z vypočítatelnosti jiných zadaných problémů B1, ..., Bn. Kromě toho poskytuje jednotný způsob, jak skutečně vytvořit řešení (algoritmus ) pro takové A ze všech známých řešení z B1, ..., Bn.

CoL formuluje výpočetní problémy v jejich nejobecnější podobě - interaktivní smysl. CoL definuje a výpočetní problém jako hra hraná strojem proti jeho prostředí. Takový problém je vypočitatelný pokud existuje stroj, který vyhraje hru proti každému možnému chování prostředí. Takový hrací automat zobecňuje Church-Turingova teze na interaktivní úroveň. Klasický koncept pravdy se ukázal být zvláštním případem vypočítatelnosti s nulovým stupněm interaktivity. Díky tomu je klasická logika zvláštním fragmentem CoL. CoL je tedy konzervativní rozšíření klasické logiky. Logika vypočítatelnosti je expresivnější, konstruktivnější a výpočetně významnější než klasická logika. Kromě klasické logiky logika přátelská k nezávislosti (IF) a určitá správná rozšíření lineární logika a intuicionistická logika také se ukázaly jako přírodní fragmenty CoL.[2][3] Proto lze ze sémantiky CoL odvodit smysluplné pojmy „intuicionistická pravda“, „lineární logická pravda“ a „IF-logická pravda“.

CoL systematicky odpovídá na základní otázku, co a jak lze vypočítat; CoL má tedy mnoho aplikací, jako jsou konstruktivní aplikované teorie, systémy znalostní báze, systémy pro plánování a akce. Z nich zatím byly značně prozkoumány pouze aplikace v konstruktivních aplikovaných teoriích: byla vytvořena řada teorií čísel založených na CoL, nazývaných „klaritmetika“[4][5] jako výpočetně a komplexně teoreticky smysluplné alternativy k klasické logice Peano aritmetika a jeho variace, jako jsou systémy omezená aritmetika.

Tradiční kontrolní systémy jako např přirozený odpočet a následný počet jsou nedostatečné pro axiomatizaci netriviálních fragmentů CoL. To si vyžádalo vyvinout alternativní, obecnější a pružnější metody dokazování, jako např cirkulující počet.[6][7]

Jazyk

Provozovatelé logiky vypočítatelnosti: jména, symboly a hodnoty

Celý jazyk CoL rozšiřuje jazyk klasické logiky prvního řádu. Jeho logický slovník má několik druhů spojení, disjunkce, kvantifikátory, implikace, negace a takzvané operátory opakování. Tato kolekce obsahuje všechny spojky a kvantifikátory klasické logiky. Jazyk má také dva druhy nelogických atomů: základní a Všeobecné. Představují základní atomy, které nejsou ničím jiným než atomy klasické logiky základní problémy, tj. hry bez pohybů, které automat automaticky vyhrává, když jsou pravdivé, a prohrává, když jsou nepravdivé. Obecné atomy, na druhé straně, lze interpretovat jako jakékoli hry, základní nebo ne-elementární. Sémanticky i syntakticky není klasická logika ničím jiným než fragmentem CoL získaným zákazem obecných atomů v jeho jazyce a zákazem všech ostatních operátorů než ¬, ∧, ∨, →, ∀, ∃.

Japaridze opakovaně poukazoval na to, že jazyk CoL je otevřený a může projít dalšími rozšířeními. Vzhledem k expresivitě tohoto jazyka byly pokroky v CoL, jako je budování axiomatizací nebo budování aplikovaných teorií založených na CoL, obvykle omezeny na jeden nebo jiný vlastní fragment jazyka.

Sémantika

Hry, které jsou základem sémantiky CoL, se nazývají statické hry. Takové hry nemají pořadí tahů; hráč se může kdykoli pohybovat, zatímco ostatní hráči „přemýšlejí“. Statické hry však nikdy hráče nepotrestají za příliš dlouhé „přemýšlení“ (zdržování jeho vlastních tahů), takže se takové hry nikdy nestanou soutěží o rychlost. Všechny základní hry jsou automaticky statické, stejně jako u her je povoleno interpretovat obecné atomy.

Ve statických hrách jsou dva hráči: the stroj a životní prostředí. Stroj může sledovat pouze algoritmické strategie, přičemž neexistují žádná omezení chování prostředí. Každý běh (hru) vyhrává jeden z těchto hráčů a druhý je prohrává.

Logické operátory CoL se chápou jako operace na hrách. Zde neformálně zkoumáme některé z těchto operací. Pro zjednodušení předpokládáme, že doménou diskurzu je vždy množina všech přirozených čísel: {0,1,2, ...}.

Provoz ¬ z negace („ne“) přepíná role dvou hráčů, otáčí tahy a výhry ze stroje na ty, které hraje prostředí, a naopak. Například pokud Šachy je šachová hra (ale s vyloučením vazeb) z pohledu bílého hráče, pak ¬Šachy je stejná hra z pohledu černého hráče.

The paralelní spojení ∧ („pand“) a paralelní disjunkce ∨ („por“) kombinuje hry paralelně. Spuštění AB nebo AB je simultánní hra ve dvou spojkách. Stroj vyhrává AB pokud vyhraje oba. Stroj vyhrává AB pokud vyhraje alespoň jeden z nich. Například, Šachy∨¬Šachy je hra na dvou deskách, jedné se hraje bílá a jedné černé a jejím úkolem je vyhrát alespoň na jedné desce. Takovou hru lze snadno vyhrát bez ohledu na to, kdo je protivníkem, kopírováním jeho tahů z jedné desky na druhou.

The paralelní implikace operátor → ("pimplication") je definován AB = ¬AB. Intuitivní význam této operace je snižování B na A, tj. řešení A dokud to protivník vyřeší B.

The paralelní kvantifikátory („Pall“) a („pexists“) lze definovat pomocí xA(X) = A(0)∧A(1)∧A(2) ∧ ... a xA(X) = A(0)∨A(1)∨A(2) ∨ .... Jedná se tedy o simultánní hry o A(0),A(1),A(2), ..., každý na samostatné desce. Stroj vyhrává xA(X) (resp. xA(X)) pokud vyhraje všechny (resp. některé) tyto hry.

The slepé kvantifikátory ∀ („blall“) a ∃ („blexists“) naopak generují hry pro jednu desku. Náběh ∀xA(X) nebo ∃xA(X) je jediný běh A. Stroj vyhrává ∀xA(X) (resp. ∃xA(X)) pokud je takový běh vyhraný běh A(X) pro všechny (resp. alespoň jednu) možné hodnoty X.

Všichni dosud charakterizovaní operátoři se chovají přesně jako jejich klasičtí protějšky, když jsou aplikováni na základní (nepohyblivé) hry, a ověřují stejné principy. Proto CoL používá pro tyto operátory stejné symboly jako klasická logika. Pokud jsou takové operátory aplikovány na neelementární hry, jejich chování již není klasické. Například, pokud str je elementární atom a P obecný atom, strstrstr je platné, zatímco PPP není. Princip vyloučeného středu P∨¬Pvšak zůstává v platnosti. Stejný princip je neplatný u všech tří dalších druhů disjunkce (výběr, postupnost a přepínání).

The volba disjunkce ⊔ („chor“) her A a B, psaný AB, je hra, kde, aby mohl stroj vyhrát, musí zvolit jednu ze dvou disjunktů a poté vyhrát ve vybrané komponentě. The sekvenční disjunkce („sor“) AB začíná jako A; také končí jako A pokud stroj nedojde k „přepnutí“, v takovém případě A je opuštěno a hra se restartuje a pokračuje jako B. V přepínací disjunkce („tor“) AB, stroj se může přepínat A a B libovolný konečný počet opakování. Každý operátor disjunkce má svou dvojitou konjunkci získanou záměnou rolí obou hráčů. Odpovídající kvantifikátory lze dále definovat jako nekonečné spojky nebo disjunkce stejným způsobem jako v případě paralelních kvantifikátorů. Každá disjunkce druhu také indukuje odpovídající operaci implikace stejným způsobem, jako tomu bylo v případě paralelní implikace →. Například implikace volby („chimplication“) AB je definována jako ¬AB.

The paralelní opakování („předchůdce“) z A lze definovat jako nekonečnou paralelní spojku A∧A∧A∧ ... Sekvenční („srecurrence“) a přepínací („trecurrence“) druhy opakování lze definovat podobně.

The jádrový výskyt operátory lze definovat jako nekonečné disjunkce. Opakování větvení („výskyt“) , což je nejsilnější druh opakování, nemá odpovídající spojení. A je hra, která začíná a pokračuje jako A. Prostředí však může kdykoli provést „replikativní“ tah, který vytvoří dvě kopie tehdy aktuální pozice A, čímž rozdělil hru na dvě paralelní vlákna se společným minulým, ale možná odlišným budoucím vývojem. Stejným způsobem může prostředí dále replikovat libovolnou pozici libovolného vlákna, čímž vytváří více a více vláken A. Tato vlákna se hrají paralelně a stroj musí vyhrát A ve všech vláknech, aby se stal vítězem A. Větvící se jádrový výskyt („cobrecurrence“) je definován symetricky záměnou „stroje“ a „prostředí“.

Každý druh opakování dále vyvolává odpovídající slabou verzi implikace a slabou verzi negace. O prvním se říká, že je zjednodušení, a druhý a vyvrácení. The větvení rimplikace („brimplication“) AB není nic jiného než ABa vyvrácení rozvětvení ("brefutation") ze dne A je A⊥, kde ⊥ je vždy ztracená základní hra. Podobně pro všechny ostatní druhy rimplikace a vyvrácení.

Jako nástroj pro specifikaci problému

Jazyk CoL nabízí systematický způsob, jak specifikovat nekonečné množství výpočetních problémů, ať už s názvy v literatuře nebo bez nich. Níže uvádíme několik příkladů.

Nechat F být unární funkcí. Problém výpočtu F bude zapsán jako Xy (y=F(X)). Podle sémantiky CoL se jedná o hru, kde první tah („vstup“) je proveden prostředím, které by mělo zvolit hodnotu m pro X. Intuitivně to znamená požádat stroj, aby sdělil hodnotu F(m). Hra pokračuje jako y (y=F(m)). Nyní se očekává, že stroj provede tah („výstup“), kterým by měla být volba hodnoty n pro y. To znamená říkat to n je hodnota F(m). Hra je nyní přivedena k elementární n=F(m), který stroj vyhraje právě tehdy n je skutečně hodnota F(m).

Nechat str být unárním predikátem. Pak X(str(X)⊔¬str(X)) vyjadřuje problém rozhodování str, X(str(X)&¬str(X)) vyjadřuje problém semidecide str, a X(str(X)⩛¬str(X)) problém rekurzivně aproximující str.

Nechat str a q být dva unární predikáty. Pak X(str(X)⊔¬str(X))X(q(X)⊔¬q(X)) vyjadřuje problém Turing-redukující q na str (V tom smyslu, že q je Turing redukovatelný na str jen a jen v případě, že interaktivní problém X(str(X)⊔¬str(X))X(q(X)⊔¬q(X)) je vypočítatelný). X(str(X)⊔¬str(X))X(q(X)⊔¬q(X)) dělá totéž, ale pro silnější verzi Turingovy redukce, kde je Oracle pro str lze dotazovat pouze jednou. Xy(q(X)↔str(y)) dělá totéž pro problém mnoho-jedna redukce q na str. S komplexnějšími výrazy lze zachytit všechny druhy bezejmenných, ale potenciálně smysluplných vztahů a operací na výpočetních problémech, jako například „Turing - redukce problému semidecidu r k problému redukce mnoha q na str". Uložením časových nebo prostorových omezení na práci stroje získáme dále teoreticko-teoretické protějšky takových vztahů a operací."

Jako nástroj pro řešení problémů

Známé deduktivní systémy pro různé fragmenty CoL sdílejí vlastnost, že řešení (algoritmus) lze automaticky extrahovat z důkazu problému v systému. Tuto vlastnost dále dědí všechny použité teorie založené na těchto systémech. Abychom tedy našli řešení daného problému, stačí jej vyjádřit v jazyce CoL a poté najít důkaz tohoto výrazu. Dalším způsobem, jak se na tento jev dívat, je myslet na vzorec G CoL jako specifikace programu (cíl). Pak důkaz G je - přesněji řečeno - program splňující tuto specifikaci. Není nutné ověřovat, zda je specifikace splněna, protože samotný důkaz je ve skutečnosti takové ověření.

Příklady aplikovaných teorií založených na CoL jsou tzv klaritmetika. Jedná se o teorie čísel založené na CoL ve stejném smyslu, jako je Peano aritmetický PA založen na klasické logice. Takový systém je obvykle konzervativním rozšířením PA. Obvykle zahrnuje všechny Peanoovy axiomy, a přidává k nim jeden nebo dva extra Peanoovy axiomy jako např Xy(y=X') vyjadřující vypočítatelnost nástupnické funkce. Obvykle má také jedno nebo dvě nelogická pravidla odvození, například konstruktivní verze indukce nebo porozumění. Prostřednictvím rutinních variací v těchto pravidlech lze získat zdravé a úplné systémy charakterizující jednu nebo jinou interaktivní třídu výpočetní složitosti C. To je v tom smyslu, že k tomu problém patří C jen a jen v případě, že má důkaz v teorii. Takovou teorii lze tedy použít k nalezení nejen algoritmických řešení, ale také efektivních řešení na vyžádání, jako jsou řešení, která běží v polynomiálním čase nebo logaritmickém prostoru. Je třeba zdůraznit, že všechny klaritmetické teorie sdílejí stejné logické postuláty a pouze jejich nelogické postuláty se liší v závislosti na cílové třídě složitosti. Jejich pozoruhodný rozlišovací znak od jiných přístupů s podobnými aspiracemi (např omezená aritmetika ) spočívá v tom, že PA rozšiřují, nikoli oslabují, přičemž zachovávají plnou dedukční sílu a pohodlí PA.

Viz také

Reference

  1. ^ G. Japaridze, Úvod do logiky vypočítatelnosti. Annals of Pure and Applied Logic 123 (2003), strany 1–99. doi:10.1016 / S0168-0072 (03) 00023-X
  2. ^ G. Japaridze, Na začátku byla herní sémantika?. Hry: Sjednocení logiky, jazyka a filozofie. O. Majer, A.-V. Pietarinen a T. Tulenheimo, eds. Springer 2009, s. 249–350. doi:10.1007/978-1-4020-9374-6_11 Předpublikace
  3. ^ G. Japaridze, Intuicionistický fragment logiky vypočítatelnosti na výrokové úrovni. Annals of Pure and Applied Logic 147 (2007), strany 187–227. doi:10.1016 / j.apal.2007.05.001
  4. ^ G. Japaridze, Úvod do klaritmetiky I. Information and Computation 209 (2011), s. 1312–1354. doi:10.1016 / j.ic.2011.07.002 Předpublikace
  5. ^ G. Japaridze, Vytvořte si vlastní klaritmetiku I: Nastavení a úplnost. Logical Methods is Computer Science 12 (2016), Issue 3, paper 8, pp. 1-59.
  6. ^ G. Japaridze, Úvod do cirkulárního počtu a sémantiky abstraktních zdrojů. Journal of Logic and Computation 16 (2006), strany 489–532. doi:10.1093 / logcom / exl005 Předpublikace
  7. ^ G. Japaridze, Zkrocení opakování v logice vypočítatelnosti pomocí obíhajícího počtu, část I.. Archiv pro Mathematical Logic 52 (2013), str. 173–212. doi:10.1007 / s00153-012-0313-8 Předpublikace

externí odkazy