जनरल रिकर्सिव फंक्शन

From Vigyanwiki

गणितीय तर्क और कंप्यूटर विज्ञान में, सामान्य पुनरावर्ती फ़ंक्शन, आंशिक पुनरावर्ती फ़ंक्शन, या μ-पुनरावर्ती फ़ंक्शन प्राकृतिक संख्याओं से प्राकृतिक संख्याओं तक आंशिक फ़ंक्शन है जो सहज ज्ञान युक्त अर्थ में गणना योग्य है - साथ ही गणना योग्य फ़ंक्शन में भी। यदि फ़ंक्शन कुल है, तो इसे कुल पुनरावर्ती फ़ंक्शन भी कहा जाता है (कभी-कभी पुनरावर्ती फ़ंक्शन के लिए छोटा किया जाता है)।[1] कम्प्यूटेबिलिटी सिद्धांत (गणना) में, यह दिखाया गया है कि μ-पुनरावर्ती फ़ंक्शन सटीक रूप से वे फ़ंक्शन हैं जिनकी गणना ट्यूरिंग मशीनों द्वारा की जा सकती है[2][4] (यह उन प्रमेयों में से है जो चर्च-ट्यूरिंग थीसिस का समर्थन करता है)। μ-पुनरावर्ती फ़ंक्शन आदिम पुनरावर्ती कार्यों से निकटता से संबंधित हैं, और उनकी आगमनात्मक परिभाषा (नीचे) आदिम पुनरावर्ती कार्यों पर आधारित है। हालाँकि, प्रत्येक कुल पुनरावर्ती फ़ंक्शन आदिम पुनरावर्ती फ़ंक्शन नहीं है - सबसे प्रसिद्ध उदाहरण एकरमैन फ़ंक्शन है।

फ़ंक्शंस के अन्य समकक्ष वर्ग लैम्ब्डा कैलकुलस के फ़ंक्शंस और फ़ंक्शंस हैं जिनकी गणना मार्कोव एल्गोरिथ्म द्वारा की जा सकती है।

मानों के साथ सभी कुल पुनरावर्ती कार्यों का उपसमूह {0,1} को कम्प्यूटेशनल जटिलता सिद्धांत में आर (जटिलता) के रूप में जाना जाता है।

परिभाषा

μ-पुनरावर्ती कार्य (या सामान्य पुनरावर्ती कार्य) आंशिक कार्य हैं जो प्राकृतिक संख्याओं के सीमित टुपल्स लेते हैं और एकल प्राकृतिक संख्या लौटाते हैं। वे आंशिक फ़ंक्शंस का सबसे छोटा वर्ग हैं जिसमें प्रारंभिक फ़ंक्शंस शामिल हैं और संरचना, आदिम रिकर्सन और μ ऑपरेटर | न्यूनतमकरण ऑपरेटर के तहत बंद है μ.

प्रारंभिक कार्यों सहित कार्यों का सबसे छोटा वर्ग और संरचना और आदिम पुनरावर्तन के तहत बंद (अर्थात न्यूनतमकरण के बिना) आदिम पुनरावर्ती कार्यों का वर्ग है। जबकि सभी आदिम पुनरावर्ती कार्य कुल हैं, यह आंशिक पुनरावर्ती कार्यों के लिए सच नहीं है; उदाहरण के लिए, उत्तराधिकारी फ़ंक्शन का न्यूनतमकरण अपरिभाषित है। आदिम पुनरावर्ती कार्य कुल पुनरावर्ती कार्यों का उपसमूह हैं, जो आंशिक पुनरावर्ती कार्यों का उपसमूह हैं। उदाहरण के लिए, एकरमैन फ़ंक्शन को पूर्ण पुनरावर्ती और गैर-आदिम साबित किया जा सकता है।

आदिम या बुनियादी कार्य:

  1. निरंतर कार्य Ck
    n
    : प्रत्येक प्राकृतिक संख्या के लिए n और हर k
    वैकल्पिक परिभाषाएँ शून्य फ़ंक्शन का उपयोग आदिम फ़ंक्शन के रूप में करती हैं जो हमेशा शून्य लौटाता है, और शून्य फ़ंक्शन, उत्तराधिकारी फ़ंक्शन और कंपोज़िशन ऑपरेटर से निरंतर फ़ंक्शन का निर्माण करता है।
  2. उत्तराधिकारी फ़ंक्शन एस:
  3. प्रक्षेपण समारोह (पहचान फ़ंक्शन भी कहा जाता है): सभी प्राकृतिक संख्याओं के लिए ऐसा है कि :

ऑपरेटर्स (ऑपरेटर द्वारा परिभाषित फ़ंक्शन का डोमेन तर्कों के मानों का सेट है, जैसे कि गणना के दौरान किया जाने वाला प्रत्येक फ़ंक्शन एप्लिकेशन अच्छी तरह से परिभाषित परिणाम प्रदान करता है):

  1. रचना संचालक (प्रतिस्थापन ऑपरेटर भी कहा जाता है): एम-एरी फ़ंक्शन दिया गया है और एम के-एरी फ़ंक्शन :
    इस का मतलब है कि केवल तभी परिभाषित किया गया है और सभी परिभाषित हैं.
  2. आदिम रिकर्सन ऑपरेटर ρ: k-ary फ़ंक्शन को देखते हुए और k+2-एरी फ़ंक्शन :
    इस का मतलब है कि केवल तभी परिभाषित किया गया है और सभी के लिए परिभाषित हैं
  3. न्यूनीकरण ऑपरेटर μ: (k+1)-एरी फ़ंक्शन दिया गया है , के-एरी फ़ंक्शन द्वारा परिभाषित किया गया है:

सहज रूप से, न्यूनतमकरण खोजता है - 0 से खोज शुरू करना और ऊपर की ओर बढ़ना - सबसे छोटा तर्क जो फ़ंक्शन को शून्य पर लौटने का कारण बनता है; यदि ऐसा कोई तर्क नहीं है, या यदि कोई किसी तर्क का सामना करता है जिसके लिए f परिभाषित नहीं है, तो खोज कभी समाप्त नहीं होती, और तर्क के लिए परिभाषित नहीं है जबकि कुछ पाठ्यपुस्तकें μ-ऑपरेटर का उपयोग करती हैं जैसा कि यहां परिभाषित है,[5][6] दूसरों को पसंद है[7][8] मांग करें कि μ-ऑपरेटर को कुल कार्यों पर लागू किया जाए f केवल। यद्यपि यह यहां दी गई परिभाषा की तुलना में μ-ऑपरेटर को प्रतिबंधित करता है, μ-पुनरावर्ती कार्यों का वर्ग वही रहता है, जो क्लेन के सामान्य फॉर्म प्रमेय (# सामान्य फॉर्म प्रमेय देखें) से अनुसरण करता है।[5][6]एकमात्र अंतर यह है कि यह अनिर्णीत हो जाता है कि क्या विशिष्ट फ़ंक्शन परिभाषा μ-पुनरावर्ती फ़ंक्शन को परिभाषित करती है, क्योंकि यह अनिर्णीत है कि क्या गणना योग्य (यानी μ-पुनरावर्ती) फ़ंक्शन कुल है।[7]

मजबूत समानता ऑपरेटर आंशिक μ-पुनरावर्ती कार्यों की तुलना करने के लिए उपयोग किया जा सकता है। इसे सभी आंशिक फलनों f और g के लिए परिभाषित किया गया है

यदि और केवल तभी मान्य है जब तर्कों के किसी भी विकल्प के लिए या तो दोनों फ़ंक्शन परिभाषित हैं और उनके मान समान हैं या दोनों फ़ंक्शन अपरिभाषित हैं।

उदाहरण

मिनिमाइज़ेशन ऑपरेटर को शामिल न करने वाले उदाहरण आदिम पुनरावर्ती फ़ंक्शन#उदाहरण पर पाए जा सकते हैं।

निम्नलिखित उदाहरणों का उद्देश्य केवल न्यूनतमकरण ऑपरेटर के उपयोग को प्रदर्शित करना है; उन्हें इसके बिना भी परिभाषित किया जा सकता है, यद्यपि अधिक जटिल तरीके से, क्योंकि वे सभी आदिम पुनरावर्ती हैं।

  • The integer square root of x can be defined as the least z such that . Using the minimization operator, a general recursive definition is , where Not, Gt, and Mul are logical negation, greater-than, and multiplication,[9] respectively. In fact, is 0 if, and only if, holds. Hence is the least z such that holds. The negation junctor Not is needed since Gt encodes truth by 1, while μ seeks for 0.

निम्नलिखित उदाहरण सामान्य पुनरावर्ती कार्यों को परिभाषित करते हैं जो आदिम पुनरावर्ती नहीं हैं; इसलिए वे न्यूनतमकरण ऑपरेटर का उपयोग करने से बच नहीं सकते।

कुल पुनरावर्ती फ़ंक्शन

एक सामान्य पुनरावर्ती फ़ंक्शन को कुल पुनरावर्ती फ़ंक्शन कहा जाता है यदि इसे प्रत्येक इनपुट के लिए परिभाषित किया गया है, या, समकक्ष, यदि इसकी गणना कुल ट्यूरिंग मशीन द्वारा की जा सकती है। गणनात्मक रूप से यह बताने का कोई तरीका नहीं है कि दिया गया सामान्य पुनरावर्ती कार्य पूर्ण है या नहीं - हॉल्टिंग समस्या देखें।

संगणना के अन्य मॉडलों के साथ समतुल्यता

चर्च की थीसिस में, ट्यूरिंग मशीनों के बीच समानांतर रेखा खींची जाती है जो कुछ इनपुट के लिए समाप्त नहीं होती है और संबंधित आंशिक पुनरावर्ती फ़ंक्शन में उस इनपुट के लिए अपरिभाषित परिणाम होता है। अनबाउंड सर्च ऑपरेटर आदिम रिकर्सन के नियमों द्वारा परिभाषित नहीं है क्योंकि वे अनंत लूप (अपरिभाषित मान) के लिए तंत्र प्रदान नहीं करते हैं।

सामान्य रूप प्रमेय

क्लेन का टी विधेय#क्लीन के कारण सामान्य रूप प्रमेय कहता है कि प्रत्येक k के लिए आदिम पुनरावर्ती कार्य हैं और ऐसा कि किसी भी μ-पुनरावर्ती फ़ंक्शन के लिए k मुक्त चर के साथ e ऐसा है

.

फ़ंक्शन f के लिए संख्या e को इंडेक्स या गोडेल नंबर कहा जाता है।[10]: 52–53  इस परिणाम का परिणाम यह है कि किसी भी μ-पुनरावर्ती फ़ंक्शन को (कुल) आदिम पुनरावर्ती फ़ंक्शन पर लागू μ ऑपरेटर के एकल उदाहरण का उपयोग करके परिभाषित किया जा सकता है।

मार्विन मिंस्की इसका निरीक्षण करते हैं ऊपर परिभाषित संक्षेप में सार्वभौमिक ट्यूरिंग मशीन के μ-पुनरावर्ती समकक्ष है:

To construct U is to write down the definition of a general-recursive function U(n, x) that correctly interprets the number n and computes the appropriate function of x. to construct U directly would involve essentially the same amount of effort, and essentially the same ideas, as we have invested in constructing the universal Turing machine [11]

प्रतीकवाद

साहित्य में अनेक प्रकार के प्रतीकों का प्रयोग किया जाता है। प्रतीकवाद का उपयोग करने का फायदा यह है कि ऑपरेटरों को के अंदर करके फ़ंक्शन की व्युत्पत्ति की जाती है, जिसे कॉम्पैक्ट रूप में लिखना आसान होता है। निम्नलिखित में पैरामीटर्स की स्ट्रिंग x1, ..., एक्सn इसे x के रूप में संक्षिप्त किया गया है:

  • निरंतर कार्य: क्लेन सी का उपयोग करता हैn
    q
    (x) = q और बूलोस-बर्गेस-जेफरी (2002) (बी-बी-जे) संक्षिप्त नाम const का उपयोग करते हैंn( एक्स) = एन :
उदा. सी7
13
(आर, एस, टी, यू, वी, डब्ल्यू, एक्स) = 13
उदा. कॉन्स्ट13 (आर, एस, टी, यू, वी, डब्ल्यू, एक्स) = 13
  • उत्तराधिकारी फ़ंक्शन: क्लेन उत्तराधिकारी के लिए x' और S का उपयोग करता है। चूंकि उत्तराधिकारी को आदिम माना जाता है, अधिकांश ग्रंथ एपॉस्ट्रॉफ़ी का उपयोग इस प्रकार करते हैं:
एस(ए) = ए +1 =def ए', जहां 1 =def 0', 2 =def 0 , आदि।
  • पहचान फ़ंक्शन: क्लेन (1952) यू का उपयोग करता हैn
    i
    वेरिएबल x पर पहचान फ़ंक्शन को इंगित करने के लिएi; बी-बी-जे पहचान फ़ंक्शन आईडी का उपयोग करेंn
    i
    चर x पर1 एक्स कोn:
यूn
i
( एक्स ) = आईडीn
i
( एक्स ) = एक्सi : जैसे यू7
3
= आईडी7
3
(आर, एस, टी, यू, वी, डब्ल्यू, एक्स) = टी
  • रचना (प्रतिस्थापन) ऑपरेटर: क्लेन बोल्ड-फेस 'एस' का उपयोग करता हैm
    n
    (उसके उत्तराधिकारी के साथ भ्रमित न हों!)। सुपरस्क्रिप्ट m, m को संदर्भित करता हैफ़ंक्शन f का वेंm, जबकि सबस्क्रिप्ट n, n को संदर्भित करता हैवेंवेरिएबल xn:
यदि हमें h(x)=g(f) दिया गया है1(एक्स), ..., एफm(एक्स) )
एच(एक्स) = एसn
m
(जी, एफ1, ... , एफm )
इसी तरह, लेकिन उप- और सुपरस्क्रिप्ट के बिना, बी-बी-जे लिखते हैं:
h(x')= Cn[g, f1 ,..., एफm](एक्स)
  • आदिम पुनरावर्तन: क्लेन प्रतीक आर का उपयोग करता हैn(बेस स्टेप, इंडक्शन स्टेप) जहां n वेरिएबल्स की संख्या को इंगित करता है, बी-बी-जे Pr(बेस स्टेप, इंडक्शन स्टेप)(x) का उपयोग करते हैं। दिया गया:
  • आधार चरण: h( 0, x )= f( x ), और
  • प्रेरण चरण: h( y+1, x ) = g( y, h(y, x),x )
उदाहरण: ए + बी की आदिम रिकर्सन परिभाषा:
  • आधार चरण: f( 0, a ) = a = U1
    1
    (ए)
  • प्रेरण चरण: f( b' , a ) = ( f ( b, a ) )' = g( b, f( b, a), a ) = g( b, c, a ) = c' = S(U3
    2
    (बी, सी, ए))
आर2{ यू1
1
(a), S [ (U3
2
( b, c, a ) ] }
पर{ ु1
1
(ए), एस[(यू3
2
(बी, सी, ए) ] }

उदाहरण: क्लेन उदाहरण देता है कि f(b, a) = b + a की पुनरावर्ती व्युत्पत्ति कैसे करें (वेरिएबल a और b का उलटा नोटिस)। वह 3 प्रारंभिक कार्यों से प्रारंभ करता है

  1. एस(ए) = ए'
  2. यू1
    1
    (ए) = ए
  3. यू3
    2
    (बी, सी, ए) = सी
  4. जी(बी, सी, ए) = एस(यू3
    2
    (बी, सी, ए)) = सी'
  5. आधार चरण: h( 0, a ) = U1
    1
    (ए)
प्रेरण चरण: एच(बी', ए) = जी(बी, एच(बी, ए), ए)

वह यहां पहुंचता है:

ए+बी = आर2[यू1
1
, एस3
1
(एस, यू3
2
) ]

उदाहरण

यह भी देखें

संदर्भ

  1. "Recursive Functions". द स्टैनफोर्ड इनसाइक्लोपीडिया ऑफ फिलॉसफी. Metaphysics Research Lab, Stanford University. 2021.
  2. Stanford Encyclopedia of Philosophy, Entry Recursive Functions, Sect.1.7: "[The class of μ-recursive functions] turns out to coincide with the class of the Turing-computable functions introduced by Alan Turing as well as with the class of the λ-definable functions introduced by Alonzo Church."
  3. Kleene, Stephen C. (1936). "λ-definability and recursiveness". Duke Mathematical Journal. 2 (2): 340–352. doi:10.1215/s0012-7094-36-00227-2.
  4. Turing, Alan Mathison (Dec 1937). "Computability and λ-Definability". Journal of Symbolic Logic. 2 (4): 153–163. doi:10.2307/2268280. JSTOR 2268280. S2CID 2317046. Proof outline on p.153: [3]
  5. 5.0 5.1 Enderton, H. B., A Mathematical Introduction to Logic, Academic Press, 1972
  6. 6.0 6.1 Boolos, G. S., Burgess, J. P., Jeffrey, R. C., Computability and Logic, Cambridge University Press, 2007
  7. 7.0 7.1 Jones, N. D., Computability and Complexity: From a Programming Perspective, The MIT Press, Cambridge, Massachusetts, London, England, 1997
  8. Kfoury, A. J., R. N. Moll, and M. A. Arbib, A Programming Approach to Computability, 2nd ed., Springer-Verlag, Berlin, Heidelberg, New York, 1982
  9. defined in Primitive recursive function#Junctors, Primitive recursive function#Equality predicate, and Primitive recursive function#Multiplication
  10. Stephen Cole Kleene (Jan 1943). "पुनरावर्ती विधेय और परिमाणक" (PDF). Transactions of the American Mathematical Society. 53 (1): 41–73. doi:10.1090/S0002-9947-1943-0007371-8.
  11. Minsky 1972, pp. 189.
On pages 210-215 Minsky shows how to create the μ-operator using the register machine model, thus demonstrating its equivalence to the general recursive functions.

बाहरी संबंध