热门问题
时间线
聊天
视角
相繼式演算
来自维基百科,自由的百科全书
Remove ads
在證明論和數理邏輯中,相繼式演算(又譯矢列演算、矢列式演算、序貫演算)是一階邏輯(和作為它的特殊情況的命題邏輯)、模態邏輯等邏輯的一類證明演算。第一個相繼式演算和由格哈德·根岑(Gerhard Gentzen)在1934年/1935年引入[1],作為研究自然演繹的工具;它的名字得來自德語的「Logischer Kalkül」,意思是「邏輯演算」。相繼式演算系統有時被稱為Gentzen系統[2][3][4][5],但使用時應避免與同為Gentzen發明的證明演算自然演繹混淆。自然演繹、公理系統和相繼式演算是常見的證明演算。
相繼式演算是邏輯研究的重要工具。許多邏輯學者會為其所研究的邏輯構造出一個或多個相繼式演算,並研究其性質(如切消定理)[6][7]。
Remove ads
介紹
分類不同風格的演繹系統的一種方式是查看在系統中「判斷」的形式,就是說,什麼事物可以作為(子)證明的結論出現。最簡單的判斷形式是用在希爾伯特演繹系統中的,這裡的判斷有形式
這個是一階邏輯的任何公式(或演繹系統適用的任何邏輯,比如命題演算或高階邏輯或模態邏輯)。定理出現為有效證明中結論判斷。希爾伯特演繹系統不需要區分公式和判斷;提及它只是為了和下面的情況做比較。
希爾伯特演繹系統的簡單語法付出的代價是完整的形式證明變得非常長。在這種系統中的關於證明的具體論證總是求助於演繹定理。這導致了把演繹定理包括為系統中的形式規則的想法,這激發出了自然演繹。在自然演繹中,判斷有形式
這裡的和是公式並且。用語言表述,判斷組成自十字轉門符號「」左手端的公式(可能為空)列表與右手端的一個單一公式[8][9][10]。定理是那些公式使得(帶有空左手端)是一個有效證明的結論。(在某些自然演繹的介紹中,和十字轉門是不明顯寫出來的,轉而使用二維表示法)。
在自然演繹中判斷的標準語義是斷言只要[11] , 等都是真的,就也是真的。判斷
- 與
是在任何一個的證明都可以擴展為另一個的證明的強烈意義上等價的。
最後,「相繼式演算」推廣了自然演繹的形式為
- ,
這個語法對象叫做相繼式[12]。再次和是公式,而和是非負整數,就是說左手端或右手端都可以為空或不空。如同自然演繹,定理是那些這裡的是有效證明的結論。
相繼式的標準語義是斷言只要都是真的,「至少一個」也是真的[13]。表達這個的一種方式是在十字轉門左側的逗號要被認為是「合取」,而在十字轉門右側的逗號要被認為是(包容性的)「析取」。相繼式
- 與
是在任何一個的證明都可以擴展為另一個的證明的強烈意義上等價的。
在第一印象上,這種判斷的擴展可能帶來奇怪的複雜性—它不是由於自然演繹的有明顯缺陷而激發來的,人們最初被逗號在十字轉門的兩側完全意味著不同的事物搞糊塗了。但是觀察到相繼式的語義還可以(通過命題重言式)被表達為
在這種公式中,在十字轉門兩側的公式間的唯一不同是在左側的公式被否定了。因為對換相繼式左右側的公式對應於否定所有構成公式。這意味著對稱性,如邏輯否定的德·摩根定律在語義層次上所顯現的,直接轉換到了相繼式的左右對稱—實際上,在相繼式中處理合取()、的推理規則處理析取()的推理規則的鏡像。
很多邏輯學家覺得這種對應的對稱表述允許提供比其他證明系統在邏輯結構上的深刻洞察,這裡的否定的對偶性不出現在規則中。
Remove ads
LK系統
將要使用下列符號:
- 和指示一階謂詞邏輯的公式(你也可以把它限制為命題邏輯),
- 、、和是有限的(可能為空)公式序列,也叫做上下文,
- 指示一個任意的項,
- 指示一個公式,在其中項的某個出現是我們感興趣的
- 指示把在中的的指定出現代換為項,
- 和指示變量,
- 一個變量被稱為在一個公式中自由出現,如果它只出現於不在量詞或作用域內的公式中,
- 和表示弱化左/右,和表示緊縮左/右,而和表示排列左/右。
公理: | 切: |
|
|
左邏輯規則: | 右邏輯規則: |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
限制:在規則和中,變量一定不能在或中自由出現。
左結構規則: | 右結構規則: |
|
|
|
|
|
|
Remove ads
上面的規則可以被分成兩個主要群組:邏輯規則和結構規則。每個邏輯規則都在十字轉門的左邊或右邊介入一個新的邏輯公式。相反的,結構規則操作在相繼式的結構上,忽略公式的準確形狀。這個一般模式的兩個例外是同一性公理和規則切。
儘管是以形式方式陳述的,上述規則允許用經典邏輯的方式非常直覺的讀出來。比如,考慮規則。它陳述了如果你能證明可以從包含的公式序列推導出來,則你也能證明自更強的假定,也就是成立。類似的,規則陳述了如果和足夠推導出,則從單獨的你可以要麼仍然推導出要麼必然為假,就是說成立。所有規則都可以用這種方式來解釋。
對於量詞規則的直覺解釋,考慮規則。當然只從為真的事實推導出成立一般是不可能的。但是如果變量在其他地方沒有被提及(就是說,它仍可以被自由的選擇,而不影響其他公式),則你可以假定,對的任何值都成立。其他規則應當是非常直接的。
不再把規則看作是對在謂詞邏輯中合法的推導的描述,你還可以把它們當作為給定陳述構造一個證明的指導。在這種情況下規則可以自底向上的讀。例如,聲稱要證明推導自假定和,分別證明可以推導自和可以推導自就足夠了。注意,給頂某個前件,如何分解成和是不明確的。但是,只有有限多的可能需要檢查,因為前件被假定為是有限的。這也展示了證明論如何被看作是以組合方式在證明的操作:給定對和二者的證明,你可以構造一個對的證明。
在查找某個證明的時候,多數規則提供或多或少的如何做的處方。切規則是不同的:它聲稱,在公式可以被推導出來,並且這個公式也可以充當推導其他公式的前提的時候,則公式可以被"切掉"並把各自的推導連接起來。在自底向上構造一個證明的時候,這產生了猜測的問題(因為它在下面根本就沒有出現)。這個問題在切消定理中處理。
第二個規則有某種特殊性,它就是同一性公理。明顯的直覺讀為:證明。
Remove ads
作為一個例子,下面是叫做排中律(拉丁語tertium non datur)的的序列推導。
這個推導還強調了語法演算的嚴格形式結構。例如,上述定義的右邏輯規則總是作用於右相繼式的第一個公式,這使得的應用在形式上是需要的。這種非常嚴格的推理開始時可能難於理解,但是它形成了在形式邏輯中語法和語義之間非常核心的區別。儘管我們知道和有相同的意義,對後者的推導將不等價於上面給出的那個。但是,你可以通過介入引理而使語法推理更加方便些,就是說,預定義完成特定標準推導的方案。作為一個例子,你可以證明下列是一個合法的變換:
一旦已知一個一般的規則序列要建立這種推導,你可以使用它作為證明內的縮寫。但是,當證明使用了好的引理而變得更加易讀的時候,也使得推導的過程更加複雜,因為有更多可能的選擇要考慮。在使用證明論(經常需要)作為自動演繹的時候這特別重要。
Remove ads
結構規則需要某些額外的討論。規則的名字是弱化()、緊縮()和排列()。緊縮和排列確保序列元素的次序()和多次出現()都不重要。就是說,你可以不把它當作序列而作為集合。
但是使用序列的額外努力是正當的,因為部分或全部的結構規則可以被忽略。這麼做了就得到了所謂的亞結構邏輯。
Remove ads
這個規則系統可以被證明關於一階邏輯是可靠的和完備的,就是說,從前提的集合Γ語義上得到的一個陳述,若且唯若相繼式可以用上述規則推導出來。
在相繼式演算中,切是可接納的。這個結果也稱為Gentzen的Hauptsatz("主定理")。
變體
上述規則可以以各種方式修改:
有些修改不改變系統的本質。所有這些修改都仍可以叫做系統。
首先,如上面提及的,相繼式可以被看做由集合或多重集組成。在這種情況下,排列和(在使用集合的時候)緊縮公式的規則就可以廢棄了。
弱化規則也變成是可接納的了,在公理被變更的時候,使得形如的任何相繼式都可以被得出。這意味著在任何上下文中證明。在推導中的任何弱化因此可以在開始處正確的進行。在自底向上構造證明的時候這是個方便的變更。
獨立於這些修改,你還可以在規則內上下文被分割的方式:在、和的情況下,在向上走的時候,左上下文被以某種方式分割成和。因為緊縮允許它們的重複,你可以假定全部上下文在兩個推導分支中都使用。通過這麼做,你能確保沒有重要的前提在錯誤的分支中被丟失。使用弱化,上下文中無關的部分以後可以被消去。
所有這些改變生成等價的系統,這是在LK中的所有推導可以有效的變換因使用了替代規則的推導反之亦然的意義上。
人們可以限制或禁用某個結構規則。這產生了亞結構邏輯系統變體。它們一般要弱於(就是說有更少的定理),因為關於標準的一階邏輯語義是不完備的。但是它們的其他有趣性質導致其在理論計算機科學和人工智慧中的應用。
令人驚訝的,的規則的一些細小的變更就足以把它變成直覺邏輯的證明系統。你必須限制使用直覺相繼式(就是說,右上下文被消去)並修改規則為如下:
這裡的是任意的公式。
結果的系統叫做系統。它關於直覺邏輯是可靠的和完備的並且容許類似的切消證明。
引用
參考文獻
參見
外部連結
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads