跳至內容

原始遞迴函數

本頁使用了標題或全文手工轉換
維基百科,自由的百科全書

可計算性理論中,原始遞迴函數(英語:primitive recursive functions)對計算的完全的形式化而言是形成重要構造板塊的一類函數。它們使用遞迴複合作為中心運算來定義,並且是遞迴函數的嚴格的子集,它們完全是可計算函數。通過補充允許偏函數和介入無界尋找運算可以定義出遞迴函數的更廣泛的類。

通常在數論中研究的很多函數,近似於實數值函數,比如加法除法階乘指數,找到第 n 個質數等等是原始遞迴的(Brainerd and Landweber, 1974)。實際上,很難設計不是原始遞迴的函數,儘管某些函數是已知的(比如阿克曼函數)。所以,通過研究它們,我們能發現有廣泛影響的結論的那些性質。

原始遞迴函數可以用總是停機的圖靈機計算,而遞迴函數需要圖靈完全系統。

原始遞迴函數的集合在計算複雜性理論中叫做PR

定義

[編輯]

原始遞迴函數接受自然數或自然數的元組作為參數並生成自然數。接受 n 個參數的函數叫做 n-函數。基本原始遞迴函數用如下公理給出:

  1. 常數函數: 0 元常數函數 0 是原始遞迴的。
  2. 後繼函數: 1 元後繼函數 S,它接受一個參數並返回皮亞諾公理給出的後繼數,是原始遞迴的。
  3. 投影函數: 對於所有 n≥1 和每個 1≤inin 元投影函數 Pin,它接受 n 個參數並返回它們中的第 i 個參數,是原始遞迴的。

更加複雜的遞迴函數可以通過應用下列公理給出的運算來獲得:

  1. 複合: 給定k 元原始遞迴函數 f,和 km 元原始遞迴函數 g1,...,gkfg1,...,gk複合,也就是 m 元函數 h(x1,...,xm) = f(g1(x1,...,xm),...,gk(x1,...,xm)), 是原始遞迴的。
  2. 原始遞迴: 給定 k 元原始遞迴函數 f,和 k+2 元原始遞迴函數 g,定義為 fg 的原始遞迴的 k+1 元函數,也就是函數 h 這裡的 h(0,x1,...,xk) = f(x1,...,xk) 並且 h(S(n),x1,...,xk) = g(h(n,x1,...,xk),n,x1,...,xk), 是原始遞迴的。

服從這些公理的函數是原始遞迴的,如果它是上述基本函數之一,或者它可以通過應用有限次數的運算獲得自基本函數。

投影函數的作用

[編輯]

投影函數可用來避免採用上述明顯刻板的函數元數方式;通過使用各種投影函數的複合,有可能把一個函數的參數子集遞移到另一個函數。例如,如果 gh 是二元原始遞迴函數,則

也是原始遞迴的。使用投影函數的一個形式定義為

.

轉換謂詞到數值函數

[編輯]

在某些設定中,自然的考慮接受混合了數值和真值{ t= true, f=false } 的參數,或生成真值作為輸出的原始遞迴函數(參見 Kleene [1952 pp.226-227])。這可以通過把真值辨識為任何固定方式的數值來完成。例如,通常把真值t 辨識為 1 和真值 f 辨識為 0。一旦作出這種辨識,集合 A特徵函數,它在文字上返回 10,可以被看作判定一個數是否在集合 A 中的謂詞。把謂詞辨識為數值函數的這種方式將假定於本文餘下部分。

例子

[編輯]

直覺上我們會把加法遞迴的定義為:

add(0,x)=x
add(n+1,x)=add(n,x)+1

為了使它適合於嚴格的原始遞迴定義,我們定義:

add(0,x)=P11(x)
add(S(n),x)=S(P13(add(n,x),n,x))

(注意: 這裡的 P13 是一個函數,它接受 3 個參數並返回第一個。)

P11 是簡單的恆等函數;包含它是上述原始遞迴運算定義的要求;它扮演了 f 的角色。SP13 的複合,它是原始遞迴的,它扮演了 g 的角色。

我們可以定義有限減法,就是說,截止到 0 的減法(因為我們還沒有負數的概念呢)。首先我們必須定義"前驅" 函數,它擔任後繼函數的對立物。

直覺上我們會把前驅定義為:

pred(0)=0
pred(n+1)=n

為了使它適合正式的原始遞迴定義,我們寫:

pred(0)=0
pred(S(n))=P22(pred(n),n)

現在我們以類似加法的方式定義減法。

sub(0,x)=P11(x)
sub(S(n),x)=pred(P13(sub(n,x),n,x))

出於簡單的緣故,切換了"標準"定義的參數次序來適合原始遞迴的要求,就是說, sub(a,b) 對應於 b-a。這可以輕易的使用適當的投影來矯正。

很多類似的函數可以被證明是原始遞迴的;一些例子包括條件指數質數檢定數學歸納法,並且原始遞迴函數可以被擴充來運算在其他物件上比如整數和有理數。

在整數和有理數上的運算

[編輯]

通過使用哥德爾數,原始遞迴函數可以被擴充到在其他物件比如整數和有理數上的運算上。如果以標準方式編碼整數用哥德爾數,算術運算包括加法、減法、乘法都是原始遞迴的。類似的,如果以哥德爾數表示有理數,則運算都是原始遞迴的。

與遞迴函數的聯系

[編輯]

通過介入無界尋找算子可定義更廣泛的偏遞迴函數類。這個算子的使用可以導致偏函數,就是說,對每個參數有最多一個值,但是不同於全函數,不必須對參數有值的關係(參見定義域)。一個等價的定義聲稱偏遞迴函數是可以被圖靈機就算的函數。全遞迴函數是對所有輸入有定義的偏遞迴函數。

所有原始遞迴函數都是全遞迴的,但不是所有全遞迴函數都是原始遞迴的。阿克曼函數 A(m,n)是周知的不是原始遞迴的全遞迴函數。原始遞迴函數有作為使用阿克曼函數的全遞迴函數的子集的一個特徵。這個特徵聲稱一個函數是原始遞迴的,若且唯若有一個自然數 m 使得這個函數可以被總在 A(m,n) 或更少步驟內停機的圖靈機計算,這裡的 n 是原始遞迴函數的參數的總數。

限制

[編輯]

原始遞迴函數意圖緊密對應於我們直覺上可計算函數應該的樣子。當然函數的初始集合在直覺上是可計算的(因為它們非常簡單),而你能用來建立新原始遞迴函數的兩個運算也是非常直接的。但是原始遞迴函數的集合不包含所有可能的可計算函數 — 這可以看作康托爾對角論證法的變體。這個論證提供了一個不是原始遞迴的可計算函數。證明的梗概如下:

原始遞迴函數集合可以被計算列舉。這個編號方案在函數定義上是唯一的,儘管在實際函數自身上不是唯一的(因為所有的函數都可以有無限數目的定義 — 考慮簡單的由恆等函數構成)。這個編碼在可計算性的形式模型,比如遞迴函數圖靈機下定義的意義上是可計算的,邱奇-圖靈論題涉及的任何機器都可以。

現在考慮一個矩陣,這裡的行是在這個編號方案下的有一個參數的原始遞迴函數,而列是自然數。則每個元素 (i, j) 對應於計算於數 j 之上的第 i 個一元原始遞迴函數。我們可以寫為 fi(j)。

現在我們考慮函數 g(x) = S(fx(x))。g 位於這個矩陣的對角線上,並簡單的對它找到的值加一。這個函數是可計算的(按上述定義),但是明顯的沒有計算它的原始遞迴函數存在,因為它與每個可能的原始遞迴函數都有至少一個值不同。所以,必然存在不是原始遞迴的可計算函數。

這個論證可以應用於能用這種方式列舉的任何一類的可計算(全)函數上。所以,任何這種可計算(全)函數的明確列表都不可能是完全的,比如那些可以用判定器計算的函數。但是要注意,可計算函數集合(那些不需要對所有參數有定義的函數)可以被明確的列舉,例如通過列舉圖靈機編碼。

可以明確展示的一個簡單的 1-元可計算函數阿克曼函數,它是對任何自然數遞迴定義的,但不是原始遞迴的。

歷史

[編輯]

遞迴定義以前在數學中或多或少地被正式使用過,但原始遞迴的構造可以追溯到理察·戴德金的 "Was sind und was sollen die Zahlen? (1888). 這項工作是第一個給出某個遞迴結構定義了一個唯一函數的證明。 [1][2][3]

原始遞迴算術是由Thoralf Skolem首次提出的[4] 1923年。

目前的術語是由Rózsa Péter(1934年)在Wilkinson之後創造的。(1934)在阿克曼於1928年證明了今天以他名字命名的函數不是原始遞迴函數之後,這一事件促使人們需要重新命名在那之前被簡單稱為遞迴函數的東西。

參見

[編輯]

注釋

[編輯]
  1. ^ Peter Smith. 哥德尔定理简介 2nd. 劍橋大學出版社. 2013: 98–99. ISBN 978-1-107-02284-3. 
  2. ^ George Tourlakis. Lectures in Logic and Set Theory: Volume 1, Mathematical Logic. Cambridge University Press. 2003: 129. ISBN 978-1-139-43942-8. 
  3. ^ Rod Downey (編). 图灵的遗产。来自图灵逻辑思想的发展. 劍橋大學出版社. 2014: 474. ISBN 978-1-107-04348-0. 
  4. ^ Thoralf Skolem 。(1923) "The foundations of elementary arithmetic" in Jean van Heijenoort, translator and ed. (1967) From Frege to Gödel: A Source Book in Mathematical Logic, 1879-1931。Harvard Univ. Press: 302-33.

參考文獻

[編輯]
  • Brainerd, W.S., Landweber, L.H. (1974), Theory of Computation, Wiley, ISBN 0-471-09585-0.
  • Robert I. Soare, Recursively Enumerable Sets and Degrees , Springer-Verlag, 1987. ISBN 0-387-15299-7
  • Stephen Kleene (1952) Introduction to Metamathematics, North-Holland Publishing Company, New York, 11th reprint 1971: (2nd edition notes added on 6th reprint). In Chapter XI. General Recursive Functions §57
  • George Boolos, John Burgess, Richard Jeffrey (2002), Computability and Logic: Fourth Edition, Cambridge University Press, Cambridge, UK. Cf pp. 70-71.
  • Robert I. Soare 1995 Computability and Recursion http://www.people.cs.uchicago.edu/~soare/History/compute.pdf頁面存檔備份,存於網際網路檔案館
  • Daniel Severin 2008, Unary primitive recursive functions, J. Symbolic Logic Volume 73, Issue 4, pp.  1122-1138 arXiv頁面存檔備份,存於網際網路檔案館projecteuclid頁面存檔備份,存於網際網路檔案館

Template:數學邏輯