रैंडम-एक्सेस मशीन: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
Line 1: Line 1:
{{Distinguish|Random-access memory|text=[[Random-access memory]]}}[[कंप्यूटर विज्ञान]] में, रैंडम-एक्सेस मशीन (रैम) [[रजिस्टर मशीन]]ों के सामान्य वर्ग में  [[अमूर्त मशीन]] है। रैम [[काउंटर मशीन]] के समान ही है लेकिन इसके रजिस्टरों के 'अप्रत्यक्ष पता' की अतिरिक्त क्षमता के साथ। काउंटर मशीन की तरह, रैम के पास मशीन के परिमित-राज्य भाग (तथाकथित [[ हार्वर्ड वास्तुकला ]]) में इसके निर्देश हैं।
{{Distinguish|रैंडम एक्सेस मेमोरी|text=[[रैंडम एक्सेस मेमोरी]]}}[[कंप्यूटर विज्ञान]] में, रैंडम-एक्सेस मशीन (रैम) [[रजिस्टर मशीन]] के सामान्य वर्ग में  [[अमूर्त मशीन]] है। रैम [[काउंटर मशीन]] के समान ही है | किन्तु इसके रजिस्टरों के 'अप्रत्यक्ष पता' की अतिरिक्त क्षमता के साथ काउंटर मशीन की तरह, रैम के पास मशीन के परिमित-स्तर भाग (तथाकथित [[ हार्वर्ड वास्तुकला | हार्वर्ड आर्किटेक्चर]] ) में इसके निर्देश हैं।


रैम [[यूनिवर्सल ट्यूरिंग मशीन]] के बराबर है{{spaced ndash}}रजिस्टरों के साथ-साथ इसके डेटा में इसके [[कंप्यूटर प्रोग्राम]] के साथ{{spaced ndash}} को [[ रैंडम-एक्सेस संग्रहित प्रोग्राम मशीन ]] या RASP कहा जाता है। यह तथाकथित [[वॉन न्यूमैन वास्तुकला]] का  उदाहरण है और [[कंप्यूटर]] की आम धारणा के सबसे करीब है।
रैम [[यूनिवर्सल ट्यूरिंग मशीन]] के समान है | रजिस्टरों के साथ-साथ इसके डेटा में इसके [[कंप्यूटर प्रोग्राम]] के साथ को [[ रैंडम-एक्सेस संग्रहित प्रोग्राम मशीन ]] या आरएएसपी कहा जाता है। यह तथाकथित [[वॉन न्यूमैन वास्तुकला|वॉन न्यूमैन आर्किटेक्चर]] का  उदाहरण है और [[कंप्यूटर]] की सामान्य धारणा के सबसे निकट है।


[[कम्प्यूटेशनल जटिलता विश्लेषण]] के लिए [[ट्यूरिंग मशीन]] और [[काउंटर-मशीन मॉडल]] के साथ, रैम और आरएएसपी मॉडल का उपयोग किया जाता है। वैन एम्डे बोस (1990) इन तीन प्लस [[ सूचक मशीन ]] अनुक्रमिक मशीन मॉडल को कहते हैं, ताकि उन्हें [[समानांतर रैंडम-एक्सेस मशीन]] मॉडल से अलग किया जा सके।
[[कम्प्यूटेशनल जटिलता विश्लेषण]] के लिए [[ट्यूरिंग मशीन]] और [[काउंटर-मशीन मॉडल]] के साथ, रैम और आरएएसपी मॉडल का उपयोग किया जाता है। वैन एम्डे बोस (1990) इन तीन प्लस [[ सूचक मशीन ]] अनुक्रमिक मशीन मॉडल को कहते हैं | जिससे उन्हें [[समानांतर रैंडम-एक्सेस मशीन]] मॉडल से अलग किया जा सके।


== मॉडल का परिचय ==
== मॉडल का परिचय ==
[[ रैंडम एक्सेस ]] मशीन (RAM) की अवधारणा सभी के सबसे सरल मॉडल, तथाकथित काउंटर मशीन मॉडल से शुरू होती है। हालाँकि, दो अतिरिक्त इसे काउंटर मशीन से दूर ले जाते हैं। पहले मशीन को अप्रत्यक्ष पते की सुविधा के साथ बढ़ाता है; दूसरा एक या एक से अधिक सहायक (समर्पित) रजिस्टरों के साथ मॉडल को अधिक पारंपरिक संचायक-आधारित कंप्यूटर की ओर ले जाता है, जिनमें से सबसे आम को संचायक कहा जाता है।
[[ रैंडम एक्सेस ]] मशीन (RAM) की अवधारणा सभी के सबसे सरल मॉडल, तथाकथित काउंटर मशीन मॉडल से प्रारंभ होती है। चूँकि, दो अतिरिक्त इसे काउंटर मशीन से दूर ले जाते हैं। पहले मशीन को अप्रत्यक्ष पते की सुविधा के साथ बढ़ाता है; दूसरा एक या एक से अधिक सहायक (समर्पित) रजिस्टरों के साथ मॉडल को अधिक पारंपरिक संचायक-आधारित कंप्यूटर की ओर ले जाता है, जिनमें से सबसे सामान्य को संचायक कहा जाता है।


=== औपचारिक परिभाषा ===
=== औपचारिक परिभाषा ===
रैंडम-एक्सेस मशीन (रैम)  अमूर्त कम्प्यूटेशनल-मशीन मॉडल है जो अप्रत्यक्ष एड्रेसिंग के साथ मल्टीपल-रजिस्टर काउंटर मशीन के समान है। अपने परिमित राज्य मशीन की टेबल से निर्देश के विवेक पर, मशीन एक लक्ष्य रजिस्टर का पता प्राप्त करती है या तो (i) सीधे निर्देश से, या (ii) अप्रत्यक्ष रूप से पॉइंटर रजिस्टर की सामग्री (जैसे संख्या, लेबल) से निर्दिष्ट होती है। निर्देश।
रैंडम-एक्सेस मशीन (रैम)  अमूर्त कम्प्यूटेशनल-मशीन मॉडल है जो अप्रत्यक्ष एड्रेसिंग के साथ मल्टीपल-रजिस्टर काउंटर मशीन के समान है। अपने परिमित स्तर मशीन की टेबल से निर्देश के विवेक पर, मशीन एक लक्ष्य रजिस्टर का पता प्राप्त करती है या तो (i) सीधे निर्देश से, या (ii) अप्रत्यक्ष रूप से पॉइंटर रजिस्टर की सामग्री (जैसे संख्या, लेबल) से निर्दिष्ट होती है। निर्देश।


परिभाषा के अनुसार:  रजिस्टर  पता (एक अद्वितीय, विशिष्ट पदनाम/प्राकृतिक संख्या के बराबर लोकेटर) और  सामग्री दोनों के साथ एक स्थान है।{{spaced ndash}} प्राकृतिक संख्या। सटीकता के लिए हम बूलोस-बर्गेस-जेफरी (2002) से अर्ध-औपचारिक प्रतीकवाद का उपयोग  रजिस्टर, इसकी सामग्री और  रजिस्टर पर  ऑपरेशन निर्दिष्ट करने के लिए करेंगे:
परिभाषा के अनुसार:  रजिस्टर  पता (एक अद्वितीय, विशिष्ट पदनाम/प्राकृतिक संख्या के समान लोकेटर) और  सामग्री दोनों के साथ एक स्थान है।{{spaced ndash}} प्राकृतिक संख्या। स्पष्टता के लिए हम बूलोस-बर्गेस-जेफरी (2002) से अर्ध-औपचारिक प्रतीकवाद का उपयोग  रजिस्टर, इसकी सामग्री और  रजिस्टर पर  ऑपरेशन निर्दिष्ट करने के लिए करेंगे:
* [आर] का मतलब पता आर के साथ रजिस्टर की सामग्री है। यहाँ लेबल r  चर है जिसे  प्राकृतिक संख्या या  अक्षर (जैसे A ) या एक नाम से भरा जा सकता है।
* [आर] का कारण पता आर के साथ रजिस्टर की सामग्री है। यहाँ लेबल r  चर है जिसे  प्राकृतिक संख्या या  अक्षर (जैसे A ) या एक नाम से भरा जा सकता है।
* → का अर्थ है प्रतिलिपि/जमा करना, या प्रतिस्थापित करना, लेकिन स्रोत को नष्ट किए बिना
* → का अर्थ है प्रतिलिपि/जमा करना, या प्रतिस्थापित करना, किन्तु स्रोत को नष्ट किए बिना
:: उदाहरण: [3] +1 → 3; का अर्थ है पते 3 के साथ स्रोत रजिस्टर की सामग्री, प्लस 1, पते 3 के साथ गंतव्य रजिस्टर में डाल दी जाती है (यहां स्रोत और गंतव्य एक ही स्थान हैं)। अगर [3]=37, यानी रजिस्टर 3 की सामग्री संख्या 37 है, तो 37+1 = 38 को रजिस्टर 3 में रखा जाएगा।
:: उदाहरण: [3] +1 → 3; का अर्थ है पते 3 के साथ स्रोत रजिस्टर की सामग्री, प्लस 1, पते 3 के साथ गंतव्य रजिस्टर में डाल दी जाती है (यहां स्रोत और गंतव्य एक ही स्थान हैं)। यदि [3]=37, अर्थात रजिस्टर 3 की सामग्री संख्या 37 है, तो 37+1 = 38 को रजिस्टर 3 में रखा जाएगा।


:: उदाहरण: [3] → 5; का अर्थ है पते 3 के साथ स्रोत रजिस्टर की सामग्री को पते 5 के साथ गंतव्य रजिस्टर में रखा गया है। अगर [3] = 38, यानी रजिस्टर 3 की सामग्री संख्या 38 है, तो यह संख्या रजिस्टर 5 में डाल दी जाएगी। रजिस्टर 3 की सामग्री इस ऑपरेशन से परेशान नहीं होती है, इसलिए [3] 38 बनी रहती है , अब [5] के समान है।
:: उदाहरण: [3] → 5; का अर्थ है पते 3 के साथ स्रोत रजिस्टर की सामग्री को पते 5 के साथ गंतव्य रजिस्टर में रखा गया है। यदि [3] = 38, अर्थात रजिस्टर 3 की सामग्री संख्या 38 है, तो यह संख्या रजिस्टर 5 में डाल दी जाएगी। रजिस्टर 3 की सामग्री इस ऑपरेशन से परेशान नहीं होती है, इसलिए [3] 38 बनी रहती है , अब [5] के समान है।


परिभाषा:  सीधा निर्देश वह है जो निर्देश में ही स्रोत या गंतव्य रजिस्टर का पता निर्दिष्ट करता है जिसकी सामग्री निर्देश का विषय होगी।
परिभाषा:  सीधा निर्देश वह है जो निर्देश में ही स्रोत या गंतव्य रजिस्टर का पता निर्दिष्ट करता है जिसकी सामग्री निर्देश का विषय होगी।
परिभाषा:  अप्रत्यक्ष निर्देश वह है जो सूचक रजिस्टर निर्दिष्ट करता है, जिसकी सामग्री लक्ष्य रजिस्टर का पता है। लक्ष्य रजिस्टर या तो स्रोत या गंतव्य हो सकता है (विभिन्न कॉपी निर्देश इसके उदाहरण प्रदान करते हैं)।  रजिस्टर अप्रत्यक्ष रूप से खुद को संबोधित कर सकता है।
परिभाषा:  अप्रत्यक्ष निर्देश वह है जो सूचक रजिस्टर निर्दिष्ट करता है, जिसकी सामग्री लक्ष्य रजिस्टर का पता है। लक्ष्य रजिस्टर या तो स्रोत या गंतव्य हो सकता है (विभिन्न कॉपी निर्देश इसके उदाहरण प्रदान करते हैं)।  रजिस्टर अप्रत्यक्ष रूप से खुद को संबोधित कर सकता है।
: मानक/सम्मेलन की चाह के लिए यह लेख निर्देश में  पैरामीटर (या पैरामीटर) के रूप में प्रत्यक्ष/अप्रत्यक्ष निर्दिष्ट करेगा, जिसे d/i के रूप में संक्षिप्त किया गया है:
: मानक/सम्मेलन की चाह के लिए यह लेख निर्देश में  पैरामीटर (या पैरामीटर) के रूप में प्रत्यक्ष/अप्रत्यक्ष निर्दिष्ट करेगा, जिसे d/i के रूप में संक्षिप्त किया गया है:
:: उदाहरण: COPY ('डी', ए, 'आई', एन) का अर्थ सीधे 'डी' स्रोत रजिस्टर का पता प्राप्त करें (पंजीकरण ए) निर्देश से ही लेकिन अप्रत्यक्ष रूप से 'i' पॉइंटर-रजिस्टर एन से गंतव्य पता प्राप्त करें मान लीजिए [एन] = 3, तो रजिस्टर 3 गंतव्य है और निर्देश निम्नलिखित कार्य करेगा: [ए] → 3।
:: उदाहरण: COPY ('डी', ए, 'आई', एन) का अर्थ सीधे 'डी' स्रोत रजिस्टर का पता प्राप्त करें (पंजीकरण ए) निर्देश से ही किन्तु अप्रत्यक्ष रूप से 'i' पॉइंटर-रजिस्टर एन से गंतव्य पता प्राप्त करें मान लीजिए [एन] = 3, तो रजिस्टर 3 गंतव्य है और निर्देश निम्नलिखित कार्य करेगा: [ए] → 3।


परिभाषा: स्रोत रजिस्टर की सामग्री का उपयोग निर्देश द्वारा किया जाता है। स्रोत रजिस्टर का पता या तो (i) सीधे निर्देश द्वारा निर्दिष्ट किया जा सकता है, या (ii) अप्रत्यक्ष रूप से निर्देश द्वारा निर्दिष्ट सूचक रजिस्टर द्वारा निर्दिष्ट किया जा सकता है।
परिभाषा: स्रोत रजिस्टर की सामग्री का उपयोग निर्देश द्वारा किया जाता है। स्रोत रजिस्टर का पता या तो (i) सीधे निर्देश द्वारा निर्दिष्ट किया जा सकता है, या (ii) अप्रत्यक्ष रूप से निर्देश द्वारा निर्दिष्ट सूचक रजिस्टर द्वारा निर्दिष्ट किया जा सकता है।
Line 27: Line 27:
परिभाषा: सूचक रजिस्टर की सामग्री लक्ष्य रजिस्टर का पता है।
परिभाषा: सूचक रजिस्टर की सामग्री लक्ष्य रजिस्टर का पता है।


परिभाषा: पॉइंटर रजिस्टर की सामग्री लक्ष्य रजिस्टर की ओर इशारा करती है{{spaced ndash}}लक्ष्य या तो स्रोत या गंतव्य रजिस्टर हो सकता है।
परिभाषा: पॉइंटर रजिस्टर की सामग्री लक्ष्य रजिस्टर की ओर संकेत करती है{{spaced ndash}}लक्ष्य या तो स्रोत या गंतव्य रजिस्टर हो सकता है।


परिभाषा: गंतव्य रजिस्टर वह जगह है जहाँ निर्देश अपना परिणाम जमा करता है। स्रोत रजिस्टर का पता या तो (i) सीधे निर्देश द्वारा निर्दिष्ट किया जा सकता है, या (ii) अप्रत्यक्ष रूप से निर्देश द्वारा निर्दिष्ट सूचक रजिस्टर द्वारा निर्दिष्ट किया जा सकता है। स्रोत और गंतव्य रजिस्टर एक हो सकते हैं।
परिभाषा: गंतव्य रजिस्टर वह स्थान है जहाँ निर्देश अपना परिणाम जमा करता है। स्रोत रजिस्टर का पता या तो (i) सीधे निर्देश द्वारा निर्दिष्ट किया जा सकता है, या (ii) अप्रत्यक्ष रूप से निर्देश द्वारा निर्दिष्ट सूचक रजिस्टर द्वारा निर्दिष्ट किया जा सकता है। स्रोत और गंतव्य रजिस्टर एक हो सकते हैं।


=== रिफ्रेशर: काउंटर-मशीन मॉडल ===
=== रिफ्रेशर: काउंटर-मशीन मॉडल ===
: मेल्ज़क (1961)  काउंटर मशीन का  आसान दृश्य प्रदान करता है: इसके रजिस्टर जमीन में छेद होते हैं, और इन छेदों में कंकड़ होते हैं।  निर्देश के अनुसार, इन छिद्रों में और बाहर कंप्यूटर (व्यक्ति या मशीन)  कंकड़ जोड़ता है (INcrements) या हटाता है (DECrements)। आवश्यकतानुसार, अतिरिक्त कंकड़ आते हैं, और अतिरिक्त कंकड़  अनंत आपूर्ति में वापस चले जाते हैं; यदि छेद कंकड़ रखने के लिए बहुत छोटा है तो कंप्यूटर छेद को बड़ा खोदता है।
: मेल्ज़क (1961)  काउंटर मशीन का  आसान दृश्य प्रदान करता है: इसके रजिस्टर जमीन में छेद होते हैं, और इन छेदों में कंकड़ होते हैं।  निर्देश के अनुसार, इन छिद्रों में और बाहर कंप्यूटर (व्यक्ति या मशीन)  कंकड़ जोड़ता है (INcrements) या हटाता है (DECrements)। आवश्यकतानुसार, अतिरिक्त कंकड़ आते हैं, और अतिरिक्त कंकड़  अनंत आपूर्ति में वापस चले जाते हैं; यदि छेद कंकड़ रखने के लिए बहुत छोटा है तो कंप्यूटर छेद को बड़ा खोदता है।


: मिन्स्की (1961) और होपक्रॉफ्ट-उलमैन 1979 (पृ. 171)  मल्टी-टेप ट्यूरिंग मशीन के विज़ुअलाइज़ेशन की पेशकश करते हैं जिसमें रजिस्टरों के रूप में कई बाएं सिरे वाले टेप होते हैं। प्रत्येक टेप की लंबाई दाईं ओर असीमित है, और बाएं छोर को छोड़कर हर वर्ग खाली है, जिसे चिह्नित किया गया है। टेप-स्क्वायर की संख्या में मापी गई टेप के सिर की उसके बाएं छोर से दूरी, रजिस्टर में प्राकृतिक संख्या का प्रतिनिधित्व करती है। वर्गों की संख्या कम करने के लिए टेप हेड बाईं ओर खिसकता है; वृद्धि यह सही चलती है। टेप पर निशान छापने या मिटाने की कोई जरूरत नहीं है; जंप-इफ-मार्क निर्देश के साथ बाएं सिरे के निशान का परीक्षण करके यह देखने के लिए केवल सशर्त निर्देश हैं कि सिर बाएं छोर पर है या नहीं।
: मिन्स्की (1961) और होपक्रॉफ्ट-उलमैन 1979 (पृ. 171)  मल्टी-टेप ट्यूरिंग मशीन के विज़ुअलाइज़ेशन की प्रस्तुति करते हैं जिसमें रजिस्टरों के रूप में कई बाएं सिरे वाले टेप होते हैं। प्रत्येक टेप की लंबाई दाईं ओर असीमित है, और बाएं छोर को छोड़कर हर वर्ग खाली है, जिसे चिह्नित किया गया है। टेप-स्क्वायर की संख्या में मापी गई टेप के सिर की उसके बाएं छोर से दूरी, रजिस्टर में प्राकृतिक संख्या का प्रतिनिधित्व करती है। वर्गों की संख्या कम करने के लिए टेप हेड बाईं ओर खिसकता है; वृद्धि यह सही चलती है। टेप पर निशान छापने या मिटाने की कोई आवश्यकता नहीं है; जंप-इफ-मार्क निर्देश के साथ बाएं सिरे के निशान का परीक्षण करके यह देखने के लिए केवल सशर्त निर्देश हैं कि सिर बाएं छोर पर है या नहीं।


:निम्नलिखित निर्देश mnemonics उदा। सीएलआर (आर) मनमानी हैं; कोई मानक मौजूद नहीं है।
:निम्नलिखित निर्देश mnemonics उदा। सीएलआर (आर) मनमानी हैं; कोई मानक उपस्थित नहीं है।


रजिस्टर मशीन के पास अपनी परिमित-राज्य मशीन के लिए बाहरी मेमोरी है{{spaced ndash}}असीमित क्षमता वाले असतत और विशिष्ट रूप से लेबल किए गए स्थानों का  असीमित (सीएफ: फुटनोट|गणनीय और असीमित) संग्रह, जिसे रजिस्टर कहा जाता है। इन रजिस्टरों में केवल प्राकृतिक संख्याएँ (शून्य और धनात्मक पूर्णांक) होती हैं। परिमित राज्य मशीन की तालिका में अनुक्रमिक निर्देशों की  सूची के अनुसार, कुछ (जैसे 2) प्रकार के आदिम संचालन इन रजिस्टरों की सामग्री पर काम करते हैं। अंत में, IF-THEN-ELSE के रूप में  सशर्त-अभिव्यक्ति एक या दो रजिस्टरों की सामग्री का परीक्षण करने के लिए उपलब्ध है और परिमित राज्य मशीन को डिफ़ॉल्ट निर्देश-अनुक्रम से बाहर शाखा / कूदती है।
रजिस्टर मशीन के पास अपनी परिमित-स्तर मशीन के लिए बाहरी मेमोरी है{{spaced ndash}}असीमित क्षमता वाले असतत और विशिष्ट रूप से लेबल किए गए स्थानों का  असीमित (सीएफ: फुटनोट|गणनीय और असीमित) संग्रह, जिसे रजिस्टर कहा जाता है। इन रजिस्टरों में केवल प्राकृतिक संख्याएँ (शून्य और धनात्मक पूर्णांक) होती हैं। परिमित स्तर मशीन की तालिका में अनुक्रमिक निर्देशों की  सूची के अनुसार, कुछ (जैसे 2) प्रकार के आदिम संचालन इन रजिस्टरों की सामग्री पर काम करते हैं। अंत में, IF-THEN-ELSE के रूप में  सशर्त-अभिव्यक्ति एक या दो रजिस्टरों की सामग्री का परीक्षण करने के लिए उपलब्ध है और परिमित स्तर मशीन को डिफ़ॉल्ट निर्देश-अनुक्रम से बाहर शाखा / कूदती है।


'बेस मॉडल 1': मिन्स्की (1961) विज़ुअलाइज़ेशन और लैम्बेक (1961) के निकटतम मॉडल:
'बेस मॉडल 1': मिन्स्की (1961) विज़ुअलाइज़ेशन और लैम्बेक (1961) के निकटतम मॉडल:
Line 70: Line 70:
|  style="text-align:center; "| [IR]  → IR
|  style="text-align:center; "| [IR]  → IR
|}
|}
बेस मॉडल 2: उत्तराधिकारी मॉडल ([[पियानो सिद्धांत]]ों के उत्तराधिकारी समारोह के नाम पर):
बेस मॉडल 2: उत्तराधिकारी मॉडल ([[पियानो सिद्धांत]]ों के उत्तराधिकारी कार्य के नाम पर):
* {रजिस्टर आर की सामग्री में वृद्धि, रजिस्टर आर की सामग्री को साफ करें, रजिस्टर आर की सामग्री ''आईएफ''<sub>j</sub> रजिस्टर आर की सामग्री के बराबर है<sub>k</sub> फिर निर्देश I पर जाएं<sub>z</sub> ELSE गोटो अगले निर्देश के लिए }
* {रजिस्टर आर की सामग्री में वृद्धि, रजिस्टर आर की सामग्री को साफ करें, रजिस्टर आर की सामग्री ''आईएफ''<sub>j</sub> रजिस्टर आर की सामग्री के समान है<sub>k</sub> फिर निर्देश I पर जाएं<sub>z</sub> ELSE गोटो अगले निर्देश के लिए }


{|class="wikitable"
{|class="wikitable"
Line 101: Line 101:
|}
|}
बेस मॉडल 3: एलगॉट-रॉबिन्सन (1964) द्वारा परिबद्ध और असंबद्ध आरएएसपी की जांच में उपयोग किया गया{{spaced ndash}}CLEAR के स्थान पर COPY वाला उत्तराधिकारी मॉडल:
बेस मॉडल 3: एलगॉट-रॉबिन्सन (1964) द्वारा परिबद्ध और असंबद्ध आरएएसपी की जांच में उपयोग किया गया{{spaced ndash}}CLEAR के स्थान पर COPY वाला उत्तराधिकारी मॉडल:
* {रजिस्टर आर की सामग्री में वृद्धि, रजिस्टर आर की सामग्री की प्रतिलिपि बनाएँ<sub>j</sub> आर दर्ज करने के लिए<sub>k</sub>, अगर रजिस्टर आर की सामग्री<sub>j</sub> रजिस्टर आर की सामग्री के बराबर है<sub>k</sub> फिर निर्देश I पर जाएं<sub>z</sub> ELSE गोटो अगले निर्देश के लिए }
* {रजिस्टर आर की सामग्री में वृद्धि, रजिस्टर आर की सामग्री की प्रतिलिपि बनाएँ<sub>j</sub> आर अंकित करने के लिए<sub>k</sub>, यदि रजिस्टर आर की सामग्री<sub>j</sub> रजिस्टर आर की सामग्री के समान है<sub>k</sub> फिर निर्देश I पर जाएं<sub>z</sub> ELSE गोटो अगले निर्देश के लिए }


{|class="wikitable"
{|class="wikitable"
Line 133: Line 133:


=== बेस सेट से सुविधा निर्देश बनाना ===
=== बेस सेट से सुविधा निर्देश बनाना ===
उपरोक्त तीन आधार सेट 1, 2, या 3 इस मायने में समतुल्य हैं कि कोई दूसरे सेट के निर्देशों का उपयोग करके  सेट के निर्देश बना सकता है (एक दिलचस्प अभ्यास: मिन्स्की से  संकेत (1967){{spaced ndash}}आरक्षित रजिस्टर घोषित करें उदा. संख्या 0 को शामिल करने के लिए इसे 0 (या शून्य के लिए Z या मिटाने के लिए E) पर कॉल करें)। मॉडल का चुनाव इस बात पर निर्भर करेगा कि  लेखक को प्रदर्शन, या प्रमाण आदि में किसका उपयोग करना सबसे आसान लगता है।
उपरोक्त तीन आधार सेट 1, 2, या 3 इस मायने में समतुल्य हैं कि कोई दूसरे सेट के निर्देशों का उपयोग करके  सेट के निर्देश बना सकता है (एक रोचक अभ्यास: मिन्स्की से  संकेत (1967){{spaced ndash}}आरक्षित रजिस्टर घोषित करें उदा. संख्या 0 को सम्मिलित करने के लिए इसे 0 (या शून्य के लिए Z या मिटाने के लिए E) पर कॉल करें)। मॉडल का चुनाव इस बात पर निर्भर करेगा कि  लेखक को प्रदर्शन, या प्रमाण आदि में किसका उपयोग करना सबसे आसान लगता है।


इसके अलावा, आधार सेट 1, 2, या 3 से हम किसी भी [[आदिम पुनरावर्ती कार्य]]ों (cf Minsky (1967), बूलोस-बर्गेस-जेफरी (2002)) को बना सकते हैं। (कुल और आंशिक mu पुनरावर्ती कार्यों को कैप्चर करने के लिए नेट को व्यापक कैसे बनाया जाए, इस पर अप्रत्यक्ष संबोधन के संदर्भ में चर्चा की जाएगी)। हालाँकि, आदिम पुनरावर्ती कार्यों का निर्माण करना मुश्किल है क्योंकि निर्देश सेट इतने ... आदिम (छोटे) हैं।  समाधान दूसरे सेट से सुविधा निर्देशों के साथ  विशेष सेट का विस्तार करना है:
इसके अतिरिक्त, आधार सेट 1, 2, या 3 से हम किसी भी [[आदिम पुनरावर्ती कार्य]]ों (cf Minsky (1967), बूलोस-बर्गेस-जेफरी (2002)) को बना सकते हैं। (कुल और आंशिक mu पुनरावर्ती कार्यों को कैप्चर करने के लिए नेट को व्यापक कैसे बनाया जाए, इस पर अप्रत्यक्ष संबोधन के संदर्भ में चर्चा की जाएगी)। चूँकि, आदिम पुनरावर्ती कार्यों का निर्माण करना कठिनाई है क्योंकि निर्देश सेट इतने ... आदिम (छोटे) हैं।  समाधान दूसरे सेट से सुविधा निर्देशों के साथ  विशेष सेट का विस्तार करना है:
: ये पारंपरिक अर्थों में सबरूटीन नहीं होंगे, बल्कि बेस सेट से बनाए गए निर्देशों के ब्लॉक होंगे और  स्मरक दिया जाएगा।  औपचारिक अर्थ में, इन ब्लॉकों का उपयोग करने के लिए हमें या तो (i) उन्हें उनके आधार-निर्देश समकक्षों में विस्तारित करने की आवश्यकता है{{spaced ndash}}उन्हें अस्थायी या सहायक रजिस्टरों के उपयोग की आवश्यकता होगी, इसलिए मॉडल को इसे ध्यान में रखना चाहिए, या (ii) 'बिल्ट इन' निर्देशों के साथ हमारी मशीनों/मॉडलों को डिज़ाइन करना चाहिए।
: ये पारंपरिक अर्थों में सबरूटीन नहीं होंगे, किन्तु बेस सेट से बनाए गए निर्देशों के ब्लॉक होंगे और  स्मरक दिया जाएगा।  औपचारिक अर्थ में, इन ब्लॉकों का उपयोग करने के लिए हमें या तो (i) उन्हें उनके आधार-निर्देश समकक्षों में विस्तारित करने की आवश्यकता है{{spaced ndash}}उन्हें अस्थायी या सहायक रजिस्टरों के उपयोग की आवश्यकता होगी, इसलिए मॉडल को इसे ध्यान में रखना चाहिए, या (ii) 'बिल्ट इन' निर्देशों के साथ हमारी मशीनों/मॉडलों को डिज़ाइन करना चाहिए।
: उदाहरण: बेस सेट 1. सीएलआर (आर) बनाने के लिए निर्देशों के ब्लॉक का उपयोग करें, रजिस्टर आर को शून्य करने के लिए काउंट डाउन करें। ऊपर बताए गए संकेत के उपयोग पर ध्यान दें:
: उदाहरण: बेस सेट 1. सीएलआर (आर) बनाने के लिए निर्देशों के ब्लॉक का उपयोग करें, रजिस्टर आर को शून्य करने के लिए काउंट डाउन करें। ऊपर बताए गए संकेत के उपयोग पर ध्यान दें:
:* सीएलआर (आर) =<sub>equiv</sub>
:* सीएलआर (आर) =<sub>equiv</sub>
Line 146: Line 146:
फिर से, यह सब केवल सुविधा के लिए है; इसमें से कोई भी मॉडल की आंतरिक शक्ति को नहीं बढ़ाता है।
फिर से, यह सब केवल सुविधा के लिए है; इसमें से कोई भी मॉडल की आंतरिक शक्ति को नहीं बढ़ाता है।


उदाहरण के लिए: सबसे विस्तारित सेट में तीन सेटों से प्रत्येक अद्वितीय निर्देश शामिल होगा, साथ ही बिना शर्त जम्प J (z) अर्थात:
उदाहरण के लिए: सबसे विस्तारित सेट में तीन सेटों से प्रत्येक अद्वितीय निर्देश सम्मिलित होगा, साथ ही बिना शर्त जम्प J (z) अर्थात:
* { सीएलआर (आर), डीईसी (आर), आईएनसी (आर), सीपीवाई (आर<sub>s</sub>, आर<sub>d</sub> ), जेजेड (आर, जेड), जेई (आर<sub>j</sub>, आर<sub>k</sub>, जेड), जे (जेड)}
* { सीएलआर (आर), डीईसी (आर), आईएनसी (आर), सीपीवाई (आर<sub>s</sub>, आर<sub>d</sub> ), जेजेड (आर, जेड), जेई (आर<sub>j</sub>, आर<sub>k</sub>, जेड), जे (जेड)}


अधिकांश लेखक सशर्त छलांगों में से एक या दूसरे को चुनते हैं, उदा। शेफर्डसन-स्टर्गिस (1963) उपरोक्त सेट माइनस जेई का उपयोग करते हैं (बिल्कुल सटीक होने के लिए वे जेएनजेड का उपयोग करते हैं){{spaced ndash}JZ के स्थान पर शून्य नहीं तो कूदें; अभी तक एक और संभावित सुविधा निर्देश)।
<nowiki>अधिकांश लेखक सशर्त छलांगों में से एक या दूसरे को चुनते हैं, उदा। शेफर्डसन-स्टर्गिस (1963) उपरोक्त सेट माइनस जेई का उपयोग करते हैं (बिल्कुल स्पष्ट होने के लिए वे जेएनजेड का उपयोग करते हैं){{spaced ndash}JZ के स्थान पर शून्य नहीं तो कूदें; अभी तक एक और संभावित सुविधा निर्देश)।</nowiki>


== अप्रत्यक्ष संचालन ==
== अप्रत्यक्ष संचालन ==
Line 166: Line 166:
=== अप्रत्यक्ष संचालन की आवश्यकता क्यों: काउंटर-मशीन मॉडल === के साथ दो प्रमुख समस्याएं
=== अप्रत्यक्ष संचालन की आवश्यकता क्यों: काउंटर-मशीन मॉडल === के साथ दो प्रमुख समस्याएं
निम्नलिखित में किसी को यह याद रखना चाहिए कि ये मॉडल भौतिक रूप से वास्तविक किसी भी चीज़ से दो मूलभूत अंतरों के साथ अमूर्त मॉडल हैं: असीम क्षमता वाले प्रत्येक रजिस्टर की असीमित संख्या। समस्या सबसे नाटकीय रूप से प्रकट होती है जब कोई आरएएसपी बनाने के लिए काउंटर-मशीन मॉडल का उपयोग करने की कोशिश करता है जो [[ट्यूरिंग पूर्णता]] है और इस प्रकार किसी आंशिक एमयू रिकर्सिव फ़ंक्शन की गणना करता है:
निम्नलिखित में किसी को यह याद रखना चाहिए कि ये मॉडल भौतिक रूप से वास्तविक किसी भी चीज़ से दो मूलभूत अंतरों के साथ अमूर्त मॉडल हैं: असीम क्षमता वाले प्रत्येक रजिस्टर की असीमित संख्या। समस्या सबसे नाटकीय रूप से प्रकट होती है जब कोई आरएएसपी बनाने के लिए काउंटर-मशीन मॉडल का उपयोग करने की कोशिश करता है जो [[ट्यूरिंग पूर्णता]] है और इस प्रकार किसी आंशिक एमयू रिकर्सिव फ़ंक्शन की गणना करता है:
* मेल्ज़ाक (1961) ने अपने होल-एंड-पेबल मॉडल में अप्रत्यक्ष रूप से जोड़ा ताकि उनका मॉडल  संगणित गोटो के साथ खुद को संशोधित कर सके और इसके उपयोग के दो उदाहरण प्रदान करता है (डी के पैमाने में दशमलव प्रतिनिधित्व और परिमाण द्वारा छंटनी, चाहे इनका उपयोग किया गया हो) उनके प्रमाण में कि मॉडल ट्यूरिंग समतुल्य है, स्पष्ट नहीं है क्योंकि कार्यक्रम को पाठक के लिए  अभ्यास के रूप में छोड़ दिया गया है (पृष्ठ 292)। मिन्स्की (1961, 1967) यह प्रदर्शित करने में सक्षम थे कि, उपयुक्त (लेकिन उपयोग में मुश्किल) गोडेल नंबर एन्कोडिंग के साथ, रजिस्टर मॉडल को ट्यूरिंग समतुल्य होने के लिए संकेत की आवश्यकता नहीं थी; लेकिन इसके लिए कम से कम  असीमित रजिस्टर की आवश्यकता थी। जैसा कि नीचे उल्लेख किया गया है, मिंस्की (1967) आरएएसपी के लिए समस्या का संकेत देता है, लेकिन समाधान की पेशकश नहीं करता है। एलगोट और रॉबिन्सन (1964) ने साबित किया कि उनका RASP मॉडल P<sub>0</sub>{{spaced ndash}} इसकी कोई अप्रत्यक्ष क्षमता नहीं है{{spaced ndash}}सभी पुनरावर्ती अनुक्रमिक कार्यों की गणना नहीं कर सकता है (जिनके मनमानी लंबाई के पैरामीटर हैं) यदि इसमें अपने स्वयं के निर्देशों को संशोधित करने की क्षमता नहीं है, लेकिन यह गोडेल संख्या के माध्यम से कर सकता है यदि यह करता है (पृष्ठ 395-397; विशेष रूप से चित्र 2 और फुटनोट पृष्ठ 395)। दूसरी ओर उनका RASP मॉडल P'<sub>0</sub>  इंडेक्स रजिस्टर (इनडायरेक्ट एड्रेसिंग) से लैस सभी आंशिक पुनरावर्ती अनुक्रमिक कार्यों (एमयू पुनरावर्ती कार्यों) की गणना कर सकता है (पृष्ठ 397-398)।
* मेल्ज़ाक (1961) ने अपने होल-एंड-पेबल मॉडल में अप्रत्यक्ष रूप से जोड़ा जिससे उनका मॉडल  संगणित गोटो के साथ खुद को संशोधित कर सके और इसके उपयोग के दो उदाहरण प्रदान करता है (डी के पैमाने में दशमलव प्रतिनिधित्व और परिमाण द्वारा छंटनी, चाहे इनका उपयोग किया गया हो) उनके प्रमाण में कि मॉडल ट्यूरिंग समतुल्य है, स्पष्ट नहीं है क्योंकि कार्यक्रम को पाठक के लिए  अभ्यास के रूप में छोड़ दिया गया है (पृष्ठ 292)। मिन्स्की (1961, 1967) यह प्रदर्शित करने में सक्षम थे कि, उपयुक्त (किन्तु उपयोग में कठिनाई) गोडेल नंबर एन्कोडिंग के साथ, रजिस्टर मॉडल को ट्यूरिंग समतुल्य होने के लिए संकेत की आवश्यकता नहीं थी; किन्तु इसके लिए कम से कम  असीमित रजिस्टर की आवश्यकता थी। जैसा कि नीचे उल्लेख किया गया है, मिंस्की (1967) आरएएसपी के लिए समस्या का संकेत देता है, किन्तु समाधान की प्रस्तुति नहीं करता है। एलगोट और रॉबिन्सन (1964) ने सिद्ध किया कि उनका आरएएसपी मॉडल P<sub>0</sub>{{spaced ndash}} इसकी कोई अप्रत्यक्ष क्षमता नहीं है{{spaced ndash}}सभी पुनरावर्ती अनुक्रमिक कार्यों की गणना नहीं कर सकता है (जिनके मनमानी लंबाई के पैरामीटर हैं) यदि इसमें अपने स्वयं के निर्देशों को संशोधित करने की क्षमता नहीं है, किन्तु यह गोडेल संख्या के माध्यम से कर सकता है यदि यह करता है (पृष्ठ 395-397; विशेष रूप से चित्र 2 और फुटनोट पृष्ठ 395)। दूसरी ओर उनका आरएएसपी मॉडल P'<sub>0</sub>  इंडेक्स रजिस्टर (इनडायरेक्ट एड्रेसिंग) से लैस सभी आंशिक पुनरावर्ती अनुक्रमिक कार्यों (एमयू पुनरावर्ती कार्यों) की गणना कर सकता है (पृष्ठ 397-398)।
: कुक एंड रेक्हो (1973) इसे सबसे संक्षेप में कहते हैं:
: कुक एंड रेक्हो (1973) इसे सबसे संक्षेप में कहते हैं:
:: निश्चित कार्यक्रम के लिए अप्रत्यक्ष निर्देश आवश्यक हैं ताकि इनपुट में भिन्नता के रूप में रजिस्टरों की असीमित संख्या तक पहुंच हो सके। (पृष्ठ 73)
:: निश्चित कार्यक्रम के लिए अप्रत्यक्ष निर्देश आवश्यक हैं जिससे इनपुट में भिन्नता के रूप में रजिस्टरों की असीमित संख्या तक पहुंच हो सके। (पृष्ठ 73)
* 'रजिस्टरों की असीमित क्षमता बनाम राज्य-मशीन निर्देशों की सीमित क्षमता': मशीन का तथाकथित परिमित राज्य हिस्सा माना जाता है{{spaced ndash}}<nowiki>एल्गोरिदम की सामान्य परिभाषा के अनुसार{{spaced ndash}राज्यों (निर्देशों) की संख्या और निर्देशों के आकार (प्रतीकों/संकेतों को धारण करने की उनकी क्षमता) दोनों में बहुत सीमित है। तो कैसे  राज्य मशीन  मनमाने ढंग से बड़े स्थिरांक को सीधे  रजिस्टर में ले जाती है, उदा। मूव (के, आर) (आर रजिस्टर करने के लिए निरंतर के को स्थानांतरित करें)? यदि विशाल स्थिरांक आवश्यक हैं, तो उन्हें या तो स्वयं रजिस्टरों में शुरू करना चाहिए या राज्य मशीन द्वारा निर्देशों की  सीमित संख्या का उपयोग करके बनाया जाना चाहिए। INC और DEC का उपयोग करके गुणा करें और सबरूटीन्स जोड़ें (लेकिन इनमें से  अर्ध-अनंत संख्या नहीं!)।</nowiki>
* 'रजिस्टरों की असीमित क्षमता बनाम स्तर-मशीन निर्देशों की सीमित क्षमता': मशीन का तथाकथित परिमित स्तर हिस्सा माना जाता है{{spaced ndash}}<nowiki>एल्गोरिदम की सामान्य परिभाषा के अनुसार{{spaced ndash}राज्यों (निर्देशों) की संख्या और निर्देशों के आकार (प्रतीकों/संकेतों को धारण करने की उनकी क्षमता) दोनों में बहुत सीमित है। तो कैसे  स्तर मशीन  इच्छानुसार से बड़े स्थिरांक को सीधे  रजिस्टर में ले जाती है, उदा। मूव (के, आर) (आर रजिस्टर करने के लिए निरंतर के को स्थानांतरित करें)? यदि विशाल स्थिरांक आवश्यक हैं, तो उन्हें या तो स्वयं रजिस्टरों में प्रारंभ करना चाहिए या स्तर मशीन द्वारा निर्देशों की  सीमित संख्या का उपयोग करके बनाया जाना चाहिए। INC और DEC का उपयोग करके गुणा करें और सबरूटीन्स जोड़ें (किन्तु इनमें से  अर्ध-अनंत संख्या नहीं!)।</nowiki>
:: कभी-कभी सीएलआर (आर) के उपयोग के बाद आईएनसी (आर) बार-बार के बार के बाद निरंतर के बनाया जाएगा{{spaced ndash}}उदा. स्थिर k = 3 को रजिस्टर r में रखने के लिए, यानी 3 → r, इसलिए निर्देश के अंत में [r] = 3: CLR (r), INC (r), INC (r), INC (r)। इस ट्रिक का उल्लेख क्लेन (1952) पृष्ठ द्वारा किया गया है। 223. समस्या तब उत्पन्न होती है जब बनाई जाने वाली संख्या परिमित राज्य मशीन के लिए उपलब्ध निर्देशों की संख्या को समाप्त कर देती है; परिमित राज्य मशीन के लिए उपलब्ध निर्देशों की संख्या की तुलना में हमेशा एक बड़ा स्थिरांक होता है।
:: कभी-कभी सीएलआर (आर) के उपयोग के बाद आईएनसी (आर) बार-बार के बार के बाद निरंतर के बनाया जाएगा{{spaced ndash}}उदा. स्थिर k = 3 को रजिस्टर r में रखने के लिए, अर्थात 3 → r, इसलिए निर्देश के अंत में [r] = 3: CLR (r), INC (r), INC (r), INC (r)। इस ट्रिक का उल्लेख क्लेन (1952) पृष्ठ द्वारा किया गया है। 223. समस्या तब उत्पन्न होती है जब बनाई जाने वाली संख्या परिमित स्तर मशीन के लिए उपलब्ध निर्देशों की संख्या को समाप्त कर देती है; परिमित स्तर मशीन के लिए उपलब्ध निर्देशों की संख्या की तुलना में सदैव एक बड़ा स्थिरांक होता है।
* 'रजिस्टरों की असीमित संख्या बनाम बाध्य राज्य-मशीन निर्देश': यह पहली समस्या से अधिक गंभीर है। विशेष रूप से, यह समस्या तब उत्पन्न होती है जब हम  तथाकथित आरएएसपी,  सार्वभौमिक मशीन (यूनिवर्सल ट्यूरिंग मशीन पर अधिक देखें) बनाने का प्रयास करते हैं जो अपने परिमित-राज्य मशीन का उपयोग अपने रजिस्टरों में स्थित निर्देशों के  कार्यक्रम की व्याख्या करने के लिए करती है।{{spaced ndash}}अर्थात। हम वो बना रहे हैं जिसे आजकल वॉन न्यूमैन आर्किटेक्चर वाला कंप्यूटर कहा जाता है।
* 'रजिस्टरों की असीमित संख्या बनाम बाध्य स्तर-मशीन निर्देश': यह पहली समस्या से अधिक गंभीर है। विशेष रूप से, यह समस्या तब उत्पन्न होती है जब हम  तथाकथित आरएएसपी,  सार्वभौमिक मशीन (यूनिवर्सल ट्यूरिंग मशीन पर अधिक देखें) बनाने का प्रयास करते हैं जो अपने परिमित-स्तर मशीन का उपयोग अपने रजिस्टरों में स्थित निर्देशों के  कार्यक्रम की व्याख्या करने के लिए करती है।{{spaced ndash}}अर्थात। हम वो बना रहे हैं जिसे आजकल वॉन न्यूमैन आर्किटेक्चर वाला कंप्यूटर कहा जाता है।


: ध्यान दें कि काउंटर मशीन की परिमित राज्य मशीन को अपने नाम/संख्या से स्पष्ट रूप से (सीधे)  रजिस्टर को कॉल करना चाहिए: INC (65,356) रजिस्टर संख्या 65,365 को स्पष्ट रूप से कॉल करता है। यदि रजिस्टरों की संख्या उन्हें संबोधित करने के लिए परिमित राज्य मशीन की क्षमता से अधिक है, तो सीमा के बाहर के रजिस्टर अगम्य होंगे। उदाहरण के लिए, यदि परिमित अवस्था मशीन केवल 65,536 = 2 तक पहुँच सकती है<sup>16</sup> पंजीकृत है तो यह 65,537वें स्थान पर कैसे पहुंच सकता है?
: ध्यान दें कि काउंटर मशीन की परिमित स्तर मशीन को अपने नाम/संख्या से स्पष्ट रूप से (सीधे)  रजिस्टर को कॉल करना चाहिए: INC (65,356) रजिस्टर संख्या 65,365 को स्पष्ट रूप से कॉल करता है। यदि रजिस्टरों की संख्या उन्हें संबोधित करने के लिए परिमित स्तर मशीन की क्षमता से अधिक है, तो सीमा के बाहर के रजिस्टर अगम्य होंगे। उदाहरण के लिए, यदि परिमित अवस्था मशीन केवल 65,536 = 2 तक पहुँच सकती है<sup>16</sup> पंजीकृत है तो यह 65,537वें स्थान पर कैसे पहुंच सकता है?


तो हम परिमित राज्य मशीन की सीमा से परे  रजिस्टर को कैसे संबोधित करते हैं?  दृष्टिकोण प्रोग्राम-निर्देशों (रजिस्टरों में संग्रहीत) को संशोधित करना होगा ताकि उनमें एक से अधिक कमांड हों। लेकिन यह भी तब तक समाप्त हो सकता है जब तक कि कोई निर्देश (संभावित रूप से) असीमित आकार का न हो। तो क्यों न केवल  über-निर्देश का उपयोग किया जाए{{spaced ndash}}वास्तव में  बहुत बड़ी संख्या{{spaced ndash}} जिसमें प्रोग्राम के सभी निर्देश एन्कोडेड हैं! इस तरह मिन्स्की समस्या को हल करता है, लेकिन वह जिस गोडेल नंबरिंग का उपयोग करता है वह मॉडल के लिए  बड़ी असुविधा का प्रतिनिधित्व करता है, और परिणाम  संग्रहीत प्रोग्राम कंप्यूटर की हमारी सहज धारणा की तरह कुछ भी नहीं है।
तो हम परिमित स्तर मशीन की सीमा से परे  रजिस्टर को कैसे संबोधित करते हैं?  दृष्टिकोण प्रोग्राम-निर्देशों (रजिस्टरों में संग्रहीत) को संशोधित करना होगा जिससे उनमें एक से अधिक कमांड हों। किन्तु यह भी तब तक समाप्त हो सकता है जब तक कि कोई निर्देश (संभावित रूप से) असीमित आकार का न हो। तो क्यों न केवल  über-निर्देश का उपयोग किया जाए{{spaced ndash}}वास्तव में  बहुत बड़ी संख्या{{spaced ndash}} जिसमें प्रोग्राम के सभी निर्देश एन्कोडेड हैं! इस तरह मिन्स्की समस्या को हल करता है, किन्तु वह जिस गोडेल नंबरिंग का उपयोग करता है वह मॉडल के लिए  बड़ी असुविधा का प्रतिनिधित्व करता है, और परिणाम  संग्रहीत प्रोग्राम कंप्यूटर की हमारी सहज धारणा की तरह कुछ भी नहीं है।


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


अपने RPT (रिपीट) निर्देश का उपयोग करते हुए  अधिक कंप्यूटर जैसे मॉडल के संदर्भ में मिन्स्की (1967) हमें समस्या के समाधान के साथ आकर्षित करता है (cf p. 214, p. 259) लेकिन कोई ठोस समाधान प्रदान नहीं करता है। वह दावा करता है:
अपने RPT (रिपीट) निर्देश का उपयोग करते हुए  अधिक कंप्यूटर जैसे मॉडल के संदर्भ में मिन्स्की (1967) हमें समस्या के समाधान के साथ आकर्षित करता है (cf p. 214, p. 259) किन्तु कोई ठोस समाधान प्रदान नहीं करता है। वह प्रमाणित करता है:
: सामान्य तौर पर RPT ऑपरेशन मशीन के परिमित-राज्य भाग में  निर्देश नहीं हो सकता है ... यह कंप्यूटर के परिमित भाग में अनुमत भंडारण की किसी विशेष मात्रा को समाप्त कर सकता है [sic, उसके RAM मॉडल के लिए उसका नाम]। RPT संचालन के लिए स्वयं के अनंत रजिस्टरों की आवश्यकता होती है। (पृष्ठ 214)।
: सामान्यतः RPT ऑपरेशन मशीन के परिमित-स्तर भाग में  निर्देश नहीं हो सकता है ... यह कंप्यूटर के परिमित भाग में अनुमत भंडारण की किसी विशेष मात्रा को समाप्त कर सकता है [sic, उसके RAM मॉडल के लिए उसका नाम]। RPT संचालन के लिए स्वयं के अनंत रजिस्टरों की आवश्यकता होती है। (पृष्ठ 214)।


वह हमें  बाउंडेड आरपीटी प्रदान करता है जो सीएलआर (आर) और आईएनसी (आर) के साथ मिलकर किसी भी आदिम पुनरावर्ती फ़ंक्शन की गणना कर सकता है, और वह ऊपर उद्धृत अनबाउंड आरपीटी प्रदान करता है जो μ ऑपरेटर की भूमिका निभा रहा है; यह CLR (r) और INC (r) के साथ मिलकर mu पुनरावर्ती कार्यों की गणना कर सकता है। लेकिन वह परोक्ष या प्रति रैम मॉडल पर चर्चा नहीं करता है।
वह हमें  बाउंडेड आरपीटी प्रदान करता है जो सीएलआर (आर) और आईएनसी (आर) के साथ मिलकर किसी भी आदिम पुनरावर्ती फ़ंक्शन की गणना कर सकता है, और वह ऊपर उद्धृत अनबाउंड आरपीटी प्रदान करता है जो μ ऑपरेटर की भूमिका निभा रहा है; यह CLR (r) और INC (r) के साथ मिलकर mu पुनरावर्ती कार्यों की गणना कर सकता है। किन्तु वह परोक्ष या प्रति रैम मॉडल पर चर्चा नहीं करता है।


हार्टमैनिस (1971) के संदर्भों से ऐसा प्रतीत होता है कि कुक (यूसी बर्कले, 1970 में अपने व्याख्यान नोट्स में) ने अप्रत्यक्ष संबोधन की धारणा को मजबूत किया है। यह कुक एंड रेक्हो (1973) के पेपर में स्पष्ट हो जाता है।{{spaced ndash}}कुक रेक्हो के मास्टर के थीसिस सलाहकार हैं। हार्टमैनिस का मॉडल{{spaced ndash}}मेल्ज़ाक के (1961) मॉडल के समान{{spaced ndash}}दो और तीन-रजिस्टर जोड़ और घटाव और दो पैरामीटर प्रतियों का उपयोग करता है; कुक और रेकहो का मॉडल  संचायक एसी के उपयोग से एक कॉल-आउट के लिए मापदंडों की संख्या (प्रोग्राम निर्देशों में बुलाए गए रजिस्टर) को कम करता है।
हार्टमैनिस (1971) के संदर्भों से ऐसा प्रतीत होता है कि कुक (यूसी बर्कले, 1970 में अपने व्याख्यान नोट्स में) ने अप्रत्यक्ष संबोधन की धारणा को शक्तिशाली किया है। यह कुक एंड रेक्हो (1973) के पेपर में स्पष्ट हो जाता है।{{spaced ndash}}कुक रेक्हो के मास्टर के थीसिस सलाहकार हैं। हार्टमैनिस का मॉडल{{spaced ndash}}मेल्ज़ाक के (1961) मॉडल के समान{{spaced ndash}}दो और तीन-रजिस्टर जोड़ और घटाव और दो पैरामीटर प्रतियों का उपयोग करता है; कुक और रेकहो का मॉडल  संचायक एसी के उपयोग से एक कॉल-आउट के लिए मापदंडों की संख्या (प्रोग्राम निर्देशों में बुलाए गए रजिस्टर) को कम करता है।


संक्षेप में समाधान: हमारी मशीन/मॉडल को असीमित संकेत के साथ डिज़ाइन करें{{spaced ndash}} असीमित पता रजिस्टर प्रदान करें जो संभावित रूप से किसी भी रजिस्टर का नाम (कॉल आउट) कर सकता है, चाहे कितने भी हों। इसके लिए काम करने के लिए, सामान्य रूप से, असीमित रजिस्टर को साफ़ करने की क्षमता की आवश्यकता होती है और फिर संभावित अनंत लूप द्वारा वृद्धि (और संभवतः, कमी) की आवश्यकता होती है। इस अर्थ में समाधान असीमित μ ऑपरेटर का प्रतिनिधित्व करता है, जो आवश्यक होने पर, रजिस्टरों की असीमित स्ट्रिंग के साथ अनंत तक शिकार कर सकता है, जब तक कि वह जो ढूंढ रहा है उसे नहीं मिल जाता। पॉइंटर रजिस्टर बिल्कुल  अपवाद के साथ किसी भी अन्य रजिस्टर की तरह है: अप्रत्यक्ष एड्रेसिंग कहलाने वाली परिस्थितियों में यह स्टेट मशीन के टेबल में एड्रेस-ऑपरेंड के बजाय अपनी सामग्री प्रदान करता है, लक्ष्य रजिस्टर का पता होने के लिए (संभवतः स्वयं सहित!) .
संक्षेप में समाधान: हमारी मशीन/मॉडल को असीमित संकेत के साथ डिज़ाइन करें{{spaced ndash}} असीमित पता रजिस्टर प्रदान करें जो संभावित रूप से किसी भी रजिस्टर का नाम (कॉल आउट) कर सकता है, चाहे कितने भी हों। इसके लिए काम करने के लिए, सामान्य रूप से, असीमित रजिस्टर को साफ़ करने की क्षमता की आवश्यकता होती है और फिर संभावित अनंत लूप द्वारा वृद्धि (और संभवतः, कमी) की आवश्यकता होती है। इस अर्थ में समाधान असीमित μ ऑपरेटर का प्रतिनिधित्व करता है, जो आवश्यक होने पर, रजिस्टरों की असीमित स्ट्रिंग के साथ अनंत तक शिकार कर सकता है, जब तक कि वह जो ढूंढ रहा है उसे नहीं मिल जाता। पॉइंटर रजिस्टर बिल्कुल  अपवाद के साथ किसी भी अन्य रजिस्टर की तरह है: अप्रत्यक्ष एड्रेसिंग कहलाने वाली परिस्थितियों में यह स्टेट मशीन के टेबल में एड्रेस-ऑपरेंड के अतिरिक्त अपनी सामग्री प्रदान करता है, लक्ष्य रजिस्टर का पता होने के लिए (संभवतः स्वयं सहित!) .


=== परिबद्ध संकेत और आदिम पुनरावर्ती कार्य ===
=== परिबद्ध संकेत और आदिम पुनरावर्ती कार्य ===
यदि हम  रजिस्टर में  राक्षस संख्या के मिन्स्की दृष्टिकोण से बचते हैं, और निर्दिष्ट करते हैं कि हमारा मशीन मॉडल  कंप्यूटर की तरह होगा, तो हमें इस अप्रत्यक्ष समस्या का सामना करना होगा यदि हम पुनरावर्ती कार्यों की गणना कर रहे हैं (जिसे μ-पुनरावर्ती कार्य भी कहा जाता है){{spaced ndash}}कुल और आंशिक दोनों किस्में।
यदि हम  रजिस्टर में  राक्षस संख्या के मिन्स्की दृष्टिकोण से बचते हैं, और निर्दिष्ट करते हैं कि हमारा मशीन मॉडल  कंप्यूटर की तरह होगा, तो हमें इस अप्रत्यक्ष समस्या का सामना करना होगा यदि हम पुनरावर्ती कार्यों की गणना कर रहे हैं (जिसे μ-पुनरावर्ती कार्य भी कहा जाता है){{spaced ndash}}कुल और आंशिक दोनों किस्में।


हमारा सरल काउंटर-मशीन मॉडल अप्रत्यक्ष रूप से बंधा हुआ रूप कर सकता है{{spaced ndash}} और इस प्रकार आदिम पुनरावर्ती कार्यों के उप-वर्ग की गणना करें{{spaced ndash}}डेफिनिशन बाय केस (क्लेन (1952) पृष्ठ 229 और बूलोस-बर्गेस-जेफरी पृष्ठ 74 में परिभाषित) नामक  आदिम पुनरावर्ती संचालिका का उपयोग करके। ऐसा बंधा हुआ संकेत  श्रमसाध्य, थकाऊ मामला है। मामलों की परिभाषा के लिए मशीन को पॉइंटर रजिस्टर की सामग्री को निर्धारित करने / अलग करने की आवश्यकता होती है, जब तक कि सफलता न मिल जाए, इस सामग्री को  संख्या / नाम के खिलाफ मिलान करने के लिए, जिसे केस ऑपरेटर स्पष्ट रूप से घोषित करता है। इस प्रकार मामलों की परिभाषा उदा से शुरू होती है। निचले बाउंड पते और मैच बनाने का प्रयास करने वाले ऊपरी बाउंड पते की ओर लगातार विज्ञापन जारी रहता है:
हमारा सरल काउंटर-मशीन मॉडल अप्रत्यक्ष रूप से बंधा हुआ रूप कर सकता है{{spaced ndash}} और इस प्रकार आदिम पुनरावर्ती कार्यों के उप-वर्ग की गणना करें{{spaced ndash}}डेफिनिशन बाय केस (क्लेन (1952) पृष्ठ 229 और बूलोस-बर्गेस-जेफरी पृष्ठ 74 में परिभाषित) नामक  आदिम पुनरावर्ती संचालिका का उपयोग करके। ऐसा बंधा हुआ संकेत  श्रमसाध्य, थकाऊ स्थिति है। स्थितियों की परिभाषा के लिए मशीन को पॉइंटर रजिस्टर की सामग्री को निर्धारित करने / अलग करने की आवश्यकता होती है, जब तक कि सफलता न मिल जाए, इस सामग्री को  संख्या / नाम के खिलाफ मिलान करने के लिए, जिसे केस ऑपरेटर स्पष्ट रूप से घोषित करता है। इस प्रकार स्थितियों की परिभाषा उदा से प्रारंभ होती है। निचले बाउंड पते और मैच बनाने का प्रयास करने वाले ऊपरी बाउंड पते की ओर लगातार विज्ञापन जारी रहता है:
: क्या रजिस्टर N में संख्या 0 के बराबर है? यदि नहीं तो क्या यह 1 के बराबर है? 2? 3? ... 65364? यदि नहीं तो हम अंतिम संख्या 65365 पर हैं और यह बेहतर होगा, अन्यथा हमें समस्या है!
: क्या रजिस्टर N में संख्या 0 के समान है? यदि नहीं तो क्या यह 1 के समान है? 2? 3? ... 65364? यदि नहीं तो हम अंतिम संख्या 65365 पर हैं और यह उत्तम होगा, अन्यथा हमें समस्या है!


  बाउंडेड इनडायरेक्शन हमें आंशिक पुनरावर्ती कार्यों की गणना करने की अनुमति नहीं देगा{{spaced ndash}} उनके लिए हमें अनबाउंड इंडिकेशन उर्फ ​​​​μ ऑपरेटर की आवश्यकता है।
  बाउंडेड इनडायरेक्शन हमें आंशिक पुनरावर्ती कार्यों की गणना करने की अनुमति नहीं देगा{{spaced ndash}} उनके लिए हमें अनबाउंड इंडिकेशन उर्फ ​​​​μ ऑपरेटर की आवश्यकता है।
: मान लीजिए कि हम 65367 नंबर पर जारी रखने में सक्षम थे, और वास्तव में उस रजिस्टर में वह था जिसकी हम तलाश कर रहे थे। तब हम अपनी गणना सफलतापूर्वक पूरी कर सकते थे! लेकिन मान लीजिए कि 65367 के पास वह नहीं है जिसकी हमें जरूरत है। हमें कितनी दूर जाना जारी रखना चाहिए?
: मान लीजिए कि हम 65367 नंबर पर जारी रखने में सक्षम थे, और वास्तव में उस रजिस्टर में वह था जिसकी हम तलाश कर रहे थे। तब हम अपनी गणना सफलतापूर्वक पूरी कर सकते थे! किन्तु मान लीजिए कि 65367 के पास वह नहीं है जिसकी हमें आवश्यकता है। हमें कितनी दूर जाना जारी रखना चाहिए?


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


=== असीम अप्रत्यक्ष और आंशिक पुनरावर्ती कार्य ===
=== असीम अप्रत्यक्ष और आंशिक पुनरावर्ती कार्य ===
अनबाउंड इंडिकेशन के लिए हमें अपने मशीन मॉडल में हार्डवेयर परिवर्तन की आवश्यकता होती है। एक बार जब हम यह परिवर्तन कर लेते हैं तो मॉडल  काउंटर मशीन नहीं रह जाता है, बल्कि रैंडम-एक्सेस मशीन बन जाता है।
अनबाउंड इंडिकेशन के लिए हमें अपने मशीन मॉडल में हार्डवेयर परिवर्तन की आवश्यकता होती है। एक बार जब हम यह परिवर्तन कर लेते हैं तो मॉडल  काउंटर मशीन नहीं रह जाता है, किन्तु रैंडम-एक्सेस मशीन बन जाता है।


अब जब उदा. आईएनसी निर्दिष्ट है, परिमित राज्य मशीन के निर्देश को यह निर्दिष्ट करना होगा कि ब्याज के रजिस्टर का पता कहां से आएगा। यह या तो हो सकता है (i) राज्य मशीन का निर्देश जो  स्पष्ट लेबल प्रदान करता है, या (ii) पॉइंटर-रजिस्टर जिसकी सामग्री रुचि का पता है। जब भी कोई निर्देश  रजिस्टर पता निर्दिष्ट करता है तो उसे अब  अतिरिक्त पैरामीटर i/d निर्दिष्ट करने की आवश्यकता होगी{{spaced ndash}}<nowiki> अप्रत्यक्ष/प्रत्यक्ष। एक मायने में यह नया आई/डी पैरामीटर  स्विच है जो निर्देश में निर्दिष्ट प्रत्यक्ष पता प्राप्त करने के लिए एक तरफ फ़्लिप करता है या पॉइंटर रजिस्टर से अप्रत्यक्ष पता प्राप्त करने का दूसरा तरीका है (जो पॉइंटर रजिस्टर{{spaced ndash}कुछ मॉडलों में प्रत्येक रजिस्टर  सूचक रजिस्टर हो सकता है</nowiki>{{spaced ndash}} निर्देश द्वारा निर्दिष्ट किया गया है)। यह पारस्परिक रूप से अनन्य लेकिन संपूर्ण विकल्प मामलों द्वारा परिभाषा का एक और उदाहरण है, और नीचे दिए गए उदाहरण में दिखाया गया अंकगणितीय समकक्ष क्लेन (1952) पी में परिभाषा से लिया गया है। 229.
अब जब उदा. आईएनसी निर्दिष्ट है, परिमित स्तर मशीन के निर्देश को यह निर्दिष्ट करना होगा कि ब्याज के रजिस्टर का पता कहां से आएगा। यह या तो हो सकता है (i) स्तर मशीन का निर्देश जो  स्पष्ट लेबल प्रदान करता है, या (ii) पॉइंटर-रजिस्टर जिसकी सामग्री रुचि का पता है। जब भी कोई निर्देश  रजिस्टर पता निर्दिष्ट करता है तो उसे अब  अतिरिक्त पैरामीटर i/d निर्दिष्ट करने की आवश्यकता होगी{{spaced ndash}}<nowiki> अप्रत्यक्ष/प्रत्यक्ष। एक मायने में यह नया आई/डी पैरामीटर  स्विच है जो निर्देश में निर्दिष्ट प्रत्यक्ष पता प्राप्त करने के लिए एक तरफ फ़्लिप करता है या पॉइंटर रजिस्टर से अप्रत्यक्ष पता प्राप्त करने का दूसरा विधि है (जो पॉइंटर रजिस्टर{{spaced ndash}कुछ मॉडलों में प्रत्येक रजिस्टर  सूचक रजिस्टर हो सकता है</nowiki>{{spaced ndash}} निर्देश द्वारा निर्दिष्ट किया गया है)। यह पारस्परिक रूप से अनन्य किन्तु संपूर्ण विकल्प स्थितियों द्वारा परिभाषा का एक और उदाहरण है, और नीचे दिए गए उदाहरण में दिखाया गया अंकगणितीय समकक्ष क्लेन (1952) पी में परिभाषा से लिया गया है। 229.


: उदाहरण: सीपीवाई (अप्रत्यक्ष<sub>source</sub>, आर<sub>source</sub>, प्रत्यक्ष<sub>destination</sub>, आर<sub>destination</sub> )
: उदाहरण: सीपीवाई (अप्रत्यक्ष<sub>source</sub>, आर<sub>source</sub>, प्रत्यक्ष<sub>destination</sub>, आर<sub>destination</sub> )
Line 208: Line 208:
: डायरेक्ट एड्रेसिंग को d= 0 और इनडायरेक्ट एड्रेसिंग को i= 1 के रूप में निर्दिष्ट करने के लिए  कोड असाइन करें। तब हमारी मशीन स्रोत का पता निम्नानुसार निर्धारित कर सकती है:
: डायरेक्ट एड्रेसिंग को d= 0 और इनडायरेक्ट एड्रेसिंग को i= 1 के रूप में निर्दिष्ट करने के लिए  कोड असाइन करें। तब हमारी मशीन स्रोत का पता निम्नानुसार निर्धारित कर सकती है:
:: मैं * [आर<sub>s</sub>] + (1-आई)*आर<sub>s</sub>
:: मैं * [आर<sub>s</sub>] + (1-आई)*आर<sub>s</sub>
: उदाहरण के लिए, मान लीजिए कि रजिस्टर 3 की सामग्री 5 है (यानी [3]=5 ) और रजिस्टर 4 की सामग्री 2 है (यानी [4]=2 ):
: उदाहरण के लिए, मान लीजिए कि रजिस्टर 3 की सामग्री 5 है (अर्थात [3]=5 ) और रजिस्टर 4 की सामग्री 2 है (अर्थात [4]=2 ):


:: उदाहरण: CPY (1, 3, 0, 4) = CPY (अप्रत्यक्ष, reg 3, प्रत्यक्ष, reg 4)
:: उदाहरण: CPY (1, 3, 0, 4) = CPY (अप्रत्यक्ष, reg 3, प्रत्यक्ष, reg 4)
Line 225: Line 225:
संभवतः जोड़े गए निर्देशों में सबसे उपयोगी है कॉपी। दरअसल, एलगॉट-रॉबिन्सन (1964) ने अपने मॉडल पी<sub>0</sub> और पी'<sub>0</sub> COPY निर्देशों के साथ, और Cook-Reckhow (1973) केवल दो अप्रत्यक्ष निर्देशों के साथ अपना संचायक-आधारित मॉडल प्रदान करते हैं{{spaced ndash}अप्रत्यक्ष रूप से संचायक को कॉपी करें, संचायक से अप्रत्यक्ष रूप से कॉपी करें।
संभवतः जोड़े गए निर्देशों में सबसे उपयोगी है कॉपी। दरअसल, एलगॉट-रॉबिन्सन (1964) ने अपने मॉडल पी<sub>0</sub> और पी'<sub>0</sub> COPY निर्देशों के साथ, और Cook-Reckhow (1973) केवल दो अप्रत्यक्ष निर्देशों के साथ अपना संचायक-आधारित मॉडल प्रदान करते हैं{{spaced ndash}अप्रत्यक्ष रूप से संचायक को कॉपी करें, संचायक से अप्रत्यक्ष रूप से कॉपी करें।


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


: सीपीवाई (डी, आर<sub>s</sub>, डॉ<sub>d</sub> ) = स्रोत-रजिस्टर से सीधे गंतव्य-रजिस्टर पर कॉपी करें
: सीपीवाई (डी, आर<sub>s</sub>, डॉ<sub>d</sub> ) = स्रोत-रजिस्टर से सीधे गंतव्य-रजिस्टर पर कॉपी करें
Line 232: Line 232:
: सीपीवाई (आई, आर<sub>sp</sub>, मैं, आर<sub>dp</sub> ) = स्रोत-सूचक रजिस्टर r में पाए जाने वाले पते के साथ अप्रत्यक्ष रूप से स्रोत रजिस्टर की सामग्री को कॉपी करें<sub>sp</sub>, गंतव्य रजिस्टर में पते के साथ गंतव्य-सूचक रजिस्टर r में पाया जाना है<sub>dp</sub>)
: सीपीवाई (आई, आर<sub>sp</sub>, मैं, आर<sub>dp</sub> ) = स्रोत-सूचक रजिस्टर r में पाए जाने वाले पते के साथ अप्रत्यक्ष रूप से स्रोत रजिस्टर की सामग्री को कॉपी करें<sub>sp</sub>, गंतव्य रजिस्टर में पते के साथ गंतव्य-सूचक रजिस्टर r में पाया जाना है<sub>dp</sub>)


इसी तरह प्रत्येक तीन-रजिस्टर निर्देश जिसमें दो स्रोत रजिस्टर आर शामिल हैं<sub>s1</sub> r<sub>s2</sub> और  गंतव्य रजिस्टर आर<sub>d</sub> इसके परिणामस्वरूप 8 किस्में होंगी, उदाहरण के लिए अतिरिक्त:
इसी तरह प्रत्येक तीन-रजिस्टर निर्देश जिसमें दो स्रोत रजिस्टर आर सम्मिलित हैं<sub>s1</sub> r<sub>s2</sub> और  गंतव्य रजिस्टर आर<sub>d</sub> इसके परिणामस्वरूप 8 किस्में होंगी, उदाहरण के लिए अतिरिक्त:
:: [आर<sub>s1</sub>] + [आर<sub>s2</sub>] → आर<sub>d</sub>
:: [आर<sub>s1</sub>] + [आर<sub>s2</sub>] → आर<sub>d</sub>
निकलेगा:
निकलेगा:
Line 244: Line 244:
* जोड़ें (मैं, आर<sub>sp1</sub>, मैं, आर<sub>sp2</sub>, मैं, आर<sub>dp</sub> )
* जोड़ें (मैं, आर<sub>sp1</sub>, मैं, आर<sub>sp2</sub>, मैं, आर<sub>dp</sub> )


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


== संचायक A == की धारणा
== संचायक A == की धारणा
ऐतिहासिक सम्मेलन संचायक को  रजिस्टर समर्पित करता है,  अंकगणितीय अंग जो अंकगणितीय कार्यों के अनुक्रम के दौरान शाब्दिक रूप से अपनी संख्या जमा करता है:
ऐतिहासिक सम्मेलन संचायक को  रजिस्टर समर्पित करता है,  अंकगणितीय अंग जो अंकगणितीय कार्यों के अनुक्रम के समय शाब्दिक रूप से अपनी संख्या जमा करता है:
: हमारे अंकगणितीय अंग का पहला भाग ...  समानांतर भंडारण अंग होना चाहिए जो एक संख्या प्राप्त कर सकता है और इसे पहले से ही इसमें जोड़ सकता है, जो इसकी सामग्री को भी साफ़ करने में सक्षम है और जो इसमें शामिल है उसे संग्रहीत कर सकता है। ऐसे अंग को हम Accumulator कहेंगे। यह अतीत और वर्तमान में सबसे विविध प्रकार की कंप्यूटिंग मशीनों में सैद्धांतिक रूप से काफी पारंपरिक है, उदा। डेस्क गुणक, मानक आईबीएम काउंटर, अधिक आधुनिक रिले मशीनें, ENIAC (मूल में बोल्डफेस: गोल्डस्टाइन और वॉन न्यूमैन, 1946; बेल और नेवेल 1971 में पृष्ठ 98)।
: हमारे अंकगणितीय अंग का पहला भाग ...  समानांतर भंडारण अंग होना चाहिए जो एक संख्या प्राप्त कर सकता है और इसे पहले से ही इसमें जोड़ सकता है, जो इसकी सामग्री को भी साफ़ करने में सक्षम है और जो इसमें सम्मिलित है उसे संग्रहीत कर सकता है। ऐसे अंग को हम Accumulator कहेंगे। यह अतीत और वर्तमान में सबसे विविध प्रकार की कंप्यूटिंग मशीनों में सैद्धांतिक रूप से अधिक पारंपरिक है, उदा। डेस्क गुणक, मानक आईबीएम काउंटर, अधिक आधुनिक रिले मशीनें, ENIAC (मूल में बोल्डफेस: गोल्डस्टाइन और वॉन न्यूमैन, 1946; बेल और नेवेल 1971 में पृष्ठ 98)।


हालांकि, संचायक प्रति अंकगणितीय ऑपरेशन के अधिक निर्देशों की कीमत पर आता है, विशेष रूप से 'पढ़ें-संशोधित-लिखें' निर्देशों के संबंध में, जैसे कि इंक्रीमेंट अप्रत्यक्ष रूप से रजिस्टर की सामग्री को रजिस्टर r2 द्वारा इंगित किया जाता है। A संचायक रजिस्टर A को निर्दिष्ट करता है:
चूँकि, संचायक प्रति अंकगणितीय ऑपरेशन के अधिक निर्देशों की कीमत पर आता है, विशेष रूप से 'पढ़ें-संशोधित-लिखें' निर्देशों के संबंध में, जैसे कि इंक्रीमेंट अप्रत्यक्ष रूप से रजिस्टर की सामग्री को रजिस्टर r2 द्वारा इंगित किया जाता है। A संचायक रजिस्टर A को निर्दिष्ट करता है:


{|class="wikitable"
{|class="wikitable"
Line 296: Line 296:
यदि हम संचायक के लिए  विशिष्ट नाम से चिपके रहते हैं, उदा. ए, हम निर्देशों में संचायक को इंगित कर सकते हैं, उदाहरण के लिए,
यदि हम संचायक के लिए  विशिष्ट नाम से चिपके रहते हैं, उदा. ए, हम निर्देशों में संचायक को इंगित कर सकते हैं, उदाहरण के लिए,
: आईएनसी (ए) = आईएनसीए
: आईएनसी (ए) = आईएनसीए
हालाँकि, जब हम बिना संचायक के CPY निर्देश लिखते हैं तो निर्देश अस्पष्ट होते हैं या उनके पास खाली पैरामीटर होने चाहिए:
चूँकि, जब हम बिना संचायक के CPY निर्देश लिखते हैं तो निर्देश अस्पष्ट होते हैं या उनके पास खाली पैरामीटर होने चाहिए:
: सीपीवाई (डी, आर2, डी, ए) = सीपीवाई (डी, आर2, , )
: सीपीवाई (डी, आर2, डी, ए) = सीपीवाई (डी, आर2, , )
: सीपीवाई (डी, ए, डी, आर2) = सीपीवाई (,, डी, आर2)
: सीपीवाई (डी, ए, डी, आर2) = सीपीवाई (,, डी, आर2)


ऐतिहासिक रूप से क्या हुआ है कि इन दो सीपीवाई निर्देशों को विशिष्ट नाम प्राप्त हुए हैं; हालाँकि, कोई सम्मेलन मौजूद नहीं है। परंपरा (उदाहरण के लिए [[डोनाल्ड नुथ]] (1973) काल्पनिक [[मिक्स]] कंप्यूटर) लोड और स्टोर नामक दो नामों का उपयोग करती है। यहां हम i/d पैरामीटर जोड़ रहे हैं:
ऐतिहासिक रूप से क्या हुआ है कि इन दो सीपीवाई निर्देशों को विशिष्ट नाम प्राप्त हुए हैं; चूँकि, कोई सम्मेलन उपस्थित नहीं है। परंपरा (उदाहरण के लिए [[डोनाल्ड नुथ]] (1973) काल्पनिक [[मिक्स]] कंप्यूटर) लोड और स्टोर नामक दो नामों का उपयोग करती है। यहां हम i/d पैरामीटर जोड़ रहे हैं:
: एलडीए (डी/आई, आर<sub>s</sub> ) =<sub>def</sub> सीपीवाई (डी/आई, आर<sub>s</sub>, डी, ए)
: एलडीए (डी/आई, आर<sub>s</sub> ) =<sub>def</sub> सीपीवाई (डी/आई, आर<sub>s</sub>, डी, ए)
: एसटीए (डी/आई, आर<sub>d</sub> ) =<sub>def</sub> सीपीवाई (डी, ए, डी/आई, आर<sub>d</sub> )
: एसटीए (डी/आई, आर<sub>d</sub> ) =<sub>def</sub> सीपीवाई (डी, ए, डी/आई, आर<sub>d</sub> )
Line 309: Line 309:
: उदाहरण: मुला (आर<sub>s</sub>) = [ए] * [आर<sub>s</sub>] → ए
: उदाहरण: मुला (आर<sub>s</sub>) = [ए] * [आर<sub>s</sub>] → ए


यदि हम ऐसा चुनते हैं, तो हम mnemonics को संक्षिप्त कर सकते हैं क्योंकि कम से कम  स्रोत-रजिस्टर और गंतव्य रजिस्टर हमेशा संचायक A होता है। इस प्रकार हमारे पास है:
यदि हम ऐसा चुनते हैं, तो हम mnemonics को संक्षिप्त कर सकते हैं क्योंकि कम से कम  स्रोत-रजिस्टर और गंतव्य रजिस्टर सदैव संचायक A होता है। इस प्रकार हमारे पास है:
:{ एलडीए (आई/डी, आर<sub>s</sub>), एसटीए (आई / डी, आर<sub>d</sub>), सीएलआरए, आईएनसीए, डीईसीए, एडीडीए (आर<sub>s</sub>), सुबा (आर<sub>s</sub>), से (आर<sub>s</sub>), दिवा (आर<sub>s</sub>), वगैरह।)
:{ एलडीए (आई/डी, आर<sub>s</sub>), एसटीए (आई / डी, आर<sub>d</sub>), सीएलआरए, आईएनसीए, डीईसीए, एडीडीए (आर<sub>s</sub>), सुबा (आर<sub>s</sub>), से (आर<sub>s</sub>), दिवा (आर<sub>s</sub>), वगैरह।)


Line 317: Line 317:
न्यूनतम दृष्टिकोण स्वयं का उपयोग करना है (शॉनहेज ऐसा करता है)।
न्यूनतम दृष्टिकोण स्वयं का उपयोग करना है (शॉनहेज ऐसा करता है)।


एक अन्य दृष्टिकोण (शॉनहेज यह भी करता है)  विशिष्ट रजिस्टर को अप्रत्यक्ष पता रजिस्टर घोषित करना है और इस रजिस्टर के सापेक्ष अप्रत्यक्षता को सीमित करना है (स्कोनहेज का RAM0 मॉडल अप्रत्यक्ष और साथ ही प्रत्यक्ष निर्देशों के लिए ए और एन दोनों रजिस्टरों का उपयोग करता है)। फिर से हमारे नए रजिस्टर में कोई पारंपरिक नाम नहीं है{{spaced ndash}}शायद एन आईएनडीएक्स से, या इनडायरेक्ट या एड्रेस नंबर।
एक अन्य दृष्टिकोण (शॉनहेज यह भी करता है)  विशिष्ट रजिस्टर को अप्रत्यक्ष पता रजिस्टर घोषित करना है और इस रजिस्टर के सापेक्ष अप्रत्यक्षता को सीमित करना है (स्कोनहेज का RAM0 मॉडल अप्रत्यक्ष और साथ ही प्रत्यक्ष निर्देशों के लिए ए और एन दोनों रजिस्टरों का उपयोग करता है)। फिर से हमारे नए रजिस्टर में कोई पारंपरिक नाम नहीं है{{spaced ndash}}संभवतः एन आईएनडीएक्स से, या इनडायरेक्ट या एड्रेस नंबर।


अधिकतम लचीलेपन के लिए, जैसा कि हमने संचायक ए के लिए किया है{{spaced ndash}}हम एन को वेतन वृद्धि, कमी, स्पष्ट, परीक्षण, प्रत्यक्ष प्रति, आदि के लिए सिर्फ एक और रजिस्टर विषय मानेंगे। फिर से हम निर्देश को एकल-पैरामीटर में सिकोड़ सकते हैं जो दिशा और संकेत प्रदान करता है, उदाहरण के लिए।
अधिकतम लचीलेपन के लिए, जैसा कि हमने संचायक ए के लिए किया है{{spaced ndash}}हम एन को वेतन वृद्धि, कमी, स्पष्ट, परीक्षण, प्रत्यक्ष प्रति, आदि के लिए सिर्फ एक और रजिस्टर विषय मानेंगे। फिर से हम निर्देश को एकल-पैरामीटर में सिकोड़ सकते हैं जो दिशा और संकेत प्रदान करता है, उदाहरण के लिए।
Line 323: Line 323:
: STAN (i/d) = CPY (d, A, i/d, N)। स्टोर एक्यूमुलेटर इनडायरेक्शन रजिस्टर के माध्यम से
: STAN (i/d) = CPY (d, A, i/d, N)। स्टोर एक्यूमुलेटर इनडायरेक्शन रजिस्टर के माध्यम से


यह इतना दिलचस्प तरीका क्यों है? कम से कम दो कारण:
यह इतना रोचक विधि क्यों है? कम से कम दो कारण:


(1) बिना मापदंडों के  निर्देश सेट:
(1) बिना मापदंडों के  निर्देश सेट:
Line 331: Line 331:
(2) रैम को पोस्ट-ट्यूरिंग मशीन में कम करें:
(2) रैम को पोस्ट-ट्यूरिंग मशीन में कम करें:


अतिसूक्ष्मवादी के रूप में प्रस्तुत करते हुए, हम संचायक A और अप्रत्यक्ष रजिस्टर N को छोड़कर सभी रजिस्टरों को कम कर देते हैं उदा. r = {r0, r1, r2, ...} (बहुत-) परिबद्ध-क्षमता वाले कबूतर-छिद्रों की  असीमित स्ट्रिंग के लिए। ये कुछ भी नहीं करेंगे लेकिन (बहुत-) बंधे हुए नंबरों को पकड़ेंगे। मूल्य {0, 1} के साथ  अकेला बिट। इसी तरह हम संचायक को एक बिट तक सिकोड़ते हैं। हम किसी भी अंकगणित को रजिस्टरों {ए, एन} तक सीमित रखते हैं, रजिस्टरों की सामग्री को संचायक में खींचने के लिए अप्रत्यक्ष संचालन का उपयोग करते हैं और संचायक से रजिस्टर में 0 या 1 लिखते हैं:
अतिसूक्ष्मवादी के रूप में प्रस्तुत करते हुए, हम संचायक A और अप्रत्यक्ष रजिस्टर N को छोड़कर सभी रजिस्टरों को कम कर देते हैं उदा. r = {r0, r1, r2, ...} (बहुत-) परिबद्ध-क्षमता वाले कबूतर-छिद्रों की  असीमित स्ट्रिंग के लिए। ये कुछ भी नहीं करेंगे किन्तु (बहुत-) बंधे हुए नंबरों को पकड़ेंगे। मूल्य {0, 1} के साथ  अकेला बिट। इसी तरह हम संचायक को एक बिट तक सिकोड़ते हैं। हम किसी भी अंकगणित को रजिस्टरों {ए, एन} तक सीमित रखते हैं, रजिस्टरों की सामग्री को संचायक में खींचने के लिए अप्रत्यक्ष संचालन का उपयोग करते हैं और संचायक से रजिस्टर में 0 या 1 लिखते हैं:
:{एलडीए (आई, एन), एसटीए (आई, एन), सीएलआर (ए/एन), आईएनसी (ए/एन), डीईसी(एन), जेडजेड (ए/एन, आई<sub>z</sub>), जेडजेड (आई<sub>z</sub>), एच }
:{एलडीए (आई, एन), एसटीए (आई, एन), सीएलआर (ए/एन), आईएनसी (ए/एन), डीईसी(एन), जेडजेड (ए/एन, आई<sub>z</sub>), जेडजेड (आई<sub>z</sub>), एच }


Line 343: Line 343:
ऊपर दिए गए अनुभाग में हमने अनौपचारिक रूप से दिखाया कि  असीमित अप्रत्यक्ष क्षमता वाली रैम  पोस्ट-ट्यूरिंग मशीन का उत्पादन करती है। पोस्ट-ट्यूरिंग मशीन ट्यूरिंग समतुल्य है, इसलिए हमने दिखाया है कि अप्रत्यक्ष रैम ट्यूरिंग समतुल्य है।
ऊपर दिए गए अनुभाग में हमने अनौपचारिक रूप से दिखाया कि  असीमित अप्रत्यक्ष क्षमता वाली रैम  पोस्ट-ट्यूरिंग मशीन का उत्पादन करती है। पोस्ट-ट्यूरिंग मशीन ट्यूरिंग समतुल्य है, इसलिए हमने दिखाया है कि अप्रत्यक्ष रैम ट्यूरिंग समतुल्य है।


हम यहां थोड़ा और औपचारिक प्रदर्शन देते हैं। हमारे मॉडल को तीन आरक्षित रजिस्टरों E , P , और N के साथ डिजाइन करके शुरू करें, साथ ही दाईं ओर रजिस्टर 1, 2, ..., n का  असीमित सेट। रजिस्टर 1, 2, ..., n को टेप का वर्ग माना जाएगा। सिर वर्तमान में देख रहा है कि स्कैन वर्ग के लिए एन अंक दर्ज करें। सिर को सशर्त छलांग के रूप में माना जा सकता है{{spaced ndash}}ध्यान दें कि यह अप्रत्यक्ष संबोधन का उपयोग करता है (cf Elgot-Robinson p. 398)। जैसा कि हम एन को घटाते या बढ़ाते हैं (स्पष्ट) सिर वर्गों के साथ बाएं या दाएं चलेगा। हम अप्रत्यक्ष CPY का उपयोग करते हुए N द्वारा बताए गए अनुसार E = 0 या P = 1 की सामग्री को स्कैन किए गए वर्ग में ले जाएंगे।
हम यहां थोड़ा और औपचारिक प्रदर्शन देते हैं। हमारे मॉडल को तीन आरक्षित रजिस्टरों E , P , और N के साथ डिजाइन करके प्रारंभ करें, साथ ही दाईं ओर रजिस्टर 1, 2, ..., n का  असीमित सेट। रजिस्टर 1, 2, ..., n को टेप का वर्ग माना जाएगा। सिर वर्तमान में देख रहा है कि स्कैन वर्ग के लिए एन अंक अंकित करें। सिर को सशर्त छलांग के रूप में माना जा सकता है{{spaced ndash}}ध्यान दें कि यह अप्रत्यक्ष संबोधन का उपयोग करता है (cf Elgot-Robinson p. 398)। जैसा कि हम एन को घटाते या बढ़ाते हैं (स्पष्ट) सिर वर्गों के साथ बाएं या दाएं चलेगा। हम अप्रत्यक्ष CPY का उपयोग करते हुए N द्वारा बताए गए अनुसार E = 0 या P = 1 की सामग्री को स्कैन किए गए वर्ग में ले जाएंगे।


तथ्य यह है कि हमारा टेप बायीं ओर है, हमें  मामूली समस्या के साथ प्रस्तुत करता है: जब भी LEFT होता है तो हमारे निर्देशों को यह निर्धारित करने के लिए परीक्षण करना होगा कि N की सामग्री शून्य है या नहीं; यदि ऐसा है तो हमें इसकी गिनती 0 पर छोड़ देनी चाहिए (यह डिजाइनरों के रूप में हमारी पसंद है{{spaced ndash}}उदाहरण के लिए हमारे पास मशीन/मॉडल हमारे द्वारा चुनी गई घटना को ट्रिगर कर सकता है)।
तथ्य यह है कि हमारा टेप बायीं ओर है, हमें  सामान्य समस्या के साथ प्रस्तुत करता है: जब भी LEFT होता है तो हमारे निर्देशों को यह निर्धारित करने के लिए परीक्षण करना होगा कि N की सामग्री शून्य है या नहीं; यदि ऐसा है तो हमें इसकी गिनती 0 पर छोड़ देनी चाहिए (यह डिजाइनरों के रूप में हमारी पसंद है{{spaced ndash}}उदाहरण के लिए हमारे पास मशीन/मॉडल हमारे द्वारा चुनी गई घटना को ट्रिगर कर सकता है)।


: निर्देश सेट 1 (संवर्धित): { आईएनसी (एन), डीईसी (एन), सीएलआर (एन), सीपीवाई (डी, आर<sub>s</sub>,i, N), JZ (i, r, z ), HALT}
: निर्देश सेट 1 (संवर्धित): { आईएनसी (एन), डीईसी (एन), सीएलआर (एन), सीपीवाई (डी, आर<sub>s</sub>,i, N), JZ (i, r, z ), HALT}
Line 697: Line 697:


== उदाहरण: बंधा हुआ संकेत  ऐसी मशीन देता है जो ट्यूरिंग समकक्ष == नहीं है
== उदाहरण: बंधा हुआ संकेत  ऐसी मशीन देता है जो ट्यूरिंग समकक्ष == नहीं है
इस पूरे प्रदर्शन के दौरान हमें यह ध्यान रखना होगा कि परिमित राज्य मशीन की तालिका में दिए गए निर्देश परिमित हैं, अर्थात परिमित:
इस पूरे प्रदर्शन के समय हमें यह ध्यान रखना होगा कि परिमित स्तर मशीन की तालिका में दिए गए निर्देश परिमित हैं, अर्थात परिमित:
: केवल नियमों का  परिमित सेट होने के अलावा जो  विशिष्ट प्रकार की समस्या को हल करने के लिए संचालन का  क्रम देता है,  एल्गोरिथ्म में पांच महत्वपूर्ण विशेषताएं हैं [परिमितता, निश्चितता, इनपुट, आउटपुट, प्रभावशीलता] (इटैलिक जोड़ा गया, नुथ पी। 4- 7).
: केवल नियमों का  परिमित सेट होने के अतिरिक्त जो  विशिष्ट प्रकार की समस्या को हल करने के लिए संचालन का  क्रम देता है,  एल्गोरिथ्म में पांच महत्वपूर्ण विशेषताएं हैं [परिमितता, निश्चितता, इनपुट, आउटपुट, प्रभावशीलता] (इटैलिक जोड़ा गया, नुथ पी। 4- 7).


: कठिनाई उत्पन्न होती है क्योंकि रजिस्टरों में स्पष्ट नाम (संख्या) होते हैं और इसे एक्सेस करने के लिए हमारी मशीन को प्रत्येक को नाम से पुकारना चाहिए।
: कठिनाई उत्पन्न होती है क्योंकि रजिस्टरों में स्पष्ट नाम (संख्या) होते हैं और इसे एक्सेस करने के लिए हमारी मशीन को प्रत्येक को नाम से पुकारना चाहिए।
Line 704: Line 704:
हम CASE ऑपरेटर के साथ अप्रत्यक्ष CPY (i, q, d, φ) बनाएंगे। लक्ष्य रजिस्टर का पता रजिस्टर क्यू की सामग्री द्वारा निर्दिष्ट किया जाएगा; एक बार जब CASE ऑपरेटर यह निर्धारित कर लेता है कि यह संख्या क्या है, तो CPY उस संख्या के साथ रजिस्टर की सामग्री को सीधे रजिस्टर φ में जमा कर देगा। हमें  अतिरिक्त रजिस्टर की आवश्यकता होगी जिसे हम y कहेंगे{{spaced ndash}}यह  अप-काउंटर के रूप में कार्य करता है।
हम CASE ऑपरेटर के साथ अप्रत्यक्ष CPY (i, q, d, φ) बनाएंगे। लक्ष्य रजिस्टर का पता रजिस्टर क्यू की सामग्री द्वारा निर्दिष्ट किया जाएगा; एक बार जब CASE ऑपरेटर यह निर्धारित कर लेता है कि यह संख्या क्या है, तो CPY उस संख्या के साथ रजिस्टर की सामग्री को सीधे रजिस्टर φ में जमा कर देगा। हमें  अतिरिक्त रजिस्टर की आवश्यकता होगी जिसे हम y कहेंगे{{spaced ndash}}यह  अप-काउंटर के रूप में कार्य करता है।


: तो निम्नलिखित वास्तव में  रचनात्मक प्रदर्शन या सबूत है कि हम वास्तव में अप्रत्यक्ष सीपीवाई (i, q, d, φ) को हमारे काउंटर मशीन/मॉडल में हार्डवेयर डिज़ाइन परिवर्तन के बिना अनुकरण कर सकते हैं। हालाँकि, ध्यान दें कि क्योंकि यह अप्रत्यक्ष CPY परिमित राज्य मशीन के आकार/सीमा से घिरा है, इस अप्रत्यक्ष CPY का उपयोग करने वाला  RASP केवल [[आदिम पुनरावर्ती कार्य]]ों की गणना कर सकता है, mu पुनरावर्ती कार्यों के पूर्ण सूट की नहीं।
: तो निम्नलिखित वास्तव में  रचनात्मक प्रदर्शन या प्रमाण है कि हम वास्तव में अप्रत्यक्ष सीपीवाई (i, q, d, φ) को हमारे काउंटर मशीन/मॉडल में हार्डवेयर डिज़ाइन परिवर्तन के बिना अनुकरण कर सकते हैं। चूँकि, ध्यान दें कि क्योंकि यह अप्रत्यक्ष CPY परिमित स्तर मशीन के आकार/सीमा से घिरा है, इस अप्रत्यक्ष CPY का उपयोग करने वाला  आरएएसपी केवल [[आदिम पुनरावर्ती कार्य]]ों की गणना कर सकता है, mu पुनरावर्ती कार्यों के पूर्ण सूट की नहीं।


क्लेन (1952) (पृष्ठ 229) और बूलोस-बर्गेस-जेफरी (2002) (पृष्ठ 74) में CASE संचालक का वर्णन किया गया है; बाद के लेखक इसकी उपयोगिता पर जोर देते हैं। निम्नलिखित परिभाषा प्रति क्लेन है लेकिन परिचित IF-THEN-ELSE निर्माण को दर्शाने के लिए संशोधित की गई है।
क्लेन (1952) (पृष्ठ 229) और बूलोस-बर्गेस-जेफरी (2002) (पृष्ठ 74) में CASE संचालक का वर्णन किया गया है; बाद के लेखक इसकी उपयोगिता पर जोर देते हैं। निम्नलिखित परिभाषा प्रति क्लेन है किन्तु परिचित IF-THEN-ELSE निर्माण को दर्शाने के लिए संशोधित की गई है।


CASE ऑपरेटर  प्राकृतिक संख्या को φ में लौटाता है, जो इस बात पर निर्भर करता है कि कौन सा मामला संतुष्ट है, case_0 से शुरू होता है और क्रमिक रूप से case_last तक जाता है; यदि कोई मामला संतुष्ट नहीं होता है तो डिफ़ॉल्ट (उर्फ वूप्स) नामक संख्या को φ में वापस कर दिया जाता है (यहाँ 'x' मापदंडों के कुछ चयन को निर्दिष्ट करता है, उदाहरण के लिए q रजिस्टर करें और स्ट्रिंग r0, ... rlast )):
CASE ऑपरेटर  प्राकृतिक संख्या को φ में लौटाता है, जो इस बात पर निर्भर करता है कि कौन सा स्थिति संतुष्ट है, case_0 से प्रारंभ होता है और क्रमिक रूप से case_last तक जाता है; यदि कोई स्थिति संतुष्ट नहीं होता है तो डिफ़ॉल्ट (उर्फ वूप्स) नामक संख्या को φ में वापस कर दिया जाता है (यहाँ 'x' मापदंडों के कुछ चयन को निर्दिष्ट करता है, उदाहरण के लिए q रजिस्टर करें और स्ट्रिंग r0, ... rlast )):


मामलों द्वारा परिभाषा φ ('x', y):
स्थितियों द्वारा परिभाषा φ ('x', y):
:* case_0: IF Q<sub>0</sub>(x, y) तब φ सत्य है<sub>0</sub>(एक्स, वाई) अन्य
:* case_0: IF Q<sub>0</sub>(x, y) तब φ सत्य है<sub>0</sub>(एक्स, वाई) अन्य
:* case_1: IF Q<sub>1</sub>(x, y) तब φ सत्य है<sub>1</sub>(एक्स, वाई) अन्य
:* case_1: IF Q<sub>1</sub>(x, y) तब φ सत्य है<sub>1</sub>(एक्स, वाई) अन्य
Line 717: Line 717:
:* डिफ़ॉल्ट: φ करें<sub>default</sub>(एक्स, वाई)
:* डिफ़ॉल्ट: φ करें<sub>default</sub>(एक्स, वाई)


क्लेन की आवश्यकता है कि विधेय Q<sub>n</sub> कि परीक्षण करना सभी परस्पर अनन्य हैं{{spaced ndash}} विधेय ऐसे कार्य हैं जो आउटपुट के लिए केवल {true, false} उत्पन्न करते हैं; बूलोस-बर्गेस-जेफरी आवश्यकता को जोड़ते हैं कि मामले संपूर्ण हैं।
क्लेन की आवश्यकता है कि विधेय Q<sub>n</sub> कि परीक्षण करना सभी परस्पर अनन्य हैं{{spaced ndash}} विधेय ऐसे कार्य हैं जो आउटपुट के लिए केवल {true, false} उत्पन्न करते हैं; बूलोस-बर्गेस-जेफरी आवश्यकता को जोड़ते हैं कि स्थिति संपूर्ण हैं।


हम रजिस्टर क्यू में एक नंबर से शुरू करते हैं जो लक्ष्य रजिस्टर के पते का प्रतिनिधित्व करता है। लेकिन यह संख्या क्या है? विधेय यह पता लगाने के लिए परीक्षण करेगा, एक के बाद एक परीक्षण: JE (q, y, z) के बाद INC (y)। एक बार संख्या की स्पष्ट रूप से पहचान हो जाने के बाद, CASE ऑपरेटर सीधे/स्पष्ट रूप से इस रजिस्टर की सामग्री को φ में कॉपी कर लेता है:
हम रजिस्टर क्यू में एक नंबर से प्रारंभ करते हैं जो लक्ष्य रजिस्टर के पते का प्रतिनिधित्व करता है। किन्तु यह संख्या क्या है? विधेय यह पता लगाने के लिए परीक्षण करेगा, एक के बाद एक परीक्षण: JE (q, y, z) के बाद INC (y)। एक बार संख्या की स्पष्ट रूप से पहचान हो जाने के बाद, CASE ऑपरेटर सीधे/स्पष्ट रूप से इस रजिस्टर की सामग्री को φ में कॉपी कर लेता है:


: मामलों द्वारा परिभाषा CPY (i, q, d, φ) =<sub>def</sub> φ (q, r0, ..., अंतिम, y) =
: स्थितियों द्वारा परिभाषा CPY (i, q, d, φ) =<sub>def</sub> φ (q, r0, ..., अंतिम, y) =
:* case_0: अगर सीएलआर (y), [q] - [y]=0 तब CPY ( r0, φ ), J (निकास) ELSE
:* case_0: यदि सीएलआर (y), [q] - [y]=0 तब CPY ( r0, φ ), J (निकास) ELSE
:* case_1: IF INC (y), [q] = [y]=1 फिर CPY (r1, φ ), J (निकास) ELSE
:* case_1: IF INC (y), [q] = [y]=1 फिर CPY (r1, φ ), J (निकास) ELSE
:* case_2 केस n के माध्यम से: IF । . . तब । . . अन्य
:* case_2 केस n के माध्यम से: IF । . . तब । . . अन्य
Line 758: Line 758:
: * बाहर निकलें: आदि।
: * बाहर निकलें: आदि।


यदि CASE अनंत तक जारी रह सकता है तो यह [[ऑपरेटर में]] होगा। लेकिन यह नहीं हो सकता{{spaced ndash}}इसका परिमित राज्य मशीन राज्य रजिस्टर अपनी अधिकतम संख्या तक पहुँच गया है (65365 = 11111111,11111111 में)<sub>2</sub> ) या इसकी तालिका में निर्देश समाप्त हो गए हैं; आखिर यह  परिमित मशीन है।
यदि CASE अनंत तक जारी रह सकता है तो यह [[ऑपरेटर में]] होगा। किन्तु यह नहीं हो सकता{{spaced ndash}}इसका परिमित स्तर मशीन स्तर रजिस्टर अपनी अधिकतम संख्या तक पहुँच गया है (65365 = 11111111,11111111 में)<sub>2</sub> ) या इसकी तालिका में निर्देश समाप्त हो गए हैं; आखिर यह  परिमित मशीन है।


== मॉडल के उदाहरण ==
== मॉडल के उदाहरण ==


=== रजिस्टर-टू-रजिस्टर (पढ़ें-संशोधित-लिखें) कुक और रेकहो (1973) का मॉडल ===
=== रजिस्टर-टू-रजिस्टर (पढ़ें-संशोधित-लिखें) कुक और रेकहो (1973) का मॉडल ===
आम तौर पर सामने आने वाला कुक और रेचको मॉडल टर्नरी-रजिस्टर माल्ज़ेक मॉडल जैसा है (नूथ मेमोनिक्स के साथ लिखा गया है){{spaced ndash}}मूल निर्देशों में टीआरए, रीड, प्रिंट को छोड़कर कोई स्मृति चिन्ह नहीं था)।
सामान्यतः सामने आने वाला कुक और रेचको मॉडल टर्नरी-रजिस्टर माल्ज़ेक मॉडल जैसा है (नूथ मेमोनिक्स के साथ लिखा गया है){{spaced ndash}}मूल निर्देशों में टीआरए, रीड, प्रिंट को छोड़कर कोई स्मृति चिन्ह नहीं था)।


:*<code> LOAD ( C, r<sub>d</sub> ) ; C → r<sub>d</sub></code>, C कोई पूर्णांक है
:*<code> LOAD ( C, r<sub>d</sub> ) ; C → r<sub>d</sub></code>, C कोई पूर्णांक है
Line 773: Line 773:
:*<code> COPY ( i, r<sub>p</sub>, d, r<sub>d</sub> ) ; [[r<sub>p</sub>] ] →  r<sub>d</sub></code>, पॉइंटर-रजिस्टर आर द्वारा इंगित स्रोत-रजिस्टर की सामग्री को अप्रत्यक्ष रूप से कॉपी करें<sub>p</sub> गंतव्य रजिस्टर में।
:*<code> COPY ( i, r<sub>p</sub>, d, r<sub>d</sub> ) ; [[r<sub>p</sub>] ] →  r<sub>d</sub></code>, पॉइंटर-रजिस्टर आर द्वारा इंगित स्रोत-रजिस्टर की सामग्री को अप्रत्यक्ष रूप से कॉपी करें<sub>p</sub> गंतव्य रजिस्टर में।
:*<code> COPY ( d, r<sub>s</sub>, i, r<sub>p</sub> ) ; [r<sub>s</sub>] → [r<sub>p</sub>]</code>. स्रोत रजिस्टर आर की सामग्री की प्रतिलिपि बनाएँ<sub>s</sub> पॉइंटर-रजिस्टर आर द्वारा इंगित गंतव्य-रजिस्टर में<sub>p</sub>.
:*<code> COPY ( d, r<sub>s</sub>, i, r<sub>p</sub> ) ; [r<sub>s</sub>] → [r<sub>p</sub>]</code>. स्रोत रजिस्टर आर की सामग्री की प्रतिलिपि बनाएँ<sub>s</sub> पॉइंटर-रजिस्टर आर द्वारा इंगित गंतव्य-रजिस्टर में<sub>p</sub>.
:*<code> JNZ ( r, I<sub>z</sub> ) ;</code> सशर्त कूद अगर [आर] सकारात्मक है; यानी IF [r]> 0 फिर निर्देश z पर जाएं और अनुक्रम में जारी रखें (कुक और रेकहो इसे कॉल करें: Xj> 0 होने पर लाइन m पर नियंत्रण स्थानांतरित करें)
:*<code> JNZ ( r, I<sub>z</sub> ) ;</code> सशर्त कूद यदि [आर] सकारात्मक है; अर्थात IF [r]> 0 फिर निर्देश z पर जाएं और अनुक्रम में जारी रखें (कुक और रेकहो इसे कॉल करें: Xj> 0 होने पर लाइन m पर नियंत्रण स्थानांतरित करें)
:*<code> READ ( r<sub>d</sub> ) ;</code> इनपुट को गंतव्य रजिस्टर आर में कॉपी करें<sub>d</sub>
:*<code> READ ( r<sub>d</sub> ) ;</code> इनपुट को गंतव्य रजिस्टर आर में कॉपी करें<sub>d</sub>
:*<code> PRINT ( r<sub>s</sub> ) ;</code> स्रोत रजिस्टर आर की सामग्री की प्रतिलिपि बनाएँ<sub>s</sub> आउटपुट के लिए।
:*<code> PRINT ( r<sub>s</sub> ) ;</code> स्रोत रजिस्टर आर की सामग्री की प्रतिलिपि बनाएँ<sub>s</sub> आउटपुट के लिए।
Line 779: Line 779:
=== शॉनहेज का RAM0 और RAM1 (1980) ===
=== शॉनहेज का RAM0 और RAM1 (1980) ===
शॉनहेज (1980) अपने एसएमएम पॉइंटर मशीन मॉडल की समानता के प्रमाण के लिए चुने गए एक बहुत ही आदिम, परमाणु मॉडल का वर्णन करता है:
शॉनहेज (1980) अपने एसएमएम पॉइंटर मशीन मॉडल की समानता के प्रमाण के लिए चुने गए एक बहुत ही आदिम, परमाणु मॉडल का वर्णन करता है:
: किसी भी स्पष्ट संबोधन से बचने के लिए RAM0 में सामग्री z के साथ संचायक है और वर्तमान सामग्री n (शुरुआत में 0) (पृष्ठ 494) के साथ  अतिरिक्त पता रजिस्टर है।
: किसी भी स्पष्ट संबोधन से बचने के लिए RAM0 में सामग्री z के साथ संचायक है और वर्तमान सामग्री n (प्रारंभ में 0) (पृष्ठ 494) के साथ  अतिरिक्त पता रजिस्टर है।


'RAM1 मॉडल': शॉनहेज दर्शाता है कि कैसे उसके निर्माण का उपयोग अधिक सामान्य, प्रयोग करने योग्य उत्तराधिकारी-जैसे RAM बनाने के लिए किया जा सकता है (इस लेख के निमोनिक्स का उपयोग करके):
'RAM1 मॉडल': शॉनहेज दर्शाता है कि कैसे उसके निर्माण का उपयोग अधिक सामान्य, प्रयोग करने योग्य उत्तराधिकारी-जैसे RAM बनाने के लिए किया जा सकता है (इस लेख के निमोनिक्स का उपयोग करके):
Line 789: Line 789:
::*<code> JEA ( r, z ) ; IF [A] = [r] then I<sub>z</sub> else continue</code>
::*<code> JEA ( r, z ) ; IF [A] = [r] then I<sub>z</sub> else continue</code>
::*<code> INCA ; [A] + 1 --> A </code>
::*<code> INCA ; [A] + 1 --> A </code>
RAM0 मॉडल: Schönhage की RAM0 मशीन में 6 निर्देश हैं जो एक अक्षर से संकेतित हैं (छठे C xxx में 'स्किप ओवर नेक्स्ट पैरामीटर' शामिल है। Schönhage ने accumulator को z , N के साथ n , आदि के साथ नामित किया है। Schönhage के mnemonics के बजाय हम इसका उपयोग करेंगे स्मृति चिन्ह ऊपर विकसित हुआ।
RAM0 मॉडल: Schönhage की RAM0 मशीन में 6 निर्देश हैं जो एक अक्षर से संकेतित हैं (छठे C xxx में 'स्किप ओवर नेक्स्ट पैरामीटर' सम्मिलित है। Schönhage ने accumulator को z , N के साथ n , आदि के साथ नामित किया है। Schönhage के mnemonics के अतिरिक्त हम इसका उपयोग करेंगे स्मृति चिन्ह ऊपर विकसित हुआ।
::*<code>(Z), CLRA:  0 → A</code>
::*<code>(Z), CLRA:  0 → A</code>
::*<code>(A), INCA:  [A] +1 → A</code>
::*<code>(A), INCA:  [A] +1 → A</code>
::*<code>(N), CPYAN:  [A] → N</code>
::*<code>(N), CPYAN:  [A] → N</code>
::*<code>(A), LDAA: <nowiki>[[A]]</nowiki> → A </code>; पता पंजीकृत करने के लिए ए अंक की सामग्री; ए में रजिस्टर की सामग्री डालें
::*<code>(A), LDAA: <nowiki>[[A]]</nowiki> → A </code>; पता पंजीकृत करने के लिए ए अंक की सामग्री; ए में रजिस्टर की सामग्री डालें
::*<code>(S), STAN: [A] → [N] </code>; पता दर्ज करने के लिए एन अंक की सामग्री; ए की सामग्री को एन द्वारा इंगित रजिस्टर में रखें
::*<code>(S), STAN: [A] → [N] </code>; पता अंकित करने के लिए एन अंक की सामग्री; ए की सामग्री को एन द्वारा इंगित रजिस्टर में रखें
::*<code>(C), JAZ ( z ): [A] = 0 then go to I<sub>z</sub> </code>; उसके इलाज में अस्पष्ट
::*<code>(C), JAZ ( z ): [A] = 0 then go to I<sub>z</sub> </code>; उसके इलाज में अस्पष्ट


Line 802: Line 802:


=== परिमित बनाम असीम ===
=== परिमित बनाम असीम ===
निश्चित तथ्य यह है कि किसी भी प्रकार की काउंटर मशीन बिना असीमित रजिस्टर-एड्रेस रजिस्टर को नाम से  रजिस्टर आर निर्दिष्ट करना चाहिए, यह इंगित करता है कि मॉडल को परिमित होने के लिए आर की आवश्यकता है, हालांकि यह इस अर्थ में असीमित है कि मॉडल संख्या के लिए कोई ऊपरी सीमा नहीं दर्शाता है अपना कार्य करने के लिए आवश्यक रजिस्टरों की संख्या। उदाहरण के लिए, हमें r <83,617,563,821,029,283,746 और न ही r <2^1,000,001, आदि की आवश्यकता नहीं है।
निश्चित तथ्य यह है कि किसी भी प्रकार की काउंटर मशीन बिना असीमित रजिस्टर-एड्रेस रजिस्टर को नाम से  रजिस्टर आर निर्दिष्ट करना चाहिए, यह इंगित करता है कि मॉडल को परिमित होने के लिए आर की आवश्यकता है, चूँकि यह इस अर्थ में असीमित है कि मॉडल संख्या के लिए कोई ऊपरी सीमा नहीं दर्शाता है अपना कार्य करने के लिए आवश्यक रजिस्टरों की संख्या। उदाहरण के लिए, हमें r <83,617,563,821,029,283,746 और न ही r <2^1,000,001, आदि की आवश्यकता नहीं है।


: इस प्रकार हमारा मॉडल  निश्चित गणना करने के लिए आवश्यक होने पर रजिस्टरों की संख्या का विस्तार कर सकता है। हालांकि इसका मतलब यह है कि मॉडल जिस भी संख्या तक फैलता है वह परिमित होना चाहिए{{spaced ndash}} यह  प्राकृतिक संख्या के साथ अनुक्रमणीय होना चाहिए: ω कोई विकल्प नहीं है।
: इस प्रकार हमारा मॉडल  निश्चित गणना करने के लिए आवश्यक होने पर रजिस्टरों की संख्या का विस्तार कर सकता है। चूँकि इसका कारण यह है कि मॉडल जिस भी संख्या तक फैलता है वह परिमित होना चाहिए{{spaced ndash}} यह  प्राकृतिक संख्या के साथ अनुक्रमणीय होना चाहिए: ω कोई विकल्प नहीं है।


अप्रत्यक्ष पते को निर्दिष्ट करने वाले रजिस्टर का पता प्रदान करने के लिए हम  असीमित रजिस्टर प्रदान करके इस प्रतिबंध से बच सकते हैं।
अप्रत्यक्ष पते को निर्दिष्ट करने वाले रजिस्टर का पता प्रदान करने के लिए हम  असीमित रजिस्टर प्रदान करके इस प्रतिबंध से बच सकते हैं।

Revision as of 10:16, 17 May 2023

कंप्यूटर विज्ञान में, रैंडम-एक्सेस मशीन (रैम) रजिस्टर मशीन के सामान्य वर्ग में अमूर्त मशीन है। रैम काउंटर मशीन के समान ही है | किन्तु इसके रजिस्टरों के 'अप्रत्यक्ष पता' की अतिरिक्त क्षमता के साथ काउंटर मशीन की तरह, रैम के पास मशीन के परिमित-स्तर भाग (तथाकथित हार्वर्ड आर्किटेक्चर ) में इसके निर्देश हैं।

रैम यूनिवर्सल ट्यूरिंग मशीन के समान है | रजिस्टरों के साथ-साथ इसके डेटा में इसके कंप्यूटर प्रोग्राम के साथ को रैंडम-एक्सेस संग्रहित प्रोग्राम मशीन या आरएएसपी कहा जाता है। यह तथाकथित वॉन न्यूमैन आर्किटेक्चर का उदाहरण है और कंप्यूटर की सामान्य धारणा के सबसे निकट है।

कम्प्यूटेशनल जटिलता विश्लेषण के लिए ट्यूरिंग मशीन और काउंटर-मशीन मॉडल के साथ, रैम और आरएएसपी मॉडल का उपयोग किया जाता है। वैन एम्डे बोस (1990) इन तीन प्लस सूचक मशीन अनुक्रमिक मशीन मॉडल को कहते हैं | जिससे उन्हें समानांतर रैंडम-एक्सेस मशीन मॉडल से अलग किया जा सके।

मॉडल का परिचय

रैंडम एक्सेस मशीन (RAM) की अवधारणा सभी के सबसे सरल मॉडल, तथाकथित काउंटर मशीन मॉडल से प्रारंभ होती है। चूँकि, दो अतिरिक्त इसे काउंटर मशीन से दूर ले जाते हैं। पहले मशीन को अप्रत्यक्ष पते की सुविधा के साथ बढ़ाता है; दूसरा एक या एक से अधिक सहायक (समर्पित) रजिस्टरों के साथ मॉडल को अधिक पारंपरिक संचायक-आधारित कंप्यूटर की ओर ले जाता है, जिनमें से सबसे सामान्य को संचायक कहा जाता है।

औपचारिक परिभाषा

रैंडम-एक्सेस मशीन (रैम) अमूर्त कम्प्यूटेशनल-मशीन मॉडल है जो अप्रत्यक्ष एड्रेसिंग के साथ मल्टीपल-रजिस्टर काउंटर मशीन के समान है। अपने परिमित स्तर मशीन की टेबल से निर्देश के विवेक पर, मशीन एक लक्ष्य रजिस्टर का पता प्राप्त करती है या तो (i) सीधे निर्देश से, या (ii) अप्रत्यक्ष रूप से पॉइंटर रजिस्टर की सामग्री (जैसे संख्या, लेबल) से निर्दिष्ट होती है। निर्देश।

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

  • [आर] का कारण पता आर के साथ रजिस्टर की सामग्री है। यहाँ लेबल r चर है जिसे प्राकृतिक संख्या या अक्षर (जैसे A ) या एक नाम से भरा जा सकता है।
  • → का अर्थ है प्रतिलिपि/जमा करना, या प्रतिस्थापित करना, किन्तु स्रोत को नष्ट किए बिना
उदाहरण: [3] +1 → 3; का अर्थ है पते 3 के साथ स्रोत रजिस्टर की सामग्री, प्लस 1, पते 3 के साथ गंतव्य रजिस्टर में डाल दी जाती है (यहां स्रोत और गंतव्य एक ही स्थान हैं)। यदि [3]=37, अर्थात रजिस्टर 3 की सामग्री संख्या 37 है, तो 37+1 = 38 को रजिस्टर 3 में रखा जाएगा।
उदाहरण: [3] → 5; का अर्थ है पते 3 के साथ स्रोत रजिस्टर की सामग्री को पते 5 के साथ गंतव्य रजिस्टर में रखा गया है। यदि [3] = 38, अर्थात रजिस्टर 3 की सामग्री संख्या 38 है, तो यह संख्या रजिस्टर 5 में डाल दी जाएगी। रजिस्टर 3 की सामग्री इस ऑपरेशन से परेशान नहीं होती है, इसलिए [3] 38 बनी रहती है , अब [5] के समान है।

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

मानक/सम्मेलन की चाह के लिए यह लेख निर्देश में पैरामीटर (या पैरामीटर) के रूप में प्रत्यक्ष/अप्रत्यक्ष निर्दिष्ट करेगा, जिसे d/i के रूप में संक्षिप्त किया गया है:
उदाहरण: COPY ('डी', ए, 'आई', एन) का अर्थ सीधे 'डी' स्रोत रजिस्टर का पता प्राप्त करें (पंजीकरण ए) निर्देश से ही किन्तु अप्रत्यक्ष रूप से 'i' पॉइंटर-रजिस्टर एन से गंतव्य पता प्राप्त करें मान लीजिए [एन] = 3, तो रजिस्टर 3 गंतव्य है और निर्देश निम्नलिखित कार्य करेगा: [ए] → 3।

परिभाषा: स्रोत रजिस्टर की सामग्री का उपयोग निर्देश द्वारा किया जाता है। स्रोत रजिस्टर का पता या तो (i) सीधे निर्देश द्वारा निर्दिष्ट किया जा सकता है, या (ii) अप्रत्यक्ष रूप से निर्देश द्वारा निर्दिष्ट सूचक रजिस्टर द्वारा निर्दिष्ट किया जा सकता है।

परिभाषा: सूचक रजिस्टर की सामग्री लक्ष्य रजिस्टर का पता है।

परिभाषा: पॉइंटर रजिस्टर की सामग्री लक्ष्य रजिस्टर की ओर संकेत करती है – लक्ष्य या तो स्रोत या गंतव्य रजिस्टर हो सकता है।

परिभाषा: गंतव्य रजिस्टर वह स्थान है जहाँ निर्देश अपना परिणाम जमा करता है। स्रोत रजिस्टर का पता या तो (i) सीधे निर्देश द्वारा निर्दिष्ट किया जा सकता है, या (ii) अप्रत्यक्ष रूप से निर्देश द्वारा निर्दिष्ट सूचक रजिस्टर द्वारा निर्दिष्ट किया जा सकता है। स्रोत और गंतव्य रजिस्टर एक हो सकते हैं।

रिफ्रेशर: काउंटर-मशीन मॉडल

मेल्ज़क (1961) काउंटर मशीन का आसान दृश्य प्रदान करता है: इसके रजिस्टर जमीन में छेद होते हैं, और इन छेदों में कंकड़ होते हैं। निर्देश के अनुसार, इन छिद्रों में और बाहर कंप्यूटर (व्यक्ति या मशीन) कंकड़ जोड़ता है (INcrements) या हटाता है (DECrements)। आवश्यकतानुसार, अतिरिक्त कंकड़ आते हैं, और अतिरिक्त कंकड़ अनंत आपूर्ति में वापस चले जाते हैं; यदि छेद कंकड़ रखने के लिए बहुत छोटा है तो कंप्यूटर छेद को बड़ा खोदता है।
मिन्स्की (1961) और होपक्रॉफ्ट-उलमैन 1979 (पृ. 171) मल्टी-टेप ट्यूरिंग मशीन के विज़ुअलाइज़ेशन की प्रस्तुति करते हैं जिसमें रजिस्टरों के रूप में कई बाएं सिरे वाले टेप होते हैं। प्रत्येक टेप की लंबाई दाईं ओर असीमित है, और बाएं छोर को छोड़कर हर वर्ग खाली है, जिसे चिह्नित किया गया है। टेप-स्क्वायर की संख्या में मापी गई टेप के सिर की उसके बाएं छोर से दूरी, रजिस्टर में प्राकृतिक संख्या का प्रतिनिधित्व करती है। वर्गों की संख्या कम करने के लिए टेप हेड बाईं ओर खिसकता है; वृद्धि यह सही चलती है। टेप पर निशान छापने या मिटाने की कोई आवश्यकता नहीं है; जंप-इफ-मार्क निर्देश के साथ बाएं सिरे के निशान का परीक्षण करके यह देखने के लिए केवल सशर्त निर्देश हैं कि सिर बाएं छोर पर है या नहीं।
निम्नलिखित निर्देश mnemonics उदा। सीएलआर (आर) मनमानी हैं; कोई मानक उपस्थित नहीं है।

रजिस्टर मशीन के पास अपनी परिमित-स्तर मशीन के लिए बाहरी मेमोरी है – असीमित क्षमता वाले असतत और विशिष्ट रूप से लेबल किए गए स्थानों का असीमित (सीएफ: फुटनोट|गणनीय और असीमित) संग्रह, जिसे रजिस्टर कहा जाता है। इन रजिस्टरों में केवल प्राकृतिक संख्याएँ (शून्य और धनात्मक पूर्णांक) होती हैं। परिमित स्तर मशीन की तालिका में अनुक्रमिक निर्देशों की सूची के अनुसार, कुछ (जैसे 2) प्रकार के आदिम संचालन इन रजिस्टरों की सामग्री पर काम करते हैं। अंत में, IF-THEN-ELSE के रूप में सशर्त-अभिव्यक्ति एक या दो रजिस्टरों की सामग्री का परीक्षण करने के लिए उपलब्ध है और परिमित स्तर मशीन को डिफ़ॉल्ट निर्देश-अनुक्रम से बाहर शाखा / कूदती है।

'बेस मॉडल 1': मिन्स्की (1961) विज़ुअलाइज़ेशन और लैम्बेक (1961) के निकटतम मॉडल:

  • {रजिस्टर आर की वृद्धि सामग्री, रजिस्टर आर की गिरावट सामग्री, यदि रजिस्टर आर की सामग्री शून्य है तो निर्देश I पर जाएंz ELSE अगले निर्देश पर जारी रखें}:
Instruction Mnemonic Action on register(s) "r" Action on finite state machine's Instruction Register, IR
INCrement INC ( r ) [r] + 1 → r [IR] + 1 → IR
DECrement DEC ( r ) [r] - 1 → r [IR] + 1 → IR
Jump if Zero JZ ( r, z ) none IF [r] = 0 THEN z → IR ELSE [IR] + 1 → IR
Halt H none [IR] → IR

बेस मॉडल 2: उत्तराधिकारी मॉडल (पियानो सिद्धांतों के उत्तराधिकारी कार्य के नाम पर):

  • {रजिस्टर आर की सामग्री में वृद्धि, रजिस्टर आर की सामग्री को साफ करें, रजिस्टर आर की सामग्री आईएफj रजिस्टर आर की सामग्री के समान हैk फिर निर्देश I पर जाएंz ELSE गोटो अगले निर्देश के लिए }
Instruction Mnemonic Action on register(s) "r" Action on finite state machine's Instruction Register, IR
CLeaR CLR ( r ) 0 → r [IR] + 1 → IR
INCrement INC ( r ) [r] + 1 → r [IR] + 1 → IR
Jump if Equal JE (r1, r2, z) none IF [r1] = [r2] THEN z → IR ELSE [IR] + 1 → IR
Halt H none [IR] → IR

बेस मॉडल 3: एलगॉट-रॉबिन्सन (1964) द्वारा परिबद्ध और असंबद्ध आरएएसपी की जांच में उपयोग किया गया – CLEAR के स्थान पर COPY वाला उत्तराधिकारी मॉडल:

  • {रजिस्टर आर की सामग्री में वृद्धि, रजिस्टर आर की सामग्री की प्रतिलिपि बनाएँj आर अंकित करने के लिएk, यदि रजिस्टर आर की सामग्रीj रजिस्टर आर की सामग्री के समान हैk फिर निर्देश I पर जाएंz ELSE गोटो अगले निर्देश के लिए }
Instruction Mnemonic Action on register(s) "r" Action on finite state machine's Instruction Register, IR
COPY COPY (r1, r2) [r1] → r2 [IR] + 1 → IR
INCrement INC ( r ) [r] + 1 → r [IR] + 1 → IR
Jump if Equal JE (r1, r2, z) none IF [r1] = [r2] THEN z → IR ELSE [IR] + 1 → IR
Halt H none [IR] → IR


बेस सेट से सुविधा निर्देश बनाना

उपरोक्त तीन आधार सेट 1, 2, या 3 इस मायने में समतुल्य हैं कि कोई दूसरे सेट के निर्देशों का उपयोग करके सेट के निर्देश बना सकता है (एक रोचक अभ्यास: मिन्स्की से संकेत (1967) – आरक्षित रजिस्टर घोषित करें उदा. संख्या 0 को सम्मिलित करने के लिए इसे 0 (या शून्य के लिए Z या मिटाने के लिए E) पर कॉल करें)। मॉडल का चुनाव इस बात पर निर्भर करेगा कि लेखक को प्रदर्शन, या प्रमाण आदि में किसका उपयोग करना सबसे आसान लगता है।

इसके अतिरिक्त, आधार सेट 1, 2, या 3 से हम किसी भी आदिम पुनरावर्ती कार्यों (cf Minsky (1967), बूलोस-बर्गेस-जेफरी (2002)) को बना सकते हैं। (कुल और आंशिक mu पुनरावर्ती कार्यों को कैप्चर करने के लिए नेट को व्यापक कैसे बनाया जाए, इस पर अप्रत्यक्ष संबोधन के संदर्भ में चर्चा की जाएगी)। चूँकि, आदिम पुनरावर्ती कार्यों का निर्माण करना कठिनाई है क्योंकि निर्देश सेट इतने ... आदिम (छोटे) हैं। समाधान दूसरे सेट से सुविधा निर्देशों के साथ विशेष सेट का विस्तार करना है:

ये पारंपरिक अर्थों में सबरूटीन नहीं होंगे, किन्तु बेस सेट से बनाए गए निर्देशों के ब्लॉक होंगे और स्मरक दिया जाएगा। औपचारिक अर्थ में, इन ब्लॉकों का उपयोग करने के लिए हमें या तो (i) उन्हें उनके आधार-निर्देश समकक्षों में विस्तारित करने की आवश्यकता है – उन्हें अस्थायी या सहायक रजिस्टरों के उपयोग की आवश्यकता होगी, इसलिए मॉडल को इसे ध्यान में रखना चाहिए, या (ii) 'बिल्ट इन' निर्देशों के साथ हमारी मशीनों/मॉडलों को डिज़ाइन करना चाहिए।
उदाहरण: बेस सेट 1. सीएलआर (आर) बनाने के लिए निर्देशों के ब्लॉक का उपयोग करें, रजिस्टर आर को शून्य करने के लिए काउंट डाउन करें। ऊपर बताए गए संकेत के उपयोग पर ध्यान दें:
  • सीएलआर (आर) =equiv
  • पाश: JZ (आर, बाहर निकलें)
  • दिसंबर (आर)
  • JZ (0, लूप)
  • बाहर निकलें: आदि।

फिर से, यह सब केवल सुविधा के लिए है; इसमें से कोई भी मॉडल की आंतरिक शक्ति को नहीं बढ़ाता है।

उदाहरण के लिए: सबसे विस्तारित सेट में तीन सेटों से प्रत्येक अद्वितीय निर्देश सम्मिलित होगा, साथ ही बिना शर्त जम्प J (z) अर्थात:

  • { सीएलआर (आर), डीईसी (आर), आईएनसी (आर), सीपीवाई (आरs, आरd ), जेजेड (आर, जेड), जेई (आरj, आरk, जेड), जे (जेड)}

अधिकांश लेखक सशर्त छलांगों में से एक या दूसरे को चुनते हैं, उदा। शेफर्डसन-स्टर्गिस (1963) उपरोक्त सेट माइनस जेई का उपयोग करते हैं (बिल्कुल स्पष्ट होने के लिए वे जेएनजेड का उपयोग करते हैं){{spaced ndash}JZ के स्थान पर शून्य नहीं तो कूदें; अभी तक एक और संभावित सुविधा निर्देश)।

अप्रत्यक्ष संचालन

अप्रत्यक्ष संबोधन का उदाहरण

हमारे दैनिक जीवन में अप्रत्यक्ष संचालन की धारणा असामान्य नहीं है।

उदाहरण: खजाने की खोज।
स्थान पर टॉम_&_बेकी'स_केव_इन_पाइरेट_चेस्ट वह स्थान होगा जहां हम खजाने की ओर निर्देशित करने वाला नक्शा ढूंढ सकते हैं:
(1) हम टॉम_&_बेकी की गुफा... के स्थान पर जाते हैं और तब तक खुदाई करते हैं जब तक हमें लकड़ी का बक्सा नहीं मिल जाता
(2) बॉक्स के अंदर खजाने के स्थान का नक्शा है: थैचर के सामने_पोर्च के नीचे
(3) हम थैचर_फ्रंट_पोर्च के नीचे स्थान पर जाते हैं, जैकहैमर कंक्रीट को दूर करते हैं, और खजाने की खोज करते हैं: जंग लगी डोर-नॉब्स की एक बोरी।

अविवेक टॉम_&_बैकी'स_केव... में पाइरेट चेस्ट के रूप में पहचाने जाने वाले स्थान को निर्दिष्ट करता है जो किसी अन्य स्थान (स्वयं सहित) के लिए संकेतक के रूप में कार्य करता है: इसकी सामग्री (खजाने का नक्शा) लक्ष्य स्थान का पता प्रदान करता है

अंडर_थैचर_फ्रंट_पोर्च जहां वास्तविक कार्रवाई हो रही है।

=== अप्रत्यक्ष संचालन की आवश्यकता क्यों: काउंटर-मशीन मॉडल === के साथ दो प्रमुख समस्याएं निम्नलिखित में किसी को यह याद रखना चाहिए कि ये मॉडल भौतिक रूप से वास्तविक किसी भी चीज़ से दो मूलभूत अंतरों के साथ अमूर्त मॉडल हैं: असीम क्षमता वाले प्रत्येक रजिस्टर की असीमित संख्या। समस्या सबसे नाटकीय रूप से प्रकट होती है जब कोई आरएएसपी बनाने के लिए काउंटर-मशीन मॉडल का उपयोग करने की कोशिश करता है जो ट्यूरिंग पूर्णता है और इस प्रकार किसी आंशिक एमयू रिकर्सिव फ़ंक्शन की गणना करता है:

  • मेल्ज़ाक (1961) ने अपने होल-एंड-पेबल मॉडल में अप्रत्यक्ष रूप से जोड़ा जिससे उनका मॉडल संगणित गोटो के साथ खुद को संशोधित कर सके और इसके उपयोग के दो उदाहरण प्रदान करता है (डी के पैमाने में दशमलव प्रतिनिधित्व और परिमाण द्वारा छंटनी, चाहे इनका उपयोग किया गया हो) उनके प्रमाण में कि मॉडल ट्यूरिंग समतुल्य है, स्पष्ट नहीं है क्योंकि कार्यक्रम को पाठक के लिए अभ्यास के रूप में छोड़ दिया गया है (पृष्ठ 292)। मिन्स्की (1961, 1967) यह प्रदर्शित करने में सक्षम थे कि, उपयुक्त (किन्तु उपयोग में कठिनाई) गोडेल नंबर एन्कोडिंग के साथ, रजिस्टर मॉडल को ट्यूरिंग समतुल्य होने के लिए संकेत की आवश्यकता नहीं थी; किन्तु इसके लिए कम से कम असीमित रजिस्टर की आवश्यकता थी। जैसा कि नीचे उल्लेख किया गया है, मिंस्की (1967) आरएएसपी के लिए समस्या का संकेत देता है, किन्तु समाधान की प्रस्तुति नहीं करता है। एलगोट और रॉबिन्सन (1964) ने सिद्ध किया कि उनका आरएएसपी मॉडल P0 – इसकी कोई अप्रत्यक्ष क्षमता नहीं है – सभी पुनरावर्ती अनुक्रमिक कार्यों की गणना नहीं कर सकता है (जिनके मनमानी लंबाई के पैरामीटर हैं) यदि इसमें अपने स्वयं के निर्देशों को संशोधित करने की क्षमता नहीं है, किन्तु यह गोडेल संख्या के माध्यम से कर सकता है यदि यह करता है (पृष्ठ 395-397; विशेष रूप से चित्र 2 और फुटनोट पृष्ठ 395)। दूसरी ओर उनका आरएएसपी मॉडल P'0 इंडेक्स रजिस्टर (इनडायरेक्ट एड्रेसिंग) से लैस सभी आंशिक पुनरावर्ती अनुक्रमिक कार्यों (एमयू पुनरावर्ती कार्यों) की गणना कर सकता है (पृष्ठ 397-398)।
कुक एंड रेक्हो (1973) इसे सबसे संक्षेप में कहते हैं:
निश्चित कार्यक्रम के लिए अप्रत्यक्ष निर्देश आवश्यक हैं जिससे इनपुट में भिन्नता के रूप में रजिस्टरों की असीमित संख्या तक पहुंच हो सके। (पृष्ठ 73)
  • 'रजिस्टरों की असीमित क्षमता बनाम स्तर-मशीन निर्देशों की सीमित क्षमता': मशीन का तथाकथित परिमित स्तर हिस्सा माना जाता है – एल्गोरिदम की सामान्य परिभाषा के अनुसार{{spaced ndash}राज्यों (निर्देशों) की संख्या और निर्देशों के आकार (प्रतीकों/संकेतों को धारण करने की उनकी क्षमता) दोनों में बहुत सीमित है। तो कैसे स्तर मशीन इच्छानुसार से बड़े स्थिरांक को सीधे रजिस्टर में ले जाती है, उदा। मूव (के, आर) (आर रजिस्टर करने के लिए निरंतर के को स्थानांतरित करें)? यदि विशाल स्थिरांक आवश्यक हैं, तो उन्हें या तो स्वयं रजिस्टरों में प्रारंभ करना चाहिए या स्तर मशीन द्वारा निर्देशों की सीमित संख्या का उपयोग करके बनाया जाना चाहिए। INC और DEC का उपयोग करके गुणा करें और सबरूटीन्स जोड़ें (किन्तु इनमें से अर्ध-अनंत संख्या नहीं!)।
कभी-कभी सीएलआर (आर) के उपयोग के बाद आईएनसी (आर) बार-बार के बार के बाद निरंतर के बनाया जाएगा – उदा. स्थिर k = 3 को रजिस्टर r में रखने के लिए, अर्थात 3 → r, इसलिए निर्देश के अंत में [r] = 3: CLR (r), INC (r), INC (r), INC (r)। इस ट्रिक का उल्लेख क्लेन (1952) पृष्ठ द्वारा किया गया है। 223. समस्या तब उत्पन्न होती है जब बनाई जाने वाली संख्या परिमित स्तर मशीन के लिए उपलब्ध निर्देशों की संख्या को समाप्त कर देती है; परिमित स्तर मशीन के लिए उपलब्ध निर्देशों की संख्या की तुलना में सदैव एक बड़ा स्थिरांक होता है।
  • 'रजिस्टरों की असीमित संख्या बनाम बाध्य स्तर-मशीन निर्देश': यह पहली समस्या से अधिक गंभीर है। विशेष रूप से, यह समस्या तब उत्पन्न होती है जब हम तथाकथित आरएएसपी, सार्वभौमिक मशीन (यूनिवर्सल ट्यूरिंग मशीन पर अधिक देखें) बनाने का प्रयास करते हैं जो अपने परिमित-स्तर मशीन का उपयोग अपने रजिस्टरों में स्थित निर्देशों के कार्यक्रम की व्याख्या करने के लिए करती है। – अर्थात। हम वो बना रहे हैं जिसे आजकल वॉन न्यूमैन आर्किटेक्चर वाला कंप्यूटर कहा जाता है।
ध्यान दें कि काउंटर मशीन की परिमित स्तर मशीन को अपने नाम/संख्या से स्पष्ट रूप से (सीधे) रजिस्टर को कॉल करना चाहिए: INC (65,356) रजिस्टर संख्या 65,365 को स्पष्ट रूप से कॉल करता है। यदि रजिस्टरों की संख्या उन्हें संबोधित करने के लिए परिमित स्तर मशीन की क्षमता से अधिक है, तो सीमा के बाहर के रजिस्टर अगम्य होंगे। उदाहरण के लिए, यदि परिमित अवस्था मशीन केवल 65,536 = 2 तक पहुँच सकती है16 पंजीकृत है तो यह 65,537वें स्थान पर कैसे पहुंच सकता है?

तो हम परिमित स्तर मशीन की सीमा से परे रजिस्टर को कैसे संबोधित करते हैं? दृष्टिकोण प्रोग्राम-निर्देशों (रजिस्टरों में संग्रहीत) को संशोधित करना होगा जिससे उनमें एक से अधिक कमांड हों। किन्तु यह भी तब तक समाप्त हो सकता है जब तक कि कोई निर्देश (संभावित रूप से) असीमित आकार का न हो। तो क्यों न केवल über-निर्देश का उपयोग किया जाए – वास्तव में बहुत बड़ी संख्या – जिसमें प्रोग्राम के सभी निर्देश एन्कोडेड हैं! इस तरह मिन्स्की समस्या को हल करता है, किन्तु वह जिस गोडेल नंबरिंग का उपयोग करता है वह मॉडल के लिए बड़ी असुविधा का प्रतिनिधित्व करता है, और परिणाम संग्रहीत प्रोग्राम कंप्यूटर की हमारी सहज धारणा की तरह कुछ भी नहीं है।

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

अपने RPT (रिपीट) निर्देश का उपयोग करते हुए अधिक कंप्यूटर जैसे मॉडल के संदर्भ में मिन्स्की (1967) हमें समस्या के समाधान के साथ आकर्षित करता है (cf p. 214, p. 259) किन्तु कोई ठोस समाधान प्रदान नहीं करता है। वह प्रमाणित करता है:

सामान्यतः RPT ऑपरेशन मशीन के परिमित-स्तर भाग में निर्देश नहीं हो सकता है ... यह कंप्यूटर के परिमित भाग में अनुमत भंडारण की किसी विशेष मात्रा को समाप्त कर सकता है [sic, उसके RAM मॉडल के लिए उसका नाम]। RPT संचालन के लिए स्वयं के अनंत रजिस्टरों की आवश्यकता होती है। (पृष्ठ 214)।

वह हमें बाउंडेड आरपीटी प्रदान करता है जो सीएलआर (आर) और आईएनसी (आर) के साथ मिलकर किसी भी आदिम पुनरावर्ती फ़ंक्शन की गणना कर सकता है, और वह ऊपर उद्धृत अनबाउंड आरपीटी प्रदान करता है जो μ ऑपरेटर की भूमिका निभा रहा है; यह CLR (r) और INC (r) के साथ मिलकर mu पुनरावर्ती कार्यों की गणना कर सकता है। किन्तु वह परोक्ष या प्रति रैम मॉडल पर चर्चा नहीं करता है।

हार्टमैनिस (1971) के संदर्भों से ऐसा प्रतीत होता है कि कुक (यूसी बर्कले, 1970 में अपने व्याख्यान नोट्स में) ने अप्रत्यक्ष संबोधन की धारणा को शक्तिशाली किया है। यह कुक एंड रेक्हो (1973) के पेपर में स्पष्ट हो जाता है। – कुक रेक्हो के मास्टर के थीसिस सलाहकार हैं। हार्टमैनिस का मॉडल – मेल्ज़ाक के (1961) मॉडल के समान – दो और तीन-रजिस्टर जोड़ और घटाव और दो पैरामीटर प्रतियों का उपयोग करता है; कुक और रेकहो का मॉडल संचायक एसी के उपयोग से एक कॉल-आउट के लिए मापदंडों की संख्या (प्रोग्राम निर्देशों में बुलाए गए रजिस्टर) को कम करता है।

संक्षेप में समाधान: हमारी मशीन/मॉडल को असीमित संकेत के साथ डिज़ाइन करें – असीमित पता रजिस्टर प्रदान करें जो संभावित रूप से किसी भी रजिस्टर का नाम (कॉल आउट) कर सकता है, चाहे कितने भी हों। इसके लिए काम करने के लिए, सामान्य रूप से, असीमित रजिस्टर को साफ़ करने की क्षमता की आवश्यकता होती है और फिर संभावित अनंत लूप द्वारा वृद्धि (और संभवतः, कमी) की आवश्यकता होती है। इस अर्थ में समाधान असीमित μ ऑपरेटर का प्रतिनिधित्व करता है, जो आवश्यक होने पर, रजिस्टरों की असीमित स्ट्रिंग के साथ अनंत तक शिकार कर सकता है, जब तक कि वह जो ढूंढ रहा है उसे नहीं मिल जाता। पॉइंटर रजिस्टर बिल्कुल अपवाद के साथ किसी भी अन्य रजिस्टर की तरह है: अप्रत्यक्ष एड्रेसिंग कहलाने वाली परिस्थितियों में यह स्टेट मशीन के टेबल में एड्रेस-ऑपरेंड के अतिरिक्त अपनी सामग्री प्रदान करता है, लक्ष्य रजिस्टर का पता होने के लिए (संभवतः स्वयं सहित!) .

परिबद्ध संकेत और आदिम पुनरावर्ती कार्य

यदि हम रजिस्टर में राक्षस संख्या के मिन्स्की दृष्टिकोण से बचते हैं, और निर्दिष्ट करते हैं कि हमारा मशीन मॉडल कंप्यूटर की तरह होगा, तो हमें इस अप्रत्यक्ष समस्या का सामना करना होगा यदि हम पुनरावर्ती कार्यों की गणना कर रहे हैं (जिसे μ-पुनरावर्ती कार्य भी कहा जाता है) – कुल और आंशिक दोनों किस्में।

हमारा सरल काउंटर-मशीन मॉडल अप्रत्यक्ष रूप से बंधा हुआ रूप कर सकता है – और इस प्रकार आदिम पुनरावर्ती कार्यों के उप-वर्ग की गणना करें – डेफिनिशन बाय केस (क्लेन (1952) पृष्ठ 229 और बूलोस-बर्गेस-जेफरी पृष्ठ 74 में परिभाषित) नामक आदिम पुनरावर्ती संचालिका का उपयोग करके। ऐसा बंधा हुआ संकेत श्रमसाध्य, थकाऊ स्थिति है। स्थितियों की परिभाषा के लिए मशीन को पॉइंटर रजिस्टर की सामग्री को निर्धारित करने / अलग करने की आवश्यकता होती है, जब तक कि सफलता न मिल जाए, इस सामग्री को संख्या / नाम के खिलाफ मिलान करने के लिए, जिसे केस ऑपरेटर स्पष्ट रूप से घोषित करता है। इस प्रकार स्थितियों की परिभाषा उदा से प्रारंभ होती है। निचले बाउंड पते और मैच बनाने का प्रयास करने वाले ऊपरी बाउंड पते की ओर लगातार विज्ञापन जारी रहता है:

क्या रजिस्टर N में संख्या 0 के समान है? यदि नहीं तो क्या यह 1 के समान है? 2? 3? ... 65364? यदि नहीं तो हम अंतिम संख्या 65365 पर हैं और यह उत्तम होगा, अन्यथा हमें समस्या है!
बाउंडेड इनडायरेक्शन हमें आंशिक पुनरावर्ती कार्यों की गणना करने की अनुमति नहीं देगा –  उनके लिए हमें अनबाउंड इंडिकेशन उर्फ ​​​​μ ऑपरेटर की आवश्यकता है।
मान लीजिए कि हम 65367 नंबर पर जारी रखने में सक्षम थे, और वास्तव में उस रजिस्टर में वह था जिसकी हम तलाश कर रहे थे। तब हम अपनी गणना सफलतापूर्वक पूरी कर सकते थे! किन्तु मान लीजिए कि 65367 के पास वह नहीं है जिसकी हमें आवश्यकता है। हमें कितनी दूर जाना जारी रखना चाहिए?

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

असीम अप्रत्यक्ष और आंशिक पुनरावर्ती कार्य

अनबाउंड इंडिकेशन के लिए हमें अपने मशीन मॉडल में हार्डवेयर परिवर्तन की आवश्यकता होती है। एक बार जब हम यह परिवर्तन कर लेते हैं तो मॉडल काउंटर मशीन नहीं रह जाता है, किन्तु रैंडम-एक्सेस मशीन बन जाता है।

अब जब उदा. आईएनसी निर्दिष्ट है, परिमित स्तर मशीन के निर्देश को यह निर्दिष्ट करना होगा कि ब्याज के रजिस्टर का पता कहां से आएगा। यह या तो हो सकता है (i) स्तर मशीन का निर्देश जो स्पष्ट लेबल प्रदान करता है, या (ii) पॉइंटर-रजिस्टर जिसकी सामग्री रुचि का पता है। जब भी कोई निर्देश रजिस्टर पता निर्दिष्ट करता है तो उसे अब अतिरिक्त पैरामीटर i/d निर्दिष्ट करने की आवश्यकता होगी – अप्रत्यक्ष/प्रत्यक्ष। एक मायने में यह नया आई/डी पैरामीटर स्विच है जो निर्देश में निर्दिष्ट प्रत्यक्ष पता प्राप्त करने के लिए एक तरफ फ़्लिप करता है या पॉइंटर रजिस्टर से अप्रत्यक्ष पता प्राप्त करने का दूसरा विधि है (जो पॉइंटर रजिस्टर{{spaced ndash}कुछ मॉडलों में प्रत्येक रजिस्टर सूचक रजिस्टर हो सकता है – निर्देश द्वारा निर्दिष्ट किया गया है)। यह पारस्परिक रूप से अनन्य किन्तु संपूर्ण विकल्प स्थितियों द्वारा परिभाषा का एक और उदाहरण है, और नीचे दिए गए उदाहरण में दिखाया गया अंकगणितीय समकक्ष क्लेन (1952) पी में परिभाषा से लिया गया है। 229.

उदाहरण: सीपीवाई (अप्रत्यक्षsource, आरsource, प्रत्यक्षdestination, आरdestination )
डायरेक्ट एड्रेसिंग को d= 0 और इनडायरेक्ट एड्रेसिंग को i= 1 के रूप में निर्दिष्ट करने के लिए कोड असाइन करें। तब हमारी मशीन स्रोत का पता निम्नानुसार निर्धारित कर सकती है:
मैं * [आरs] + (1-आई)*आरs
उदाहरण के लिए, मान लीजिए कि रजिस्टर 3 की सामग्री 5 है (अर्थात [3]=5 ) और रजिस्टर 4 की सामग्री 2 है (अर्थात [4]=2 ):
उदाहरण: CPY (1, 3, 0, 4) = CPY (अप्रत्यक्ष, reg 3, प्रत्यक्ष, reg 4)
1*[3] + 0*3 = [3] = स्रोत-पंजीकरण पता 5
0*[4] + 1*4 = 4 = गंतव्य-पंजीकरण पता 4
उदाहरण: CPY ( 0, 3, 0, 4 )
0*[3] + 1*3 = 3 = स्रोत-पंजीकरण पता 3
0*[4] + 1*4 = 4 = गंतव्य-पंजीकरण पता 4
उदाहरण: CPY ( 0, 3, 1, 4 )
0*[3] + 1*3 = 3 = स्रोत-पंजीकरण पता 3
1 * [4] + 0 * 4 = [4] = गंतव्य-पंजीकरण पता 2

अप्रत्यक्ष कॉपी निर्देश

संभवतः जोड़े गए निर्देशों में सबसे उपयोगी है कॉपी। दरअसल, एलगॉट-रॉबिन्सन (1964) ने अपने मॉडल पी0 और पी'0 COPY निर्देशों के साथ, और Cook-Reckhow (1973) केवल दो अप्रत्यक्ष निर्देशों के साथ अपना संचायक-आधारित मॉडल प्रदान करते हैं{{spaced ndash}अप्रत्यक्ष रूप से संचायक को कॉपी करें, संचायक से अप्रत्यक्ष रूप से कॉपी करें।

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

सीपीवाई (डी, आरs, डॉd ) = स्रोत-रजिस्टर से सीधे गंतव्य-रजिस्टर पर कॉपी करें
सीपीवाई (आई, आरsp, डॉd ) = स्रोत-सूचक रजिस्टर आर में पाए जाने वाले स्रोत पते का उपयोग करके अप्रत्यक्ष रूप से गंतव्य-रजिस्टर पर कॉपी करेंsp.
सीपीवाई (डी, आरs, मैं, आरdp ) = गंतव्य-सूचक रजिस्टर आर में पाए जाने वाले गंतव्य पते का उपयोग करके अप्रत्यक्ष रूप से स्रोत-रजिस्टर की सामग्री को रजिस्टर में कॉपी करेंdp.
सीपीवाई (आई, आरsp, मैं, आरdp ) = स्रोत-सूचक रजिस्टर r में पाए जाने वाले पते के साथ अप्रत्यक्ष रूप से स्रोत रजिस्टर की सामग्री को कॉपी करेंsp, गंतव्य रजिस्टर में पते के साथ गंतव्य-सूचक रजिस्टर r में पाया जाना हैdp)

इसी तरह प्रत्येक तीन-रजिस्टर निर्देश जिसमें दो स्रोत रजिस्टर आर सम्मिलित हैंs1 rs2 और गंतव्य रजिस्टर आरd इसके परिणामस्वरूप 8 किस्में होंगी, उदाहरण के लिए अतिरिक्त:

[आरs1] + [आरs2] → आरd

निकलेगा:

  • जोड़ें (डी, आरs1, डॉs2, डॉd )
  • जोड़ें (मैं, आरsp1, डॉs2, डॉd )
  • जोड़ें (डी, आरs1, मैं, आरsp2, डॉd )
  • जोड़ें (मैं, आरsp1, मैं, आरsp2, डॉd )
  • जोड़ें (डी, आरs1, डॉs2, मैं, आरdp )
  • जोड़ें (मैं, आरsp1, डॉs2, मैं, आरdp )
  • जोड़ें (डी, आरs1, मैं, आरsp2, मैं, आरdp )
  • जोड़ें (मैं, आरsp1, मैं, आरsp2, मैं, आरdp )

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

== संचायक A == की धारणा ऐतिहासिक सम्मेलन संचायक को रजिस्टर समर्पित करता है, अंकगणितीय अंग जो अंकगणितीय कार्यों के अनुक्रम के समय शाब्दिक रूप से अपनी संख्या जमा करता है:

हमारे अंकगणितीय अंग का पहला भाग ... समानांतर भंडारण अंग होना चाहिए जो एक संख्या प्राप्त कर सकता है और इसे पहले से ही इसमें जोड़ सकता है, जो इसकी सामग्री को भी साफ़ करने में सक्षम है और जो इसमें सम्मिलित है उसे संग्रहीत कर सकता है। ऐसे अंग को हम Accumulator कहेंगे। यह अतीत और वर्तमान में सबसे विविध प्रकार की कंप्यूटिंग मशीनों में सैद्धांतिक रूप से अधिक पारंपरिक है, उदा। डेस्क गुणक, मानक आईबीएम काउंटर, अधिक आधुनिक रिले मशीनें, ENIAC (मूल में बोल्डफेस: गोल्डस्टाइन और वॉन न्यूमैन, 1946; बेल और नेवेल 1971 में पृष्ठ 98)।

चूँकि, संचायक प्रति अंकगणितीय ऑपरेशन के अधिक निर्देशों की कीमत पर आता है, विशेष रूप से 'पढ़ें-संशोधित-लिखें' निर्देशों के संबंध में, जैसे कि इंक्रीमेंट अप्रत्यक्ष रूप से रजिस्टर की सामग्री को रजिस्टर r2 द्वारा इंगित किया जाता है। A संचायक रजिस्टर A को निर्दिष्ट करता है:

Label Instruction A r2 r378,426 Description
. . . 378,426 17
INCi ( r2 ): CPY ( i, r2, d, A ) 17 378,426 17 Contents of r2 points to r378,426 with contents "17": copy this to A
INC ( A ) 18 378,426 17 Incement contents of A
CPY ( d, A, i, r2 ) 18 378,426 18 Contents of r2 points to r378,426: copy contents of A into r378,426

यदि हम संचायक के लिए विशिष्ट नाम से चिपके रहते हैं, उदा. ए, हम निर्देशों में संचायक को इंगित कर सकते हैं, उदाहरण के लिए,

आईएनसी (ए) = आईएनसीए

चूँकि, जब हम बिना संचायक के CPY निर्देश लिखते हैं तो निर्देश अस्पष्ट होते हैं या उनके पास खाली पैरामीटर होने चाहिए:

सीपीवाई (डी, आर2, डी, ए) = सीपीवाई (डी, आर2, , )
सीपीवाई (डी, ए, डी, आर2) = सीपीवाई (,, डी, आर2)

ऐतिहासिक रूप से क्या हुआ है कि इन दो सीपीवाई निर्देशों को विशिष्ट नाम प्राप्त हुए हैं; चूँकि, कोई सम्मेलन उपस्थित नहीं है। परंपरा (उदाहरण के लिए डोनाल्ड नुथ (1973) काल्पनिक मिक्स कंप्यूटर) लोड और स्टोर नामक दो नामों का उपयोग करती है। यहां हम i/d पैरामीटर जोड़ रहे हैं:

एलडीए (डी/आई, आरs ) =def सीपीवाई (डी/आई, आरs, डी, ए)
एसटीए (डी/आई, आरd ) =def सीपीवाई (डी, ए, डी/आई, आरd )

विशिष्ट संचायक-आधारित मॉडल में इसके सभी दो-चर अंकगणितीय और निरंतर संचालन होंगे (जैसे ADD (A, r), SUB (A, r) ) उपयोग (i) संचायक की सामग्री, साथ में (ii) निर्दिष्ट रजिस्टर की सामग्री . वन-वैरिएबल ऑपरेशंस (जैसे INC (A), DEC (A) और CLR (A) ) के लिए केवल संचायक की आवश्यकता होती है। दोनों निर्देश-प्रकार संचायक में परिणाम (जैसे योग, अंतर, उत्पाद, भागफल या शेष) जमा करते हैं।

उदाहरण: आईएनसीए = [ए] +1 → ए
उदाहरण: एडीडीए (आरs) = [ए] + [आरs] → ए
उदाहरण: मुला (आरs) = [ए] * [आरs] → ए

यदि हम ऐसा चुनते हैं, तो हम mnemonics को संक्षिप्त कर सकते हैं क्योंकि कम से कम स्रोत-रजिस्टर और गंतव्य रजिस्टर सदैव संचायक A होता है। इस प्रकार हमारे पास है:

{ एलडीए (आई/डी, आरs), एसटीए (आई / डी, आरd), सीएलआरए, आईएनसीए, डीईसीए, एडीडीए (आरs), सुबा (आरs), से (आरs), दिवा (आरs), वगैरह।)

== अप्रत्यक्ष पता रजिस्टर एन == की धारणा यदि हमारे मॉडल में असीमित संचायक है तो क्या हम अन्य सभी रजिस्टरों को बाध्य कर सकते हैं? जब तक हम कम से कम असीमित रजिस्टर प्रदान नहीं करते हैं जिससे हम अपने अप्रत्यक्ष पते प्राप्त करते हैं।

न्यूनतम दृष्टिकोण स्वयं का उपयोग करना है (शॉनहेज ऐसा करता है)।

एक अन्य दृष्टिकोण (शॉनहेज यह भी करता है) विशिष्ट रजिस्टर को अप्रत्यक्ष पता रजिस्टर घोषित करना है और इस रजिस्टर के सापेक्ष अप्रत्यक्षता को सीमित करना है (स्कोनहेज का RAM0 मॉडल अप्रत्यक्ष और साथ ही प्रत्यक्ष निर्देशों के लिए ए और एन दोनों रजिस्टरों का उपयोग करता है)। फिर से हमारे नए रजिस्टर में कोई पारंपरिक नाम नहीं है – संभवतः एन आईएनडीएक्स से, या इनडायरेक्ट या एड्रेस नंबर।

अधिकतम लचीलेपन के लिए, जैसा कि हमने संचायक ए के लिए किया है – हम एन को वेतन वृद्धि, कमी, स्पष्ट, परीक्षण, प्रत्यक्ष प्रति, आदि के लिए सिर्फ एक और रजिस्टर विषय मानेंगे। फिर से हम निर्देश को एकल-पैरामीटर में सिकोड़ सकते हैं जो दिशा और संकेत प्रदान करता है, उदाहरण के लिए।

एलडीएएन (आई/डी) = सीपीवाई (आई/डी, एन, डी, ए); लोड संचायक indirection रजिस्टर के माध्यम से
STAN (i/d) = CPY (d, A, i/d, N)। स्टोर एक्यूमुलेटर इनडायरेक्शन रजिस्टर के माध्यम से

यह इतना रोचक विधि क्यों है? कम से कम दो कारण:

(1) बिना मापदंडों के निर्देश सेट:

Schönhage अपने RAM0 निर्देश सेट को बनाने के लिए ऐसा करता है। नीचे अनुभाग देखें।

(2) रैम को पोस्ट-ट्यूरिंग मशीन में कम करें:

अतिसूक्ष्मवादी के रूप में प्रस्तुत करते हुए, हम संचायक A और अप्रत्यक्ष रजिस्टर N को छोड़कर सभी रजिस्टरों को कम कर देते हैं उदा. r = {r0, r1, r2, ...} (बहुत-) परिबद्ध-क्षमता वाले कबूतर-छिद्रों की असीमित स्ट्रिंग के लिए। ये कुछ भी नहीं करेंगे किन्तु (बहुत-) बंधे हुए नंबरों को पकड़ेंगे। मूल्य {0, 1} के साथ अकेला बिट। इसी तरह हम संचायक को एक बिट तक सिकोड़ते हैं। हम किसी भी अंकगणित को रजिस्टरों {ए, एन} तक सीमित रखते हैं, रजिस्टरों की सामग्री को संचायक में खींचने के लिए अप्रत्यक्ष संचालन का उपयोग करते हैं और संचायक से रजिस्टर में 0 या 1 लिखते हैं:

{एलडीए (आई, एन), एसटीए (आई, एन), सीएलआर (ए/एन), आईएनसी (ए/एन), डीईसी(एन), जेडजेड (ए/एन, आईz), जेडजेड (आईz), एच }

हम ERASE और PRINT: [ERASE]=0, [PRINT]=1 नामक दो स्थिर रजिस्टरों के उपयोग से A को और आगे बढ़ाते हैं और पूरी तरह से समाप्त कर देते हैं।

{सीपीवाई (डी, ईआरएएसई, आई, एन), सीपीवाई (डी, प्रिंट, आई, एन), सीएलआर (एन), आईएनसी (एन), डीईसी (एन), जेजेड (आई, एन, आईz), जेडजेड (आईz), एच }

COPY निर्देशों का नाम बदलें और INC (N) = राइट, DEC (N) = LEFT पर कॉल करें और हमारे पास पोस्ट-ट्यूरिंग मशीन के समान निर्देश हैं, साथ ही अतिरिक्त CLRN:

{ मिटाएं, प्रिंट करें, सीएलआरएन, दाएं, बाएं, जेजेड (आई, एन, आईz), जेडजेड (आईz), एच }

संकेत के साथ रैम की ट्यूरिंग समानता

ऊपर दिए गए अनुभाग में हमने अनौपचारिक रूप से दिखाया कि असीमित अप्रत्यक्ष क्षमता वाली रैम पोस्ट-ट्यूरिंग मशीन का उत्पादन करती है। पोस्ट-ट्यूरिंग मशीन ट्यूरिंग समतुल्य है, इसलिए हमने दिखाया है कि अप्रत्यक्ष रैम ट्यूरिंग समतुल्य है।

हम यहां थोड़ा और औपचारिक प्रदर्शन देते हैं। हमारे मॉडल को तीन आरक्षित रजिस्टरों E , P , और N के साथ डिजाइन करके प्रारंभ करें, साथ ही दाईं ओर रजिस्टर 1, 2, ..., n का असीमित सेट। रजिस्टर 1, 2, ..., n को टेप का वर्ग माना जाएगा। सिर वर्तमान में देख रहा है कि स्कैन वर्ग के लिए एन अंक अंकित करें। सिर को सशर्त छलांग के रूप में माना जा सकता है – ध्यान दें कि यह अप्रत्यक्ष संबोधन का उपयोग करता है (cf Elgot-Robinson p. 398)। जैसा कि हम एन को घटाते या बढ़ाते हैं (स्पष्ट) सिर वर्गों के साथ बाएं या दाएं चलेगा। हम अप्रत्यक्ष CPY का उपयोग करते हुए N द्वारा बताए गए अनुसार E = 0 या P = 1 की सामग्री को स्कैन किए गए वर्ग में ले जाएंगे।

तथ्य यह है कि हमारा टेप बायीं ओर है, हमें सामान्य समस्या के साथ प्रस्तुत करता है: जब भी LEFT होता है तो हमारे निर्देशों को यह निर्धारित करने के लिए परीक्षण करना होगा कि N की सामग्री शून्य है या नहीं; यदि ऐसा है तो हमें इसकी गिनती 0 पर छोड़ देनी चाहिए (यह डिजाइनरों के रूप में हमारी पसंद है – उदाहरण के लिए हमारे पास मशीन/मॉडल हमारे द्वारा चुनी गई घटना को ट्रिगर कर सकता है)।

निर्देश सेट 1 (संवर्धित): { आईएनसी (एन), डीईसी (एन), सीएलआर (एन), सीपीवाई (डी, आरs,i, N), JZ (i, r, z ), HALT}

निम्न तालिका दोनों पोस्ट-ट्यूरिंग निर्देशों को उनके रैम समकक्ष निर्देशों के संदर्भ में परिभाषित करती है और उनके कामकाज का उदाहरण देती है। रजिस्टर r0-r5 के टेप के साथ सिर का (स्पष्ट) स्थान। . . छायांकित दिखाया गया है:

Mnemonic label: E P N r0 r1 r2 r3 r4 r5 etc. Action on registers Action on finite state machine Instruction Register IR
start: 0 1 3 1 0
R right: INC ( N ) 0 1 4 1 0 [N] +1 → N [IR] +1 → IR
P print: CPY ( d, P, i, N ) 0 1 4 1 1 [P]=1 → [N]=r4 [IR] +1 → IR
E erase: CPY ( d, E, i, N ) 0 1 4 1 0 [E]=0 → [N]=r4 [IR] +1 → IR
L left: JZ ( i, N, end ) 0 1 4 1 0 none IF N =r4] =0 THEN "end" → IR else [IR]+1 → IR
DEC ( N ) 0 1 3 1 0 [N] -1 → N
J0 ( halt ) jump_if_blank: JZ ( i, N, end ) 0 1 3 1 0 none IF N =r3] =0 THEN "end" → IR else [IR]+1 → IR
J1 ( halt ) jump_if_mark: JZ ( i, N, halt ) 0 1 3 1 0 N =r3] → A IF N =r3] =0 THEN "end" → IR else [IR]+1 → IR
end . . . etc. 0 1 3 1 0
halt: H 0 1 3 1 0 none [IR] +1 → IR


== उदाहरण: बंधा हुआ संकेत ऐसी मशीन देता है जो ट्यूरिंग समकक्ष == नहीं है इस पूरे प्रदर्शन के समय हमें यह ध्यान रखना होगा कि परिमित स्तर मशीन की तालिका में दिए गए निर्देश परिमित हैं, अर्थात परिमित:

केवल नियमों का परिमित सेट होने के अतिरिक्त जो विशिष्ट प्रकार की समस्या को हल करने के लिए संचालन का क्रम देता है, एल्गोरिथ्म में पांच महत्वपूर्ण विशेषताएं हैं [परिमितता, निश्चितता, इनपुट, आउटपुट, प्रभावशीलता] (इटैलिक जोड़ा गया, नुथ पी। 4- 7).
कठिनाई उत्पन्न होती है क्योंकि रजिस्टरों में स्पष्ट नाम (संख्या) होते हैं और इसे एक्सेस करने के लिए हमारी मशीन को प्रत्येक को नाम से पुकारना चाहिए।

हम CASE ऑपरेटर के साथ अप्रत्यक्ष CPY (i, q, d, φ) बनाएंगे। लक्ष्य रजिस्टर का पता रजिस्टर क्यू की सामग्री द्वारा निर्दिष्ट किया जाएगा; एक बार जब CASE ऑपरेटर यह निर्धारित कर लेता है कि यह संख्या क्या है, तो CPY उस संख्या के साथ रजिस्टर की सामग्री को सीधे रजिस्टर φ में जमा कर देगा। हमें अतिरिक्त रजिस्टर की आवश्यकता होगी जिसे हम y कहेंगे – यह अप-काउंटर के रूप में कार्य करता है।

तो निम्नलिखित वास्तव में रचनात्मक प्रदर्शन या प्रमाण है कि हम वास्तव में अप्रत्यक्ष सीपीवाई (i, q, d, φ) को हमारे काउंटर मशीन/मॉडल में हार्डवेयर डिज़ाइन परिवर्तन के बिना अनुकरण कर सकते हैं। चूँकि, ध्यान दें कि क्योंकि यह अप्रत्यक्ष CPY परिमित स्तर मशीन के आकार/सीमा से घिरा है, इस अप्रत्यक्ष CPY का उपयोग करने वाला आरएएसपी केवल आदिम पुनरावर्ती कार्यों की गणना कर सकता है, mu पुनरावर्ती कार्यों के पूर्ण सूट की नहीं।

क्लेन (1952) (पृष्ठ 229) और बूलोस-बर्गेस-जेफरी (2002) (पृष्ठ 74) में CASE संचालक का वर्णन किया गया है; बाद के लेखक इसकी उपयोगिता पर जोर देते हैं। निम्नलिखित परिभाषा प्रति क्लेन है किन्तु परिचित IF-THEN-ELSE निर्माण को दर्शाने के लिए संशोधित की गई है।

CASE ऑपरेटर प्राकृतिक संख्या को φ में लौटाता है, जो इस बात पर निर्भर करता है कि कौन सा स्थिति संतुष्ट है, case_0 से प्रारंभ होता है और क्रमिक रूप से case_last तक जाता है; यदि कोई स्थिति संतुष्ट नहीं होता है तो डिफ़ॉल्ट (उर्फ वूप्स) नामक संख्या को φ में वापस कर दिया जाता है (यहाँ 'x' मापदंडों के कुछ चयन को निर्दिष्ट करता है, उदाहरण के लिए q रजिस्टर करें और स्ट्रिंग r0, ... rlast )):

स्थितियों द्वारा परिभाषा φ ('x', y):

  • case_0: IF Q0(x, y) तब φ सत्य है0(एक्स, वाई) अन्य
  • case_1: IF Q1(x, y) तब φ सत्य है1(एक्स, वाई) अन्य
  • Case_2 से case_next_to_last: आदि। . . . . . . . अन्य
  • case_last: IF Qlast(x, y) तब φ सत्य हैlast(एक्स, वाई) अन्य
  • डिफ़ॉल्ट: φ करेंdefault(एक्स, वाई)

क्लेन की आवश्यकता है कि विधेय Qn कि परीक्षण करना सभी परस्पर अनन्य हैं – विधेय ऐसे कार्य हैं जो आउटपुट के लिए केवल {true, false} उत्पन्न करते हैं; बूलोस-बर्गेस-जेफरी आवश्यकता को जोड़ते हैं कि स्थिति संपूर्ण हैं।

हम रजिस्टर क्यू में एक नंबर से प्रारंभ करते हैं जो लक्ष्य रजिस्टर के पते का प्रतिनिधित्व करता है। किन्तु यह संख्या क्या है? विधेय यह पता लगाने के लिए परीक्षण करेगा, एक के बाद एक परीक्षण: JE (q, y, z) के बाद INC (y)। एक बार संख्या की स्पष्ट रूप से पहचान हो जाने के बाद, CASE ऑपरेटर सीधे/स्पष्ट रूप से इस रजिस्टर की सामग्री को φ में कॉपी कर लेता है:

स्थितियों द्वारा परिभाषा CPY (i, q, d, φ) =def φ (q, r0, ..., अंतिम, y) =
  • case_0: यदि सीएलआर (y), [q] - [y]=0 तब CPY ( r0, φ ), J (निकास) ELSE
  • case_1: IF INC (y), [q] = [y]=1 फिर CPY (r1, φ ), J (निकास) ELSE
  • case_2 केस n के माध्यम से: IF । . . तब । . . अन्य
  • case_n: IF INC (y), [q] = [y]=n फिर CPY ( rn, φ ), J (निकास) ELSE
  • case_n+1 से case_last: IF । . . तब । . . अन्य
  • case_last: IF INC (y), [q] = [y]= last THEN CPY ( rlast, φ ), J (exit) ELSE
  • डिफ़ॉल्ट: वूप्स

Case_0 (y पर पुनरावर्तन का आधार चरण) इस तरह दिखता है:

* केस_0:
  • सीएलआर (वाई); रजिस्टर वाई = 0 सेट करें
  • जेई (क्यू, वाई, _φ0)
  • जे (केस_1)
  • _φ0: सीपीवाई (आर0, φ)
  • जे (बाहर निकलें)
  • case_1: आदि।

Case_n (इंडक्शन स्टेप) ऐसा दिखता है; याद रखें, n , n+1 , ..., अंतिम का प्रत्येक उदाहरण स्पष्ट प्राकृतिक संख्या होना चाहिए:

* केस_एन:
  • कांग्रेस (वाई)
  • जेई (क्यू, वाई, _φn)
  • जे (केस_एन+1)
  • _φn: सीपीवाई (आरएन, φ)
  • जे (बाहर निकलें)
  • केस__एन+1: आदि।

Case_last इंडक्शन को रोकता है और CASE ऑपरेटर को बाध्य करता है (और इस तरह अप्रत्यक्ष कॉपी ऑपरेटर को बाध्य करता है):

  • मामला_अंतिम:
  • कांग्रेस (वाई)
  • जेई ( क्यू, वाई, _φlast )
  • जे (उफ़)
  • _φlast: CPY ( rlast, φ )
  • जे (बाहर निकलें)
  • वूप्स: हम एक सीमा से बाहर के प्रयास को कैसे हैंडल करते हैं?
* बाहर निकलें: आदि।

यदि CASE अनंत तक जारी रह सकता है तो यह ऑपरेटर में होगा। किन्तु यह नहीं हो सकता – इसका परिमित स्तर मशीन स्तर रजिस्टर अपनी अधिकतम संख्या तक पहुँच गया है (65365 = 11111111,11111111 में)2 ) या इसकी तालिका में निर्देश समाप्त हो गए हैं; आखिर यह परिमित मशीन है।

मॉडल के उदाहरण

रजिस्टर-टू-रजिस्टर (पढ़ें-संशोधित-लिखें) कुक और रेकहो (1973) का मॉडल

सामान्यतः सामने आने वाला कुक और रेचको मॉडल टर्नरी-रजिस्टर माल्ज़ेक मॉडल जैसा है (नूथ मेमोनिक्स के साथ लिखा गया है) – मूल निर्देशों में टीआरए, रीड, प्रिंट को छोड़कर कोई स्मृति चिन्ह नहीं था)।

  • LOAD ( C, rd ) ; C → rd, C कोई पूर्णांक है
उदाहरण: LOAD ( 0, 5 ) रजिस्टर 5 को साफ़ करेगा।
  • ADD ( rs1, rs2, rd ) ; [rs1] + [rs2] → rd, रजिस्टर समान या भिन्न हो सकते हैं;
उदाहरण: ADD ( A, A, A ) रजिस्टर ए की सामग्री को दोगुना कर देगा।
  • SUB ( rs1, rs2, rd ) ; [rs1] - [rs2] → rd, रजिस्टर समान या भिन्न हो सकते हैं:
उदाहरण: SUB ( 3, 3, 3 ) रजिस्टर 3 को साफ़ करेगा।
  • COPY ( i, rp, d, rd ) ; [[rp] ] → rd, पॉइंटर-रजिस्टर आर द्वारा इंगित स्रोत-रजिस्टर की सामग्री को अप्रत्यक्ष रूप से कॉपी करेंp गंतव्य रजिस्टर में।
  • COPY ( d, rs, i, rp ) ; [rs] → [rp]. स्रोत रजिस्टर आर की सामग्री की प्रतिलिपि बनाएँs पॉइंटर-रजिस्टर आर द्वारा इंगित गंतव्य-रजिस्टर मेंp.
  • JNZ ( r, Iz ) ; सशर्त कूद यदि [आर] सकारात्मक है; अर्थात IF [r]> 0 फिर निर्देश z पर जाएं और अनुक्रम में जारी रखें (कुक और रेकहो इसे कॉल करें: Xj> 0 होने पर लाइन m पर नियंत्रण स्थानांतरित करें)
  • READ ( rd ) ; इनपुट को गंतव्य रजिस्टर आर में कॉपी करेंd
  • PRINT ( rs ) ; स्रोत रजिस्टर आर की सामग्री की प्रतिलिपि बनाएँs आउटपुट के लिए।

शॉनहेज का RAM0 और RAM1 (1980)

शॉनहेज (1980) अपने एसएमएम पॉइंटर मशीन मॉडल की समानता के प्रमाण के लिए चुने गए एक बहुत ही आदिम, परमाणु मॉडल का वर्णन करता है:

किसी भी स्पष्ट संबोधन से बचने के लिए RAM0 में सामग्री z के साथ संचायक है और वर्तमान सामग्री n (प्रारंभ में 0) (पृष्ठ 494) के साथ अतिरिक्त पता रजिस्टर है।

'RAM1 मॉडल': शॉनहेज दर्शाता है कि कैसे उसके निर्माण का उपयोग अधिक सामान्य, प्रयोग करने योग्य उत्तराधिकारी-जैसे RAM बनाने के लिए किया जा सकता है (इस लेख के निमोनिक्स का उपयोग करके):

  • LDA k ; k --> A , k स्थिरांक है, सुस्पष्ट संख्या जैसे कि 47
  • LDA ( d, r ) ; [r] → A ; सीधे लोड ए
  • LDA ( i, r ) ; [[r]] → A ; अप्रत्यक्ष रूप से लोड ए
  • STA ( d, r ) ; [A] → r ; सीधे स्टोर ए
  • STA ( i, r ) ; [A] → [r] ; अप्रत्यक्ष रूप से स्टोर ए
  • JEA ( r, z ) ; IF [A] = [r] then Iz else continue
  • INCA ; [A] + 1 --> A

RAM0 मॉडल: Schönhage की RAM0 मशीन में 6 निर्देश हैं जो एक अक्षर से संकेतित हैं (छठे C xxx में 'स्किप ओवर नेक्स्ट पैरामीटर' सम्मिलित है। Schönhage ने accumulator को z , N के साथ n , आदि के साथ नामित किया है। Schönhage के mnemonics के अतिरिक्त हम इसका उपयोग करेंगे स्मृति चिन्ह ऊपर विकसित हुआ।

  • (Z), CLRA: 0 → A
  • (A), INCA: [A] +1 → A
  • (N), CPYAN: [A] → N
  • (A), LDAA: [[A]] → A ; पता पंजीकृत करने के लिए ए अंक की सामग्री; ए में रजिस्टर की सामग्री डालें
  • (S), STAN: [A] → [N] ; पता अंकित करने के लिए एन अंक की सामग्री; ए की सामग्री को एन द्वारा इंगित रजिस्टर में रखें
  • (C), JAZ ( z ): [A] = 0 then go to Iz ; उसके इलाज में अस्पष्ट

संकेत (i) CPYAN से आता है (कॉपी / ट्रांसफर सामग्री A से N) store_A_via_N STAN के साथ काम कर रहा है, और (ii) अजीबोगरीब अप्रत्यक्ष निर्देश से LDAA ( [[A]] → [A] ).

फुटनोट्स

परिमित बनाम असीम

निश्चित तथ्य यह है कि किसी भी प्रकार की काउंटर मशीन बिना असीमित रजिस्टर-एड्रेस रजिस्टर को नाम से रजिस्टर आर निर्दिष्ट करना चाहिए, यह इंगित करता है कि मॉडल को परिमित होने के लिए आर की आवश्यकता है, चूँकि यह इस अर्थ में असीमित है कि मॉडल संख्या के लिए कोई ऊपरी सीमा नहीं दर्शाता है अपना कार्य करने के लिए आवश्यक रजिस्टरों की संख्या। उदाहरण के लिए, हमें r <83,617,563,821,029,283,746 और न ही r <2^1,000,001, आदि की आवश्यकता नहीं है।

इस प्रकार हमारा मॉडल निश्चित गणना करने के लिए आवश्यक होने पर रजिस्टरों की संख्या का विस्तार कर सकता है। चूँकि इसका कारण यह है कि मॉडल जिस भी संख्या तक फैलता है वह परिमित होना चाहिए – यह प्राकृतिक संख्या के साथ अनुक्रमणीय होना चाहिए: ω कोई विकल्प नहीं है।

अप्रत्यक्ष पते को निर्दिष्ट करने वाले रजिस्टर का पता प्रदान करने के लिए हम असीमित रजिस्टर प्रदान करके इस प्रतिबंध से बच सकते हैं।

यह भी देखें

बाहरी संबंध


संदर्भ

With a few exceptions, these references are the same as those at Register machine.

    • Goldstine, Herman H., and von Neumann, John, "Planning and Coding of the Problems for an Electronic Computing Instrument", Rep. 1947, Institute for Advanced Study, Princeton. Reprinted on pp. 92–119 in Bell, C. Gordon and Newell, Allen (1971), Computer Structures: Readings and Examples, McGraw-Hill Book Company, New York. ISBN 0-07-004357-4}.
  • George Boolos, John P. Burgess, Richard Jeffrey (2002), Computability and Logic: Fourth Edition, Cambridge University Press, Cambridge, England. The original Boolos-Jeffrey text has been extensively revised by Burgess: more advanced than an introductory textbook. "Abacus machine" model is extensively developed in Chapter 5 Abacus Computability; it is one of three models extensively treated and compared – the Turing machine (still in Boolos' original 4-tuple form) and recursion the other two.
  • Arthur Burks, Herman Goldstine, John von Neumann (1946), Preliminary discussion of the logical design of an electronic computing instrument, reprinted pp. 92ff in Gordon Bell and Allen Newell (1971), Computer Structures: Readings and Examples, mcGraw-Hill Book Company, New York. ISBN 0-07-004357-4 .
  • Stephen A. Cook and Robert A. Reckhow (1973), Time-bounded random access machines, Journal of Computer Systems Science 7(4):354-375.
  • Martin Davis (1958), Computability & Unsolvability, McGraw-Hill Book Company, Inc. New York.
  • Calvin Elgot and Abraham Robinson (1964), Random-Access Stored-Program Machines, an Approach to Programming Languages, Journal of the Association for Computing Machinery, Vol. 11, No. 4 (October, 1964), pp. 365–399.
  • J. Hartmanis (1971), "Computational Complexity of Random Access Stored Program Machines," Mathematical Systems Theory 5, 3 (1971) pp. 232–245.
  • John Hopcroft, Jeffrey Ullman (1979). Introduction to Automata Theory, Languages and Computation, 1st ed., Reading Mass: Addison-Wesley. ISBN 0-201-02988-X. A difficult book centered around the issues of machine-interpretation of "languages", NP-Completeness, etc.
  • Stephen Kleene (1952), Introduction to Metamathematics, North-Holland Publishing Company, Amsterdam, Netherlands. ISBN 0-7204-2103-9.
  • Donald Knuth (1968), The Art of Computer Programming, Second Edition 1973, Addison-Wesley, Reading, Massachusetts. Cf pages 462-463 where he defines "a new kind of abstract machine or 'automaton' which deals with linked structures."
  • Joachim Lambek (1961, received 15 June 1961), How to Program an Infinite Abacus, Mathematical Bulletin, vol. 4, no. 3. September 1961 pages 295-302. In his Appendix II, Lambek proposes a "formal definition of 'program'. He references Melzak (1961) and Kleene (1952) Introduction to Metamathematics.
  • Z. A. Melzak (1961, received 15 May 1961), An informal Arithmetical Approach to Computability and Computation, Canadian Mathematical Bulletin, vol. 4, no. 3. September 1961 pages 279-293. Melzak offers no references but acknowledges "the benefit of conversations with Drs. R. Hamming, D. McIlroy and V. Vyssots of the Bell telephone Laborators and with Dr. H. Wang of Oxford University."
  • Marvin Minsky (1961). "Recursive Unsolvability of Post's Problem of 'Tag' and Other Topics in Theory of Turing Machines". Annals of Mathematics. The Annals of Mathematics, Vol. 74, No. 3. 74 (3): 437–455. doi:10.2307/1970290. JSTOR 1970290.
  • Marvin Minsky (1967). Computation: Finite and Infinite Machines (1st ed.). Englewood Cliffs, N. J.: Prentice-Hall, Inc. In particular see chapter 11: Models Similar to Digital Computers and chapter 14: Very Simple Bases for Computability. In the former chapter he defines "Program machines" and in the later chapter he discusses "Universal Program machines with Two Registers" and "...with one register", etc.
  • John C. Shepherdson and H. E. Sturgis (1961) received December 1961 Computability of Recursive Functions, Journal of the Association for Computing Machinery (JACM) 10:217-255, 1963. An extremely valuable reference paper. In their Appendix A the authors cite 4 others with reference to "Minimality of Instructions Used in 4.1: Comparison with Similar Systems".
  • Kaphengst, Heinz, Eine Abstrakte programmgesteuerte Rechenmaschine', Zeitschrift fur mathematische Logik und Grundlagen der Mathematik:5 (1959), 366-379.
  • Ershov, A. P. On operator algorithms, (Russian) Dok. Akad. Nauk 122 (1958), 967-970. English translation, Automat. Express 1 (1959), 20-23.
  • Péter, Rózsa Graphschemata und rekursive Funktionen, Dialectica 12 (1958), 373.
  • Hermes, Hans Die Universalität programmgesteuerter Rechenmaschinen. Math.-Phys. Semsterberichte (Göttingen) 4 (1954), 42-53.
  • Arnold Schönhage (1980), Storage Modification Machines, Society for Industrial and Applied Mathematics, SIAM J. Comput. Vol. 9, No. 3, August 1980. Wherein Schōnhage shows the equivalence of his SMM with the "successor RAM" (Random Access Machine), etc. resp. Storage Modification Machines, in Theoretical Computer Science (1979), pp. 36–37
  • Peter van Emde Boas, "Machine Models and Simulations" pp. 3–66, in: Jan van Leeuwen, ed. Handbook of Theoretical Computer Science. Volume A: Algorithms and Complexity, The MIT PRESS/Elsevier, 1990. ISBN 0-444-88071-2 (volume A). QA 76.H279 1990. van Emde Boas's treatment of SMMs appears on pp. 32–35. This treatment clarifies Schōnhage 1980 – it closely follows but expands slightly the Schōnhage treatment. Both references may be needed for effective understanding.
  • Hao Wang (1957), A Variant to Turing's Theory of Computing Machines, JACM (Journal of the Association for Computing Machinery) 4; 63-92. Presented at the meeting of the Association, June 23–25, 1954.