रजिस्टर मशीन: Difference between revisions
m (10 revisions imported from alpha:रजिस्टर_मशीन) |
No edit summary |
||
| Line 486: | Line 486: | ||
*[http://www.igblan.free-online.co.uk/igblan/ca/minsky.html Igblan - Minsky Register Machines] | *[http://www.igblan.free-online.co.uk/igblan/ca/minsky.html Igblan - Minsky Register Machines] | ||
{{DEFAULTSORT:Register Machine}} | {{DEFAULTSORT:Register Machine}} | ||
[[Category:Commons category link is locally defined|Register Machine]] | |||
[[Category:Created On 17/02/2023|Register Machine]] | |||
[[Category: Machine | [[Category:Lua-based templates|Register Machine]] | ||
[[Category:Created On 17/02/2023]] | [[Category:Machine Translated Page|Register Machine]] | ||
[[Category:Vigyan Ready]] | [[Category:Multi-column templates|Register Machine]] | ||
[[Category:Pages using div col with small parameter|Register Machine]] | |||
[[Category:Pages with script errors|Register Machine]] | |||
[[Category:Short description with empty Wikidata description|Register Machine]] | |||
[[Category:Templates Vigyan Ready|Register Machine]] | |||
[[Category:Templates that add a tracking category|Register Machine]] | |||
[[Category:Templates that generate short descriptions|Register Machine]] | |||
[[Category:Templates using TemplateData|Register Machine]] | |||
[[Category:Templates using under-protected Lua modules|Register Machine]] | |||
[[Category:Wikipedia fully protected templates|Div col]] | |||
[[Category:गणना के मॉडल|Register Machine]] | |||
[[Category:रजिस्टर मशीन| रजिस्टर मशीन ]] | |||
Latest revision as of 18:03, 3 March 2023
गणितीय तर्क और सैद्धांतिक कंप्यूटर विज्ञान में रजिस्टर मशीन वर्चुअल मशीनों का सामान्य वर्ग है जिसका उपयोग ट्यूरिंग मशीन की सरल विधियो द्वारा किया जाता है। यह सभी प्रारूपों में ट्यूरिंग पूर्णता पर निर्भर रहती हैं।
अवलोकन
रजिस्टर मशीन को उसका नाम प्रोसेसर रजिस्टर के उपयोग से मिला हैं। ट्यूरिंग मशीन द्वारा उपयोग किए जाने वाले टेप और सिर के विपरीत यह मॉडल विशिष्ट रूप से संबोधित रजिस्टरों का उपयोग करता है, जिनमें से प्रत्येक में धनात्मक पूर्णांक होता है।
साहित्य रूप से कम से कम चार उप-वर्ग बनाए गए हैं, जिसमे सबसे विशेष रूप से कंप्यूटर के उपयोग के माध्यम से सबसे अधिक सरलता से सूचीबद्ध हैं:
- काउंटर मशीन - कंप्यूटर हार्डवेयर का सबसे विशेष और कम सैद्धांतिक मॉडल में किया जाता हैं। इसमें अप्रत्यक्ष संबोधन का अभाव रहता है। हार्वर्ड संरचना के तरीके में निर्देश परिमित स्थिति मशीन में हैं।
- सूचक मशीन - काउंटर मशीन और रैम मॉडल का मिश्रण किसी भी मॉडल की तुलना में कम सामान्य और अधिक वर्चुअल मिलता हैं। इस प्रकार हार्वर्ड संरचना की विधियों में निर्देश परिमित स्थिति मशीन में हैं।
- रैंडम-एक्सेस मशीन (रैम) - काउंटर मशीन जिसमें इनडायरेक्ट एड्रेसिंग और, सामान्यतः, संवर्धित निर्देश सेट होता है। हार्वर्ड संरचना के तरीके में निर्देश परिमित स्थिति मशीन में हैं।
- रैंडम-एक्सेस संग्रहीत प्रोग्राम मशीन मॉडल (आरएएसपी) - यूनिवर्सल ट्यूरिंग मशीन के अनुरूप अपने रजिस्टरों में निर्देशों के साथ रैम को उपयोग किया जाता हैं और इस प्रकार यह वॉन न्यूमैन संरचना का उदाहरण है। किन्तु कंप्यूटर के विपरीत, मॉडल प्रभावी रूप से अनंत रजिस्टरों के साथ आदर्श रूपों में उपयोग में लाया जाता हैं (और यदि उपयोग किया जाता है, तो प्रभावी रूप से अनंत विशेष रजिस्टर जैसे संचायक को संलग्न किया जाता हैं)। इस प्रकार कंप्यूटर की तुलना में, निर्देश सेट संख्या और जटिलता में बहुत कम होता है।
किसी भी प्रकार से सही से परिभाषित रजिस्टर मशीन मॉडल ट्यूरिंग के संलग्न पूर्णतयः होती है। इस प्रकार कम्प्यूटरीकृत गति से प्रारूपित यह मशीन विशेष रूप से निर्भर होती है।
व्यावहारिक कंप्यूटर विज्ञान में, समान अवधारणा जिसे वर्चुअल मशीन के रूप में जाना जाता है, जिसका उपयोग कभी-कभी अंतर्निहित मशीन की संरचना पर निर्भरता को कम करने के लिए किया जाता है। ऐसी मशीनों का उपयोग शिक्षण के लिए भी किया जाता है। रजिस्टर मशीन शब्द का प्रयोग कभी-कभी पाठ्यपुस्तकों में वर्चुअल मशीन को संदर्भित करने के लिए किया जाता है।[1]
औपचारिक परिभाषा
एक रजिस्टर मशीन में सम्मलित हैं:
- लेबल किए गए असतत, असीमित रजिस्टरों की असीमित संख्या सीमा (क्षमता) में असीमित: रजिस्टरों का परिमित (या कुछ मॉडलों में अनंत) सेट के प्रत्येक मान को अनंत सीमा तक माना जाता है और जिनमें से प्रत्येक में गैर-ऋणात्मक पूर्णांक (0, 1, 2, ...) होता है।[2] उक्त रजिस्टर स्वतः अंकगणितीय प्रक्रिया कर सकते हैं, या इससे अधिक विशेष रजिस्टर हो सकते हैं जो अंकगणितीय प्रक्रिया करते हैं। उदाहरण के लिए संचायक और/या पता रजिस्टर तथा रैंडम-एक्सेस मशीन इसका मुख्य उदाहरण हैं।
- 'टैली काउंटर या निशान':[3] असतत, अप्रभेद्य वस्तुएं या मॉडल के लिए उपयुक्त केवल प्रकार के निशान उपलब्ध रहते हैं। सबसे कम काउंटर मशीन मॉडल में, प्रत्येक अंकगणितीय ऑपरेशन के अनुसार केवल वस्तु/चिह्न को उसके स्थान/टेप से जोड़ा या हटाया जाता है। कुछ काउंटर मशीन मॉडल में (जैसे मेल्ज़ाक (1961), मिन्स्की (1961)) और अधिकांश रैम और आरएएसपी मॉडल में से अधिक ऑब्जेक्ट/मार्क को ऑपरेशन में जोड़ा या हटाया जा सकता है और सामान्यतः घटाव के लिए तथा कभी-कभी गुणा और/या भाग के साथ उपयोग किया जाता हैं। कुछ मॉडलों में नियंत्रण संचालन होते हैं जैसे कॉपी (विभिन्न: मूव, लोड, स्टोर) जो क्रिया में रजिस्टर से रजिस्टर करने के लिए ऑब्जेक्ट्स/मार्क्स के क्लंप को स्थानांतरित करते हैं।
- A (बहुत) निर्देशों का सीमित सेट: निर्देश दो वर्गों अंकगणित और नियंत्रण में विभाजित होते हैं। निर्देश-सेट बनाने के लिए निर्देश दो वर्गों से तैयार किए जाते हैं, जैसे कि निर्देश सेट को मॉडल को ट्यूरिंग समतुल्य होने की अनुमति देनी चाहिए (यह किसी भी आंशिक पुनरावर्ती फ़ंक्शन की गणना करने में सक्षम होना चाहिए)।
- अंकगणित: अंकगणितीय निर्देश सभी रजिस्टरों पर या सिर्फ विशेष रजिस्टर (जैसे संचायक) पर कार्य कर सकते हैं। वे सामान्यतः निम्नलिखित सेटों में से चुने जाते हैं (किन्तु अपवाद सामान्य हैं):
- काउंटर मशीन: { Increment (r), Decrement (r), Clear-to-zero (r) }
- RAM, RASP: { Increment (r), Decrement (r), Clear-to-zero (r), Load-immediate-constant k, Add (r1,r2), proper-Subtract (r1,r2), Increment accumulator, Decrement accumulator, Clear accumulator, Add to accumulator contents of register r, proper-Subtract from accumulator contents of register r, }
- संवर्धित रैम, रैस्प: सभी कम किए गए निर्देश प्लस: { Multiply, Divide, various Boolean bit-wise (left-shift, bit test, etc.)}
- नियंत्रण:
- काउंटर मशीन मॉडल: वैकल्पिक { Copy (r1,r2) }
- रैम और रैस्प मॉडल: अधिकांश में { Copy (r1,r2) }, or { Load Accumulator from r, Store accumulator into r, Load Accumulator with immediate constant }
- सभी मॉडल: रजिस्टर के परीक्षण के बाद कम से कम सशर्त छलांग (शाखा, गोटो)। { Jump-if-zero, Jump-if-not-zero (i.e. Jump-if-positive), Jump-if-equal, Jump-if-not equal }
- सभी प्रारूप वैकल्पिक हैं: { unconditional program jump (goto) }
- 'रजिस्टर-एड्रेसिंग विधि':
- काउंटर मशीन: कोई अप्रत्यक्ष संबोधन नहीं, अत्यधिक एटमाइज्ड मॉडल में तत्काल ऑपरेंड संभव है
- रैम और रैस्प: इनडायरेक्ट एड्रेसिंग उपलब्ध, तत्काल ऑपरेंड विशिष्ट
- 'इनपुट-आउटपुट': सभी मॉडलों में वैकल्पिक
- अंकगणित: अंकगणितीय निर्देश सभी रजिस्टरों पर या सिर्फ विशेष रजिस्टर (जैसे संचायक) पर कार्य कर सकते हैं। वे सामान्यतः निम्नलिखित सेटों में से चुने जाते हैं (किन्तु अपवाद सामान्य हैं):
- 'स्थिति रजिस्टर': विशेष निर्देश रजिस्टर आईआर, परिमित और उपरोक्त रजिस्टरों से अलग, वर्तमान निर्देश को निष्पादित करने के लिए संग्रहीत करता है और इसका पता निर्देशों की तालिका में होता है; यह रजिस्टर और इसकी तालिका परिमित अवस्था की मशीन में स्थित है।
- आईआर सभी मॉडलों के लिए ऑफ-लिमिट है। रैम और आरएएसपी की स्थिति में, रजिस्टर के पते का निर्धारण करने के प्रयोजनों के लिए, मॉडल या तो (i) सीधे संबोधित करने की स्थिति में उक्त तालिका द्वारा निर्दिष्ट पते और आईआर में अस्थायी रूप से स्थित (ii) का चयन कर सकता है। इस प्रकार अप्रत्यक्ष पते की स्थिति में आईआर के निर्देश द्वारा निर्दिष्ट रजिस्टर की सामग्री उपलब्ध हैं।
- आईआर रैस्प (या पारंपरिक कंप्यूटर) का प्रोग्राम काउंटर (PC) नहीं है। पीसी संचायक के समान और रजिस्टर है, किन्तु आरएएसपी के वर्तमान रजिस्टर-आधारित निर्देश की संख्या को धारण करने के लिए समर्पित है। इस प्रकार रैस्प के पास दो निर्देश/फंक्शन रजिस्टर होते हैं- (i) आईआर (परिमित स्थिति मशीन का निर्देश रजिस्टर), और (ii) रजिस्टरों में स्थित फंक्शन के लिए पीसी (प्रोग्राम काउंटर) के साथ ही साथ पीसी को समर्पित रजिस्टर, आरएएसपी प्रोग्राम-इंस्ट्रक्शन रजिस्टर (पीआईआर, आईआर, पीआर, आदि जैसे किसी भी नाम से जाने वाले) के लिए और रजिस्टर समर्पित कर सकता है।
- 'लेबल निर्देशों की सूची, सामान्यतः अनुक्रमिक क्रम में': निर्देशों की सीमित सूची . काउंटर मशीन, रैंडम-एक्सेस मशीन (रैम) और पॉइंटर मशीन की स्थिति में निर्देश स्टोर परिमित स्थिति मशीन की तालिका में है; इस प्रकार ये मॉडल हार्वर्ड संरचना के उदाहरण हैं। आरएएसपी की स्थिति में प्रोग्राम स्टोर रजिस्टरों में है; इस प्रकार यह वॉन न्यूमैन संरचना का उदाहरण है। रैंडम-एक्सेस मशीन और रैंडम-एक्सेस स्टोर-प्रोग्राम मशीन भी देखें।
सामान्यतः, कंप्यूटर प्रोग्राम की तरह, निर्देश अनुक्रमिक क्रम में सूचीबद्ध होते हैं; जब तक जम्पना सफल नहीं होता तब तक डिफ़ॉल्ट अनुक्रम संख्यात्मक क्रम में जारी रहता है। इसका अपवाद एबैकस (लैम्बेक (1961), मिन्स्की (1961)) काउंटर मशीन मॉडल है- प्रत्येक निर्देश में कम से कम अगला निर्देश पहचानकर्ता z होता है, और सशर्त शाखा में दो रूप होते हैं।- ध्यान दें कि अबेकस मॉडल दो निर्देशों को जोड़ता है, JZ फिर DEC: उदा. { INC ( r, z ), JZDEC ( r, ztrue, zfalse ) }.
सशर्त व्यंजक के बारे में अधिक जानकारी के लिए मैककार्थी औपचारिकता "IF r=0 THEN ztrue ELSE zfalse" (cf McCarthy (1960))
- ध्यान दें कि अबेकस मॉडल दो निर्देशों को जोड़ता है, JZ फिर DEC: उदा. { INC ( r, z ), JZDEC ( r, ztrue, zfalse ) }.
रजिस्टर मशीन मॉडल का ऐतिहासिक विकास
1950 के दशक की प्रारंभ में दो रुझान दिखाई दिए- पहला कंप्यूटर को ट्यूरिंग मशीन के रूप में चिह्नित करने के लिए, दूसरा कंप्यूटर जैसे मॉडल को परिभाषित करने के लिए-अनुक्रमिक निर्देश अनुक्रम और सशर्त जम्प वाले मॉडल-एक ट्यूरिंग मशीन की शक्ति के साथ, अर्ताथ तथाकथित ट्यूरिंग तुल्यता के साथ संलग्न रहकर कार्य करता हैं। इस कार्य की आवश्यकता दो कठिन समस्याओं के संदर्भ में की गई थी: एमिल पोस्ट द्वारा प्रस्तुत अघुलनशील शब्द समस्या- टैग की उनकी समस्या और हिल्बर्ट की समस्याओं की बहुत कठिन समस्या डायोफैंटाइन समीकरण के आसपास 10वां प्रश्न हैं। शोधकर्ता ट्यूरिंग-समतुल्य मॉडल की खोज कर रहे थे जो प्रकृति में कम तार्किक और अधिक अंकगणितीय थे।
पहली प्रवृत्ति-कंप्यूटर के लक्षण वर्णन के समान लगती है,[4] हैंस हेमीज़ (1954), रोज़ा पेटर (1958), और हेंज कफेंग्स्ट (1959) के साथ, हाओ वांग (अकादमिक) (1954, 1957) के साथ दूसरी प्रवृत्ति और, जैसा कि ऊपर उल्लेख किया गया है।
पिछले पांच नामों को स्पष्ट रूप से यूरी मटियासेविच द्वारा उसी क्रम में सूचीबद्ध किया गया है। वह इसके साथ चलता है:
- रजिस्टर मशीनें जिनमें कुछ लेखक काउंटर-मशीन के पर्यायवाची रजिस्टर मशीन का उपयोग करते हैं, डायोफैंटाइन समीकरणों के निर्माण के लिए विशेष रूप से उपयुक्त हैं। ट्यूरिंग मशीनों की तरह, उनके पास बहुत ही विशेष निर्देश हैं और, इसके अलावा, वे संख्याओं से निपटते हैं (यूरी मटियासेविच (1993), हिल्बर्ट की दसवीं समस्या, पुस्तक के अध्याय 5 की टिप्पणी, http://logic.pdmi.ras.ru/ पर युमैट/H10Pbook/commch_5htm.)
इस प्रकार ऐसा प्रतीत होता है कि लैम्बेक, मेल्ज़ाक, मिंस्की और शेफर्डसन और स्टर्गिस ने स्वतंत्र रूप से ही समय में ही विचार का अनुमान लगाया था। इस वरीयता के लिए नीचे दी हुई टिप्पणी देखें। इस इतिहास की प्रारंभ वांग के मॉडल से होती है।
वांग का (1954, 1957) मॉडल: पोस्ट-ट्यूरिंग मशीन
वैंग का कार्य एमिल पोस्ट (1936) के पेपर से हुआ और वैंग को उनकी वैंग बी-मशीन की परिभाषा तक ले गया- दो-प्रतीक पोस्ट-ट्यूरिंग मशीन कम्प्यूटेशन मॉडल जिसमें केवल चार परमाणु निर्देश थे:
- { LEFT, RIGHT, PRINT, JUMP_if_marked_to_instruction_z }
इन चारों को दोनों वांग (1954, 1957) और फिर सी. वाई. ली (1961) ने पोस्ट सेट {ERASE} से और निर्देश जोड़ा, और फिर पोस्ट की बिना शर्त छलांग {JUMP_to_instruction_z} (या चीजों को सरल बनाने के लिए, JUMP_IF_blank_to_instruction_z, या दोनों। ली ने इसे डब्ल्यू-मशीन मॉडल का नाम दिया:
- { LEFT, RIGHT, PRINT, ERASE, JUMP_if_marked, [maybe JUMP or JUMP_IF_blank] }
वांग ने आशा व्यक्त की कि उनका मॉडल ट्यूरिंग मशीनों के सिद्धांत और कंप्यूटर की व्यावहारिक दुनिया के बीच तालमेल (पृ. 63) होगा।
वांग का कार्य अत्यधिक प्रभावशाली था। हम उसे मिंस्की (1961) और (1967), मेल्ज़ाक (1961), शेफर्डसन और स्टर्गिस (1963) द्वारा संदर्भित पाते हैं। वास्तव में, शेफर्डसन और स्टर्गिस (1963) टिप्पणी करते हैं कि:
- ... हमने वैंग द्वारा सुझाई गई संगणना के व्यावहारिक और सैद्धांतिक पहलुओं के बीच कदम और आगे बढ़ने का प्रयास किया है।
मार्टिन डेविस (गणितज्ञ) ने अंततः इस मॉडल को (2-प्रतीक) पोस्ट-ट्यूरिंग मशीन में विकसित किया।
वैंग/पोस्ट-ट्यूरिंग मॉडल के साथ कठिनाइयाँ:
सिवाय इसके कि कोई समस्या थी: वांग मॉडल (7-निर्देश पोस्ट-ट्यूरिंग मशीन के छह निर्देश) अभी भी एकल-टेप ट्यूरिंग-जैसी डिवाइस थी, चूंकि इसका क्रमिक फंक्शन निर्देश-प्रवाह अच्छा हो सकता है। मेलज़क (1961) और शेफर्डसन और स्टर्गिस (1963) दोनों ने इसे देखा (कुछ तथ्यों और जांच के संदर्भ में) ट्यूरिंग मशीन में निश्चित अपारदर्शिता होती है। ट्यूरिंग मशीन (काल्पनिक) संचालन में धीमी होती है और सामान्यतः जटिल होती है। इससे इसे डिजाइन करना कठिन हो जाता है, और समय या भंडारण अनुकूलन या दो एल्गोरिदम की दक्षता के बीच तुलना जैसे स्थितियों की जांच करना भी कठिन हो जाता है।
चूंकि इसमें किसी प्रकार की कठिनाई नहीं है, यह मुख्यतः प्रमाण दो कारणों से जटिल रहते हैं: (1) ट्यूरिंग मशीन में केवल सिर होता है जिससे कि अंक पर संचालन के बहुत छोटे चरणों में गणना को तोड़ने के लिए बाध्य हो . (2) इसमें केवल टेप होता है जिससे किसी को उस नंबर को खोजने के लिए कुछ परेशानी में पड़ना पड़ता है जिस पर वह कार्य करता है और उसे अन्य संख्याओं से अलग रखता है।
मुख्य रूप से ट्यूरिंग मशीन के उदाहरण, पोस्ट-ट्यूरिंग मशीन और आंशिक फ़ंक्शन शो के उदाहरण के रूप में, कार्य जटिल हो सकता है।
मिन्स्की, मेल्ज़ाक-लैम्बेक और शेफर्डसन-स्टर्गिस मॉडल ने टेप को कई प्रकार से काटा था
इस प्रकार क्यों न 'टेप को काटें' जिससे कि प्रत्येक असीम रूप से लंबा हो (किसी भी आकार के पूर्णांक को समायोजित करने के लिए) किन्तु बाएँ सिरे पर, और इन तीन टेपों को पोस्ट-ट्यूरिंग (अर्ताथ वैंग-जैसे) टेप कहें? व्यक्तिगत शीर्ष बाएं (घटाने के लिए) और दाएं (वेतन वृद्धि के लिए) चलेंगे। इस प्रकार से शीर्ष, जुड़े हुए चिह्नों के ढेर के शीर्ष को इंगित करते हैं या मिन्स्की (1961) और होपक्रॉफ्ट और उलमैन (1979, पृ. 171ff) में टेप सदैव खाली रहता है जिसके अतिरिक्त बाएं छोर पर निशान लगा के किसी भी समय कोई हेड प्रिंट या मिटाता नहीं है।
हमें केवल अपने निर्देशों को लिखने में सावधानी बरतनी है जिससे कि शून्य के लिए परीक्षण हो और घटने से पहले जम्प करे तो अन्यथा हमारी मशीन अंत से गिर जाएगी या अंत से टकरा जाएगी - हमारे पास आंशिक कार्य का उदाहरण होगा। घटने से पहले हमारी मशीन को सदैव यह सवाल पूछना चाहिए: क्या टेप/काउंटर खाली है? यदि ऐसा है तो मैं घट नहीं सकता, अन्यथा मैं कर सकता हूँ।
मिन्स्की (1961) और शेफर्डसन-स्टर्गिस (1963) सिद्ध करते हैं कि केवल कुछ टेप- जितने कम अभी भी मशीन को ट्यूरिंग समतुल्य होने की अनुमति देते हैं यदि टेप पर डेटा को गोडेल नंबर (या कुछ अन्य विशिष्ट रूप से एनकोडेबल-) के रूप में दर्शाया जाता है। इस प्रकार डिकोडेबल नंबर की गणना आगे बढ़ने पर यह संख्या विकसित होगी। गोडेल संख्या एन्कोडिंग वाले टेप संस्करण में काउंटर मशीन को (i) गोडेल संख्या को स्थिरांक (संख्या 2 या 3) से गुणा करने में सक्षम होना चाहिए, और (ii) स्थिरांक (संख्या 2 या 3) से विभाजित करना चाहिए और जम्प करनी चाहिए यदि शेष शून्य है। मिंस्की (1967) ने दिखाया कि इस विचित्र निर्देश सेट की आवश्यकता को {INC (r), JZDEC (r, z)} और सुविधा निर्देश {CLR (r), J (r)} में शिथिल किया जा सकता है यदि दो टेप उपलब्ध हैं, चूंकि, साधारण गोडेलाइज़ेशन अभी भी आवश्यक है। उनके आरएएसपी मॉडल के संबंध में एल्गोट-रॉबिन्सन (1964) में समान परिणाम दिखाई देता है।
मेल्ज़ाक (1961) का मॉडल अलग है: कंकड़ के गुच्छे छिद्रों में और बाहर जाते हैं
मेल्ज़ाक (1961) मॉडल अधिक अलग है। उन्होंने स्वयं से बनाया गये मॉडल को लिया, टेपों को लंबवत रूप से फ़्लिप किया, उन्हें कंकड़ काउंटरों से भरने के लिए जमीन में होल करता हैं। इस प्रकार मिन्स्की की वृद्धि और गिरावट के विपरीत, मेल्ज़ाक ने कंकड़ की किसी भी गिनती के उचित घटाव की अनुमति दी और कंकड़ की किसी भी गिनती को जोड़ दिया।
वह अपने मॉडल (पृष्ठ 288) के लिए अप्रत्यक्ष संबोधन को परिभाषित करता है और इसके उपयोग के दो उदाहरण प्रदान करता है, उसका प्रमाण (पृ. 290-292) कि उसका मॉडल ट्यूरिंग समतुल्य है, इतना अस्पष्ट है कि पाठक यह नहीं बता सकता है कि वह अप्रत्यक्ष संबोधन को प्रमाण के लिए आवश्यकता होने की आशा रखता है या नहीं।
मेलज़क के मॉडल की मुख्य लैम्बेक का सरलीकरण और कुक एंड रेक्हो 1973 में उनके स्मरक सम्मेलनों का पुन: प्रकट होना है।
लैम्बेक (1961) ने मेल्ज़ाक के मॉडल को मिन्स्की (1961) मॉडल में परमाणुकृत किया: INC और DEC-with-test
लैम्बेक (1961) ने मेल्ज़ाक के त्रिगुट मॉडल को लिया और इसे दो एकात्मक निर्देशों-X+, X- यदि संभव हो तो जम्प को बिल्कुल वही दो जो मिन्स्की (1961) के साथ आए थे, के लिए परमाणुकृत किया हैं।
चूंकि, मिन्स्की (1961) मॉडल के समान, लैम्बेक मॉडल अपने निर्देशों को डिफ़ॉल्ट-अनुक्रमिक विधियों से निष्पादित करता है, - X+ और X- दोनों अगले निर्देश के पहचानकर्ता को ले जाते हैं, और X- भी शून्य होने पर निर्देश पर जम्प करता है। जिससे परीक्षण सफल रहता है।
एलगॉट-रॉबिन्सन (1964) और अप्रत्यक्ष समाधान के बिना रैस्प की समस्या
इस रैस्प या रैंडम-एक्सेस स्टोर्ड-प्रोग्राम मशीन काउंटर मशीन के रूप में प्रारंभ होती है, जिसके निर्देश के प्रोग्राम को इसके रजिस्टर में रखा जाता है। परिमित स्थिति मशीन के निर्देश रजिस्टर के अनुरूप, किन्तु स्वतंत्र, कम से कम रजिस्टर (प्रोग्राम काउंटर (पीसी) का उपनाम) और या से अधिक अस्थायी रजिस्टर वर्तमान निर्देश की संख्या का रिकॉर्ड बनाए रखते हैं और उस पर कार्य करते हैं। परिमित स्थिति मशीन के निर्देशों की तालिका (i) वर्तमान प्रोग्राम निर्देश को उचित रजिस्टर से लाने के लिए जिम्मेदार होते हैं (ii) प्रोग्राम निर्देश को पार्स करना, (iii) प्रोग्राम निर्देश द्वारा निर्दिष्ट ऑपरेंड को लाना, और (iv) प्रोग्राम निर्देश को निष्पादित करना इसका मुख्य कार्य हैं।
इसके अतिरिक्त इसकी समस्या है कि यदि काउंटर मशीन चेसिस के आधार पर यह कंप्यूटर जैसा है, तो जॉन वॉन न्यूमैन मशीन ट्यूरिंग समकक्ष नहीं होगी। यह गणना योग्य हर चीज की गणना नहीं कर सकता है। आंतरिक रूप से मॉडल इसके (बहुत-) परिमित स्थिति मशीन के निर्देशों के आकार से घिरा है। काउंटर मशीन आधारित रैस्प किसी भी विशेष पुनरावर्ती फ़ंक्शन (जैसे गुणन) की गणना कर सकता है, किन्तु सभी म्यू पुनरावर्ती कार्यों (जैसे एकरमैन समारोह) की गणना नहीं कर सकता है।
एलगॉट-रॉबिन्सन अपने आरएएसपी मॉडल को अपने प्रोग्राम निर्देशों को स्वयं संशोधित करने की अनुमति देने की संभावना की जांच करते हैं। यह विचार पुराना था, जिसे बर्क-गोल्डस्टाइन-वॉन न्यूमैन (1946-7) द्वारा प्रस्तावित किया गया था, और कभी-कभी इसे कंप्यूटेड गोटो कहा जाता था। मेल्ज़ाक (1961) ने विशेष रूप से नाम से संगणित गोटो का उल्लेख किया है, किन्तु इसके अतिरिक्त अप्रत्यक्ष संबोधन के साथ अपना मॉडल प्रदान करता है।
'कम्प्यूटेड गोटो:' निर्देशों का आरएएसपी प्रोग्राम जो सशर्त- या बिना शर्त जम्प फंक्शन निर्देश में गोटो पते को संशोधित करता है।
किन्तु यह समस्या का समाधान नहीं करता है, जब तक कि कोई गोडेल संख्या का सहारा नहीं लेता हैं। इस लिए आवश्यक है कि फंक्शन निर्देश का पता लाने के लिए विधि है जो परिमित स्थिति मशीन के निर्देश रजिस्टर और तालिका के ऊपरी सीमा से दूर रहकर इसके ऊपर स्थित रहती हैं।
- उदाहरण: केवल चार असीमित रजिस्टरों से लैस काउंटर मशीन द्वारा किया जाता हैं, उदाहरण के लिए किसी भी दो संख्याओं (m, n) को साथ गुणा करके p— प्राप्त करें और इस प्रकार विशेष पुनरावर्ती फलन बनें—इससे कोई फर्क नहीं पड़ता कि संख्याएँ m और n कितनी बड़ी हैं; इसके अलावा, ऐसा करने के लिए 20 से कम निर्देशों की आवश्यकता होती है। उदाहरण के लिएː { 1: CLR ( p ), 2: JZ ( m, done ), 3 outer_loop: JZ ( n, done ), 4: CPY ( m, temp ), 5: inner_loop: JZ ( m, outer_loop ), 6: DEC ( m ), 7: INC ( p ), 8: J ( inner_loop ), 9: outer_loop: DEC ( n ), 10 J ( outer_loop ), HALT }
- चूंकि, केवल 4 रजिस्टरों के साथ, यह मशीन रैस्प बनाने के लिए लगभग इतनी बड़ी नहीं है जो प्रोग्राम के रूप में मल्टीप्ल एल्गोरिथम को निष्पादित कर सके। कोई फर्क नहीं पड़ता कि हम अपनी परिमित स्थिति मशीन का कितना बड़ा निर्माण करते हैं, इस प्रकार सदैव फंक्शन (इसके मापदंडों सहित) होगा जो बड़ा होता है। इसलिए परिभाषा के अनुसार बाउंडेड प्रोग्राम मशीन जो अनबाउंड एन्कोडिंग ट्रिक्स जैसे गोडेल नंबर का उपयोग नहीं करती है, सार्वभौमिक नहीं हो सकती है।
इस प्रकार मिन्स्की (1967) निर्देशों {CLR (R), INC (R), और RPT (एक बार निर्देश m से n)} से लैस काउंटर मशीन (वह उन्हें प्रोग्राम कंप्यूटर मॉडल कहते हैं) की अपनी जांच में इस विवाद पर संकेत देता है। वह हमें यह नहीं बताता कि समस्या को कैसे ठीक किया जाए, किन्तु वह देखता है कि प्रोग्राम कंप्यूटर के पास यह ट्रैक रखने के लिए कोई तरीका होना चाहिए कि कितने RPT किए जाने बाकी हैं, और यह कंप्यूटर के परिमित भाग में अनुमत स्टोरेज की किसी विशेष मात्रा को समाप्त कर सकता है। सामान्य तौर पर, RPT संचालन के लिए अपने स्वयं के अनंत रजिस्टरों की आवश्यकता होती है, और हमारे द्वारा विचार किए गए अन्य प्रकार के संचालनों से अलग व्यवहार किया जाना चाहिए।
किन्तु एल्गोट और रॉबिन्सन समस्या का समाधान करते हैं: वे अपने P0 निर्देशों के अनुक्रमित सेट के साथ रैस्प - अप्रत्यक्ष संबोधन का कुछ अधिक जटिल (किन्तु अधिक लचीला) रूप में रहता हैं। उनका P'0 मॉडल निर्देश में स्पष्ट रूप से निर्दिष्ट इंडेक्स (या इसके विपरीत, स्वैपिंग बेस और इंडेक्स) में बेस रजिस्टर (निर्देश में निर्दिष्ट) की सामग्री को जोड़कर रजिस्टरों को संबोधित करता है। इस प्रकार अनुक्रमण P'0 निर्देशों में गैर-इंडेक्सिंग P0 की तुलना में और पैरामीटर है- निर्देश:
- उदाहरण: INC ( rbase, index ) ; effective address will be [rbase] + सूचकांक, जहां प्राकृतिक संख्या सूचकांक परिमित-स्थिति मशीन निर्देश से ही प्राप्त होता है।
हार्टमैनिस (1971)
1971 तक हार्टमैनिस ने अपने रैस्प मॉडल में उपयोग के लिए अनुक्रमण को अप्रत्यक्ष रूप से सरल बना दिया है।
अविवेक एड्रेसिंग: पॉइंटर-रजिस्टर निर्देश के लिए आवश्यक लक्ष्य रजिस्टर के पते के साथ परिमित स्थिति मशीन की आपूर्ति करता है। दूसरे तरीके से कहा: पॉइंटर-रजिस्टर की सामग्री निर्देश द्वारा उपयोग किए जाने वाले लक्ष्य रजिस्टर का पता है। यदि पॉइंटर-रजिस्टर अबाधित है, तो रैम और इसके चेसिस पर निर्मित उपयुक्त रैस्प, ट्यूरिंग समकक्ष होगा। लक्ष्य रजिस्टर या तो स्रोत या गंतव्य रजिस्टर के रूप में कार्य कर सकता है, जैसा कि निर्देश द्वारा निर्दिष्ट किया गया है।
ध्यान दें कि परिमित स्थिति मशीन को इस लक्ष्य रजिस्टर के पते को स्पष्ट रूप से निर्दिष्ट करने की आवश्यकता नहीं है। यह सिर्फ मशीन के बाकी हिस्सों से कहता है: मुझे मेरे पॉइंटर-रजिस्टर द्वारा बताए गए रजिस्टर की सामग्री प्राप्त करें और फिर इसके साथ xyz करता हैं। इसे अपने निर्देश के माध्यम से स्पष्ट रूप से नाम से निर्दिष्ट करना होगा, यह पॉइंटर-रजिस्टर (जैसे N , या 72 या PC , आदि) किन्तु यह जानने की आवश्यकता नहीं है कि पॉइंटर-रजिस्टर में वास्तव में कौन सी संख्या है।
कुक एंड रेक्हो (1973) रैम का वर्णन करते हैं
कुक एंड रेक्हो (1973) हार्टमैनिस (1971) का आशय देते हैं और अपने मॉडल को रैंडम-एक्सेस मशीन (रैम- अर्ताथ अप्रत्यक्ष और हार्वर्ड संरचना वाली मशीन) कहते हैं। इस स्थिति में हम मेल्ज़ाक (1961) में वापस आ गए हैं, किन्तु मेल्ज़क की तुलना के साथ बहुत सरल मॉडल हैं।
प्राथमिकता
मिन्स्की एमआईटी लिंकन प्रयोगशाला में कार्य कर रहे थे और उन्होंने वहां अपना कार्य प्रकाशित किया; उनका पेपर 15 अगस्त, 1960 को एनाल्स ऑफ मैथमेटिक्स में प्रकाशित होने के लिए प्राप्त हुआ था, किन्तु नवंबर 1961 तक प्रकाशित नहीं हुआ था। मेल्ज़ाक और लैम्बेक के कार्य के प्राप्त होने और प्रकाशित होने से पूरे साल पहले प्राप्ति हुई थी (क्रमशः मई और जून 15 प्राप्त हुआ था)। इस प्रकार 1961 में साथ-साथ सितंबर 1961 में प्रकाशित हुआ कि (i) दोनों कैनेडियन थे और कनाडाई गणितीय बुलेटिन में प्रकाशित हुए थे, (ii) दोनों में से किसी में भी मिंस्की के कार्य का संदर्भ नहीं होता क्योंकि यह अभी तक पीयर-रिव्यू जर्नल में प्रकाशित नहीं हुआ था, किन्तु (iii) मेल्ज़ाक वांग का संदर्भ देता है, और लैम्बेक संदर्भ मेलज़क, परिकल्पना की ओर ले जाता है कि उनका कार्य साथ और स्वतंत्र रूप से हुआ था।
शेफर्डसन और स्टर्गिस के साथ लगभग ठीक वैसा ही हुआ। उनका पेपर दिसंबर 1961 में प्राप्त हुआ था - मेल्ज़ाक और लैम्बेक के कार्य के प्राप्त होने के कुछ ही महीनों बाद दोबारा, उनके पास मिन्स्की के कार्य की समीक्षा करने का बहुत कम (अधिकतम 1 महीने) या कोई लाभ नहीं था। वे फ़ुटनोट्स में यह देखने के लिए सावधान थे, कि कहीं एर्शोव, काफेंगस्ट और पीटर द्वारा हाल ही में पेपर सामने आए थे। ये बहुत पहले प्रकाशित हुए थे किन्तु जर्मन पत्रिकाओं में जर्मन भाषा में छपे थे इसलिए अभिगम्यता के विवाद स्वयं उपस्थित होते हैं।
शेफर्डसन और स्टर्गिस का अंतिम पेपर 1963 तक सहकर्मी-समीक्षा पत्रिका में नहीं दिखाई दिया था और जैसा कि वे अपने परिशिष्ट ए में निष्पक्ष और ईमानदारी से नोट करते हैं, काफेंगस्ट (1959), एर्शोव (1958), पीटर (1958) के 'सिस्टम' सभी इतने समान हैं कि बाद में जो परिणाम प्राप्त हुए वे निम्नलिखित के सेट के लिए अप्रभेद्य हैं:
- उत्पादन 0 अर्ताथ 0 → n
- एक संख्या बढ़ाएँ अर्थात n+1 → n
- अर्थात उन संक्रियाओं को करने से जो प्राकृतिक संख्याएँ उत्पन्न करती हैं।
- एक नंबर अर्ताथ n → m कॉपी करें,
- एक गणना के पाठ्यक्रम को बदलने के लिए, या तो दो संख्याओं की तुलना करना या 0 तक घटाया जाता हैं।
दरअसल, शेफर्सन और स्टर्गिस का निष्कर्ष है।
- विभिन्न न्यूनतम प्रणालियाँ बहुत समान हैं।
प्रकाशन तिथि के क्रम में काफेंगस्ट (1959), एर्शोव (1958), पीटर (1958) के कार्य पहले थे।
यह भी देखें
- काउंटर मशीन
- सूचक मशीन
- रैंडम-एक्सेस मशीन
- रैंडम-एक्सेस संग्रहीत प्रोग्राम मशीन
- ट्यूरिंग मशीन
- यूनिवर्सल ट्यूरिंग मशीन
- ट्यूरिंग मशीन गैलरी
- ट्यूरिंग मशीन के उदाहरण
- वांग बी-मशीन
- पोस्ट-ट्यूरिंग मशीन - विवरण और उदाहरण
- कलन विधि
- रुकने की समस्या
- व्यस्त ऊदबिलाव
- स्टैक मशीन
- WDR पेपर कंप्यूटर
ग्रन्थसूची
Background texts: The following bibliography of source papers includes a number of texts to be used as background. The mathematics that led to the flurry of papers about abstract machines in the 1950s and 1960s can be found in van Heijenoort (1967)—an assemblage of original papers spanning the 50 years from Frege (1879) to Gödel (1931). Davis (ed.) The Undecidable (1965) carries the torch onward beginning with Gödel (1931) through Gödel's (1964) postscriptum (p. 71); the original papers of Alan Turing (1936-7) and Emil Post (1936) are included in The Undecidable. The mathematics of Church, Rosser and Kleene that appear as reprints of original papers in The Undecidable is carried further in Kleene (1952), a mandatory text for anyone pursuing a deeper understanding of the mathematics behind the machines. Both Kleene (1952) and Davis (1958) are referenced by a number of the papers.
For a good treatment of the counter machine see Minsky (1967) Chapter 11 "Models similar to Digital Computers"—he calls the counter machine a "progरैम computer". A recent overview is found at van Emde Boas (1990). A recent treatment of the Minsky (1961)/Lambek (1961) model can be found Boolos-Burgess-Jeffrey (2002); they reincarnate Lambek's "abacus model" to demonstrate equivalence of Turing machines and partial recursive functions, and they provide a graduate-level introduction to both abstract machine models (counter- and Turing-) and the mathematics of recursion theory. Beginning with the first edition Boolos-Burgess (1970) this model appeared with virtually the same treatment.
The papers: The papers begin with Wang (1957) and his dरैमatic simplification of the Turing machine. Turing (1936), Kleene (1952), Davis (1958) and in particular Post (1936) are cited in Wang (1957); in turn, Wang is referenced by Melzak (1961), Minsky (1961) and Shepherdson–Sturgis (1961-3) as they independently reduce the Turing tapes to "counters". Melzak (1961) provides his pebble-in-holes counter machine model with indirection but doesn't carry the treatment further. The work of Elgot–Robinson (1964) define the रैस्प—the computer-like random-access stored-progरैम machines—and appear to be the first to investigate the failure of the bounded counter machine to calculate the mu-recursive functions. This failure—except with the draconian use of Gödel numbers in the manner of Minsky (1961))—leads to their definition of "indexed" instructions (i.e. indirect addressing) for theआईआर रैस्प model. Elgot–Robinson (1964) and more so Hartmanis (1971) investigate रैस्पs with self-modifying progरैमs. Hartmanis (1971) specifies an instruction set with indirection, citing lecture notes of Cook (1970). For use in investigations of computational complexity Cook and his graduate student Reckhow (1973) provide the definition of a रैम (their model and mnemonic convention are similar to Melzak's, but offer him no reference in the paper). The pointer machines are an offshoot of Knuth (1968, 1973) and independently Schönhage (1980).
For the most part the papers contain mathematics beyond the undergraduate level—in particular the primitive recursive functions and mu recursive functions presented elegantly in Kleene (1952) and less in depth, but useful nonetheless, in Boolos-Burgess-Jeffrey (2002).
All texts and papers excepting the four starred have been witnessed. These four are written in German and appear as references in Shepherdson–Sturgis (1963) and Elgot–Robinson (1964); Shepherdson–Sturgis (1963) offer a brief discussion of their results in Shepherdson–Sturgis' Appendix A. The terminology of at least one paper (Kaphengst (1959) seems to hark back to the Burke-Goldstine-von Neumann (1946-7) analysis of computer architecture.
| Author | Year | Reference | Turing machine | Counter machine | रैम | रैस्प | Pointer machine | Indirect addressing | Self-modifying progरैम |
|---|---|---|---|---|---|---|---|---|---|
| Goldstine & von Neumann | 1947 | ||||||||
| Kleene | 1952 | ||||||||
| *Hermes | 1954, 5 | ? | |||||||
| Wang | 1957 |