證明論數理邏輯中,相繼式演算(又譯矢列演算、矢列式演算、序貫演算)是一階邏輯(和作為它的特殊情況的命題邏輯)、模態邏輯等邏輯的一類證明演算英語Proof_calculus。第一個相繼式演算由格哈德·根岑(Gerhard Gentzen)在1934年/1935年引入[1],作為研究自然演繹的工具;它的名字得來自德語的「Logischer Kalkül」,意思是「邏輯演算」。相繼式演算系統有時被稱為Gentzen系統[2][3][4][5],但使用時應避免與同為Gentzen發明的證明演算自然演繹混淆。自然演繹、公理系統和相繼式演算是常見的證明演算。

相繼式演算是邏輯研究的重要工具。許多邏輯學者會為其所研究的邏輯構造出一個或多個相繼式演算,並研究其性質(如切消定理[6][7]

介紹

編輯

分類不同風格的演繹系統的一種方式是查看在系統中「判斷」的形式,就是說,什麼事物可以作為(子)證明的結論出現。最簡單的判斷形式是用在希爾伯特演繹系統中的,這裡的判斷有形式

 

這個 一階邏輯的任何公式(或演繹系統適用的任何邏輯,比如命題演算高階邏輯模態邏輯)。定理出現為有效證明中結論判斷。希爾伯特演繹系統不需要區分公式和判斷;提及它只是為了和下面的情況做比較。

希爾伯特演繹系統的簡單語法付出的代價是完整的形式證明變得非常長。在這種系統中的關於證明的具體論證總是求助於演繹定理。這導致了把演繹定理包括為系統中的形式規則的想法,這激發出了自然演繹。在自然演繹中,判斷有形式

 

這裡的  是公式並且 。用語言表述,判斷組成自十字轉門符號「 」左手端的公式(可能為空)列表與右手端的一個單一公式[8][9][10]。定理是那些公式 使得 (帶有空左手端)是一個有效證明的結論。(在某些自然演繹的介紹中, 和十字轉門是不明顯寫出來的,轉而使用二維表示法)。

在自然演繹中判斷的標準語義是斷言只要[11]  ,  等都是真的, 就也是真的。判斷

  

是在任何一個的證明都可以擴展為另一個的證明的強烈意義上等價的。

最後,「相繼式演算」推廣了自然演繹的形式為

 

這個語法對象叫做相繼式[12]。再次  是公式,而  是非負整數,就是說左手端或右手端都可以為空或不空。如同自然演繹,定理是那些 這裡的 是有效證明的結論。

相繼式的標準語義是斷言只要 都是真的,「至少一個」 也是真的[13]。表達這個的一種方式是在十字轉門左側的逗號要被認為是「合取」,而在十字轉門右側的逗號要被認為是(包容性的)「析取」。相繼式

  

是在任何一個的證明都可以擴展為另一個的證明的強烈意義上等價的。

在第一印象上,這種判斷的擴展可能帶來奇怪的複雜性—它不是由於自然演繹的有明顯缺陷而激發來的,人們最初被逗號在十字轉門的兩側完全意味着不同的事物搞糊塗了。但是觀察到相繼式的語義還可以(通過命題重言式)被表達為

 

在這種公式中,在十字轉門兩側的公式間的唯一不同是在左側的公式被否定了。因為對換相繼式左右側的公式對應於否定所有構成公式。這意味着對稱性,如邏輯否定的德·摩根定律在語義層次上所顯現的,直接轉換到了相繼式的左右對稱—實際上,在相繼式中處理合取( )、的推理規則處理析取( )的推理規則的鏡像。

很多邏輯學家覺得這種對應的對稱表述允許提供比其他證明系統在邏輯結構上的深刻洞察,這裡的否定的對偶性不出現在規則中。

LK系統

編輯

在這個演算中的(形式)證明是一序列的相繼式,這個的每個相繼式使用下面的推理規則之一而推導自更早出現的相繼式。

推理規則

編輯

將要使用下列符號:

  •   指示一階謂詞邏輯的公式(你也可以把它限制為命題邏輯),
  •     是有限的(可能為空)公式序列,也叫做上下文,
  •  指示一個任意的項,
  •  指示一個公式 ,在其中項 的某個出現是我們感興趣的
  •  指示把在 中的 的指定出現代換為項 
  •   指示變量,
  • 一個變量被稱為在一個公式中自由出現,如果它只出現於不在量詞  作用域內的公式中,
  •   表示弱化左/右  表示緊縮左/右,而  表示排列左/右
公理

 

 

左邏輯規則 右邏輯規則

 

 

 

 

 

 

 

 

 

 

 

 

 

 

限制:在規則  中,變量 一定不能在  中自由出現。

左結構規則 右結構規則

 

 

 

 

 

 

直覺解釋

編輯

上面的規則可以被分成兩個主要群組:邏輯規則結構規則。每個邏輯規則都在十字轉門 的左邊或右邊介入一個新的邏輯公式。相反的,結構規則操作在相繼式的結構上,忽略公式的準確形狀。這個一般模式的兩個例外是同一性公理 和規則切 

儘管是以形式方式陳述的,上述規則允許用經典邏輯的方式非常直覺的讀出來。比如,考慮規則 。它陳述了如果你能證明 可以從包含 的公式序列推導出來,則你也能證明 自更強的假定,也就是 成立。類似的,規則 陳述了如果  足夠推導出 ,則從單獨的 你可以要麼仍然推導出 要麼 必然為假,就是說 成立。所有規則都可以用這種方式來解釋。

對於量詞規則的直覺解釋,考慮規則 。當然只從 為真的事實推導出 成立一般是不可能的。但是如果變量 在其他地方沒有被提及(就是說,它仍可以被自由的選擇,而不影響其他公式),則你可以假定,  的任何值都成立。其他規則應當是非常直接的。

不再把規則看作是對在謂詞邏輯中合法的推導的描述,你還可以把它們當作為給定陳述構造一個證明的指導。在這種情況下規則可以自底向上的讀。例如, 聲稱要證明 推導自假定  ,分別證明 可以推導自  可以推導自 就足夠了。注意,給頂某個前件,如何分解成  是不明確的。但是,只有有限多的可能需要檢查,因為前件被假定為是有限的。這也展示了證明論如何被看作是以組合方式在證明的操作:給定對  二者的證明,你可以構造一個對 的證明。

在查找某個證明的時候,多數規則提供或多或少的如何做的處方。切規則是不同的:它聲稱,在公式 可以被推導出來,並且這個公式也可以充當推導其他公式的前提的時候,則公式 可以被"切掉"並把各自的推導連接起來。在自底向上構造一個證明的時候,這產生了猜測 的問題(因為它在下面根本就沒有出現)。這個問題在切消定理中處理。

第二個規則有某種特殊性,它就是同一性公理 。明顯的直覺讀為: 證明 

例子推導

編輯

作為一個例子,下面是叫做排中律(拉丁語tertium non datur)的 的序列推導。

 

這個推導還強調了語法演算的嚴格形式結構。例如,上述定義的右邏輯規則總是作用於右相繼式的第一個公式,這使得 的應用在形式上是需要的。這種非常嚴格的推理開始時可能難於理解,但是它形成了在形式邏輯中語法語義之間非常核心的區別。儘管我們知道  有相同的意義,對後者的推導將不等價於上面給出的那個。但是,你可以通過介入引理而使語法推理更加方便些,就是說,預定義完成特定標準推導的方案。作為一個例子,你可以證明下列是一個合法的變換:

 

一旦已知一個一般的規則序列要建立這種推導,你可以使用它作為證明內的縮寫。但是,當證明使用了好的引理而變得更加易讀的時候,也使得推導的過程更加複雜,因為有更多可能的選擇要考慮。在使用證明論(經常需要)作為自動演繹的時候這特別重要。

結構規則

編輯

結構規則需要某些額外的討論。規則的名字是弱化 )、緊縮 )和排列 )。緊縮和排列確保序列元素的次序( )和多次出現( )都不重要。就是說,你可以不把它當作序列而作為集合

但是使用序列的額外努力是正當的,因為部分或全部的結構規則可以被忽略。這麼做了就得到了所謂的亞結構邏輯

LK系統的性質

編輯

這個規則系統可以被證明關於一階邏輯可靠的和完備的,就是說,從前提的集合Γ語義上得到的一個陳述 當且僅當相繼式 可以用上述規則推導出來。

在相繼式演算中,切是可接納的。這個結果也稱為Gentzen的Hauptsatz("主定理")。

變體

編輯

上述規則可以以各種方式修改:

次要結構變更

編輯

有些修改不改變 系統的本質。所有這些修改都仍可以叫做 系統。

首先,如上面提及的,相繼式可以被看做由集合或多重集組成。在這種情況下,排列和(在使用集合的時候)緊縮公式的規則就可以廢棄了。

弱化規則也變成是可接納的了,在公理 被變更的時候,使得形如 的任何相繼式都可以被得出。這意味着在任何上下文中 證明 。在推導中的任何弱化因此可以在開始處正確的進行。在自底向上構造證明的時候這是個方便的變更。

獨立於這些修改,你還可以在規則內上下文被分割的方式:在   的情況下,在向上走的時候,左上下文被以某種方式分割成  。因為緊縮允許它們的重複,你可以假定全部上下文在兩個推導分支中都使用。通過這麼做,你能確保沒有重要的前提在錯誤的分支中被丟失。使用弱化,上下文中無關的部分以後可以被消去。

所有這些改變生成等價的系統,這是在LK中的所有推導可以有效的變換因使用了替代規則的推導反之亦然的意義上。

亞結構邏輯

編輯

人們可以限制或禁用某個結構規則。這產生了亞結構邏輯系統變體。它們一般要弱於 (就是說有更少的定理),因為關於標準的一階邏輯語義是不完備的。但是它們的其他有趣性質導致其在理論計算機科學人工智能中的應用。

LJ系統

編輯

令人驚訝的, 的規則的一些細小的變更就足以把它變成直覺邏輯的證明系統。你必須限制使用直覺相繼式(就是說,右上下文被消去)並修改規則 為如下:

 

這裡的 是任意的公式。

結果的系統叫做 系統。它關於直覺邏輯是可靠的和完備的並且容許類似的切消證明。

引用

編輯
  1. ^ Gentzen 1934, Gentzen 1935.
  2. ^ Curry 1977,第189–244頁, calls Gentzen systems LC systems. Curry's emphasis is more on theory than on practical logic proofs.
  3. ^ Kleene 2009,第440–516頁. This book is much more concerned with the theoretical, metamathematical implications of Gentzen-style sequent calculus than applications to practical logic proofs.
  4. ^ Kleene 2002,第283–312, 331–361頁, defines Gentzen systems and proves various theorems within these systems, including Gödel's completeness theorem and Gentzen's theorem.
  5. ^ Smullyan 1995,第101–127頁
  6. ^ Curry 1977,第208–213頁, gives a 5-page proof of the elimination theorem. See also pages 188, 250.
  7. ^ Kleene 2009,第453頁, gives a very brief proof of the cut-elimination theorem.
  8. ^ Curry 1977,第184–244頁, compares natural deduction systems, denoted LA, and Gentzen systems, denoted LC. Curry's emphasis is more theoretical than practical.
  9. ^ Suppes 1999,第25–150頁, is an introductory presentation of practical natural deduction of this kind. This became the basis of System L.
  10. ^ Lemmon 1965 is an elementary introduction to practical natural deduction based on the convenient abbreviated proof layout style System L based on Suppes 1999,第25–150頁.
  11. ^ 這裡的「只要」是如下的非正式略寫「對值到判斷中的自由變量的所有指派」。
  12. ^ Shankar, Natarajan; Owre, Sam; Rushby, John M.; Stringer-Calvert, David W. J. PVS Prover Guide (PDF). User guide. SRI International. 2001-11-01 [2015-05-29]. (原始內容 (PDF)存檔於2022-03-27). 
  13. ^ For explanations of the disjunctive semantics for the right side of sequents, see Curry 1977,第189–190頁, Kleene 2002,第290, 297頁, Kleene 2009,第441頁, Hilbert & Bernays 1970,第385頁, Smullyan 1995,第104–105頁 and Gentzen 1934,第180頁.

參考文獻

編輯

參見

編輯

外部連結

編輯