स्नोबोल: Difference between revisions

From Vigyanwiki
(TEXT)
(TEXT)
Line 28: Line 28:


=== स्नोबॉल1 ===
=== स्नोबॉल1 ===
प्रारंभिक स्नोबॉल भाषा को इसके लेखकों द्वारा बहुपदों के प्रतीकात्मक प्रकलन के साथ काम करने के लिए उपयोग किए जाने वाले उपकरण के रूप में बनाया गया था। यह [[IBM 7090]] के लिए समन्वायोजन भाषा में लिखा गया था। इसमें एक साधारण वाक्यविचार था, केवल एक डेटा'''टाइप, श्रृंखला, कोई फ़ंक्शन नहीं, और कोई घोषणा नहीं और बहुत कम त्रुटि नियंत्रण। हालाँकि, इसकी सादगी और इसकी व्यक्तिगत प्रकृति के बावजूद इसका उपयोग अन्य समूहों में फैलने लगा। नतीजतन, लेखकों ने इसे विस्तारित करने और इसे साफ करने का फैसला किया'''।
प्रारंभिक स्नोबॉल भाषा को इसके लेखकों द्वारा बहुपदों के प्रतीकात्मक प्रकलन के साथ काम करने के लिए उपयोग किए जाने वाले उपकरण के रूप में बनाया गया था। यह [[IBM 7090]] के लिए समन्वायोजन भाषा में लिखा गया था। इसमें एक साधारण वाक्यविचार था, केवल एक प्रदत्त प्रकार, श्रृंखला, कोई प्रकार्य नहीं, और कोई घोषणा नहीं और बहुत कम त्रुटि नियंत्रण था। हालाँकि, इसकी सरलता और इसकी व्यक्तिगत प्रकृति होने पर भी इसका उपयोग अन्य समूहों में विस्तृत होने लगा। नतीजतन, लेखकों ने इसे विस्तारित करने और इसे सुव्यवस्थित करने का निर्णय किया।


=== स्नोबॉल2 ===
=== स्नोबॉल2 ===
स्नोबॉल2 मौजूद था, लेकिन यह उपयोगकर्ता-परिभाषित कार्यों के बिना एक अल्पकालिक मध्यवर्ती विकास संस्करण था और इसे कभी जारी नहीं किया गया था।
स्नोबॉल2 उपस्थित था, लेकिन यह उपयोगकर्ता-परिभाषित कार्यों के बिना एक अल्पकालिक मध्यवर्ती विकास संस्करण था और इसे कभी जारी नहीं किया गया था।


=== स्नोबॉल3 ===
=== स्नोबॉल3 ===
स्नोबॉल को मानक और उपयोगकर्ता परिभाषित दोनों कार्यों को जोड़ने के लिए फिर से लिखा गया था, और परिणाम स्नोबॉल3 के रूप में जारी किया गया था। स्नोबॉल3 काफी लोकप्रिय हो गया और अन्य प्रोग्रामर्स द्वारा IBM 7090 के अलावा अन्य कंप्यूटरों के लिए फिर से लिखा गया। परिणामस्वरूप, कई असंगत बोलियाँ उत्पन्न हुईं।
स्नोबॉल को मानक और उपयोगकर्ता परिभाषित दोनों कार्यों को जोड़ने के लिए फिर से लिखा गया था, और परिणाम स्नोबॉल3 के रूप में जारी किया गया था। स्नोबॉल3 अत्यंत लोकप्रिय हो गया और अन्य क्रमादेशित्रों द्वारा IBM 7090 के अलावा अन्य कंप्यूटरों के लिए फिर से लिखा गया। परिणामस्वरूप, कई असंगत बोलियाँ उत्पन्न हुईं।


=== स्नोबॉल4 ===
=== स्नोबॉल4 ===
जैसा कि स्नोबॉल3 अधिक लोकप्रिय हो गया, लेखकों को भाषा के विस्तार के लिए अधिक से अधिक अनुरोध प्राप्त हुए। उन्हें उन संस्करणों में असंगति और बग के बारे में शिकायतें भी मिलने लगीं जिन्हें उन्होंने लिखा नहीं था। इसे संबोधित करने के लिए और 1960 के दशक के अंत में पेश किए गए नए कंप्यूटरों का लाभ उठाने के लिए, स्नोबॉल4 को कई अतिरिक्त डेटाटाइप्स और सुविधाओं के साथ विकसित करने का निर्णय लिया गया था, लेकिन कंप्यूटरों में बेहतर पोर्टेबिलिटी की अनुमति देने के लिए एक [[आभासी मशीन]] पर आधारित था।<ref>See Chapter 1 of ''The Macro Implementation of SNOBOL4''</ref> स्नोबॉल4 भाषा अनुवादक अभी भी असेम्बली भाषा में लिखा गया था। हालाँकि असेंबलर की मैक्रो विशेषताओं का उपयोग स्नोबॉल इम्प्लीमेंटेशन लैंग्वेज, SIL के वर्चुअल मशीन निर्देशों को परिभाषित करने के लिए किया गया था। इसने वर्चुअल मशीन को पोर्ट करना अपेक्षाकृत आसान बनाकर भाषा की पोर्टेबिलिटी में बहुत सुधार किया, जिसने किसी मशीन पर अपने वर्चुअल निर्देशों को फिर से बनाकर होस्ट किया, जिसमें एक मैक्रो असेंबलर या वास्तव में एक उच्च स्तरीय भाषा सम्मिलित थी।<ref>SNOBOL4 has been implemented using C to recreate the virtual machine instructions.</ref>
जैसा कि स्नोबॉल3 अधिक लोकप्रिय हो गया, लेखकों को भाषा के विस्तार के लिए अधिक से अधिक अनुरोध प्राप्त हुए। उन्हें उन संस्करणों में असंगति और दोष के बारे में व्यथा भी मिलने लगीं जिन्हें उन्होंने लिखा नहीं था। इसे संबोधित करने के लिए और 1960 के दशक के अंत में प्रस्तुत किए गए नए कंप्यूटरों का लाभ उठाने के लिए, स्नोबॉल4 को कई अतिरिक्त प्रदत्त प्रकार और सुविधाओं के साथ विकसित करने का निर्णय लिया गया था, लेकिन कंप्यूटरों में बेहतर सुवाह्यता की अनुमति देने के लिए एक [[आभासी मशीन|आभासी यंत्र]] पर आधारित था।<ref>See Chapter 1 of ''The Macro Implementation of SNOBOL4''</ref> स्नोबॉल4 भाषा अनुवादक अभी भी स्मरांतरण भाषा में लिखा गया था। हालाँकि समायोजक की स्थूल विशेषताओं का उपयोग स्नोबॉल क्रियान्वयन भाषा, SIL के आभासी यंत्र निर्देशों को परिभाषित करने के लिए किया गया था। इसने आभासी यंत्र को प्रद्वार करना अपेक्षाकृत आसान बनाकर भाषा की सुवाह्यता में बहुत सुधार किया, जिसने किसी यन्त्र पर अपने कल्पित निर्देशों को फिर से बनाकर आयोजित किया, जिसमें एक दीर्घ समायोजक या वास्तव में एक उच्च स्तरीय भाषा सम्मिलित थी।<ref>SNOBOL4 has been implemented using C to recreate the virtual machine instructions.</ref>
मशीन-स्वतंत्र भाषा एसआईएल [[डगलस मैक्लॉयय]] द्वारा श्रृंखला मैनिपुलेशन मैक्रोज़ के सामान्यीकरण के रूप में उभरी, जिसका प्रारंभिक एसएनओबीओएल कार्यान्वयन में बड़े पैमाने पर उपयोग किया गया था। 1969 में, McIlroy ने तालिका प्रकार को स्नोबॉल4 में जोड़ने पर जोर देकर फिर से भाषा को प्रभावित किया।<ref name="Gris78">{{cite journal |last=Griswold |first=Ralph |author-link=Ralph Griswold |title=A history of the SNOBOL programming languages |journal=ACM SIGPLAN Notices |pages=275–308 |volume=13 |number=8 |year=1978 |doi=10.1145/960118.808393 |s2cid=5413577 |url=http://pdfs.semanticscholar.org/a404/c09b14e2b03496604387f532fd33975179ec.pdf |archive-url=https://web.archive.org/web/20190302233559/http://pdfs.semanticscholar.org/a404/c09b14e2b03496604387f532fd33975179ec.pdf |url-status=dead |archive-date=2019-03-02 }}</ref><ref>{{cite book |editor-link=Richard Wexelblat|editor-first=Richard L. |editor-last=Wexelblat |title=History of Programming Languages |orig-year=1981 |year=2014 |publisher=Academic Press |isbn=9781483266169 |pages=784}}</ref>
 
यन्त्र-स्वतंत्र भाषा SIL [[डगलस मैक्लॉयय]] द्वारा श्रृंखला प्रकलन दीर्घ के सामान्यीकरण के रूप में उभरी, जिसका प्रारंभिक स्नोबॉल कार्यान्वयन में बड़े अनुपात पर उपयोग किया गया था। 1969 में, मेक्लोरी ने तालिका प्रकार को स्नोबॉल4 में जोड़ने पर दृढ़ रहकर फिर से भाषा को प्रभावित किया।<ref name="Gris78">{{cite journal |last=Griswold |first=Ralph |author-link=Ralph Griswold |title=A history of the SNOBOL programming languages |journal=ACM SIGPLAN Notices |pages=275–308 |volume=13 |number=8 |year=1978 |doi=10.1145/960118.808393 |s2cid=5413577 |url=http://pdfs.semanticscholar.org/a404/c09b14e2b03496604387f532fd33975179ec.pdf |archive-url=https://web.archive.org/web/20190302233559/http://pdfs.semanticscholar.org/a404/c09b14e2b03496604387f532fd33975179ec.pdf |url-status=dead |archive-date=2019-03-02 }}</ref><ref>{{cite book |editor-link=Richard Wexelblat|editor-first=Richard L. |editor-last=Wexelblat |title=History of Programming Languages |orig-year=1981 |year=2014 |publisher=Academic Press |isbn=9781483266169 |pages=784}}</ref>
 




== स्नोबॉल4 सुविधाएँ ==
== स्नोबॉल4 सुविधाएँ ==
{{Original research|date=August 2020}}
{{Original research|date=August 2020}}
स्नोबॉल प्रारूप [[समारोह (प्रोग्रामिंग)|समारोह (क्रमादेशन)]] शैली में विशिष्ट है, जो समकालीन प्रक्रियात्मक भाषाओं जैसे कि [[फोरट्रान]] और ALGOL से मौलिक रूप से भिन्न हैं।
स्नोबॉल प्रारूप और [[समारोह (प्रोग्रामिंग)|क्रमादेशन]] शैली में विशिष्ट है, जो समकालीन प्रक्रियात्मक भाषाओं जैसे कि [[फोरट्रान]] और ऐल्गॉल से मौलिक रूप से भिन्न हैं।


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


सभी स्नोबॉल कमांड लाइन फॉर्म के हैं
सभी स्नोबॉल समादेश पंक्ति निम्न स्वरुप के हैं
: लेबल विषय प्रतिरूप '=' वस्तु ':' स्थानांतरण
: नामपत्र विषय प्रतिरूप '=' वस्तु ':' स्थानांतरण


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


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


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


स्नोबॉल4 प्रतिरूप-मैचिंग एक पश्चअनुमार्गण एल्गोरिथम का उपयोग करता है जो [[तर्क प्रोग्रामिंग|तर्क क्रमादेशन]] भाषा [[प्रोलॉग]] में उपयोग किया जाता है, जो [[निश्चित खंड व्याकरण]] के माध्यम से प्रतिरूप-समान निर्माण प्रदान करता है। अधिकांश भाषाओं की तुलना में यह एल्गोरिथ्म स्नोबॉल को तर्क क्रमादेशन भाषा के रूप में उपयोग करना आसान बनाता है।
स्नोबॉल4 प्रतिरूप-मिलान एक पश्चअनुमार्गण कलन विधि का उपयोग करता है जो [[तर्क प्रोग्रामिंग|तर्क क्रमादेशन]] भाषा [[प्रोलॉग|प्रस्तावना]] में उपयोग किया जाता है, जो [[निश्चित खंड व्याकरण]] के माध्यम से प्रतिरूप-समान निर्माण प्रदान करता है। अधिकांश भाषाओं की तुलना में यह कलन विधि स्नोबॉल को तर्क क्रमादेशन भाषा के रूप में उपयोग करना आसान बनाता है।


स्नोबॉल एक [[कचरा संग्रह (कंप्यूटर विज्ञान)]]|कचरा-एकत्रित ढेर में चर, तार और डेटा संरचनाओं को संग्रहीत करता है।
स्नोबॉल एक [[कचरा संग्रह (कंप्यूटर विज्ञान)|कचरा-संग्रहित (कंप्यूटर विज्ञान)]] ढेर में चर, तार और डेटा संरचनाओं को संग्रहीत करता है।


== उदाहरण कार्यक्रम ==
== उदाहरण कार्यक्रम ==
Line 69: Line 71:
</वाक्यविन्यास हाइलाइट>
</वाक्यविन्यास हाइलाइट>


एक उपयोगकर्ता का नाम पूछने के लिए एक साधारण प्रोग्राम और फिर इसे आउटपुट वाक्य में प्रयोग करें ...
एक उपयोगकर्ता का नाम पूछने के लिए एक साधारण क्रमानुदेश और फिर इसे आउटपुट वाक्य में प्रयोग करें ...
<वाक्यविन्यास हाईलाइट लैंग = स्नोबोल>
<वाक्यविन्यास हाईलाइट लैंग = स्नोबोल>
           आउटपुट = आपका नाम क्या है?
           आउटपुट = आपका नाम क्या है?
Line 93: Line 95:


<वाक्यविन्यास हाईलाइट लैंग = स्नोबोल>
<वाक्यविन्यास हाईलाइट लैंग = स्नोबोल>
           OUTPUT = यह प्रोग्राम आपसे व्यक्तिगत नाम पूछेगा
           OUTPUT = यह क्रमानुदेश आपसे व्यक्तिगत नाम पूछेगा
           OUTPUT = जब तक आप रिटर्न दिए बिना रिटर्न दबाते हैं
           OUTPUT = जब तक आप रिटर्न दिए बिना रिटर्न दबाते हैं
           NameCount = 0 :(GETINPUT)
           NameCount = 0 :(GETINPUT)
Line 107: Line 109:
== कार्यान्वयन ==
== कार्यान्वयन ==


क्लासिक कार्यान्वयन [[पीडीपी-10]] पर था; इसका उपयोग [[संकलक]], [[औपचारिक व्याकरण]] और कृत्रिम बुद्धिमत्ता, विशेष रूप से मशीनी अनुवाद और [[प्राकृतिक भाषा]]ओं की मशीन समझ के अध्ययन के लिए किया गया है। मूल कार्यान्वयन बेल लैब्स, होल्मडेल, एन.जे. में आईबीएम 7090 पर था। स्नोबॉल4 को विशेष रूप से पोर्टेबिलिटी के लिए अभिकल्पित किया गया था; पहला कार्यान्वयन 1966 में IBM 7094 पर शुरू किया गया था, लेकिन 1967 में IBM 360 पर पूरा हुआ। इसे तेजी से कई अन्य प्लेटफार्मों पर पोर्ट किया गया।
उत्कृष्ट कार्यान्वयन [[पीडीपी-10|PDP-10]] पर था; इसका उपयोग [[संकलक]], [[औपचारिक व्याकरण]] और कृत्रिम बुद्धिमत्ता, विशेष रूप से मशीनी अनुवाद और [[प्राकृतिक भाषा]]ओं की मशीन समझ के अध्ययन के लिए किया गया है। मूल कार्यान्वयन बेल प्रयोगशाला, होल्मडेल, एन.जे. में IBM 7090 पर था। स्नोबॉल4 को विशेष रूप से सुवाह्यता के लिए अभिकल्पित किया गया था; पहला कार्यान्वयन 1966 में IBM 7094 पर प्रारम्भ किया गया था, लेकिन 1967 में IBM 360 पर पूरा हुआ। इसे तेजी से कई अन्य मंच पर रख दिया गया।


इसकी कुछ बहुत उच्च-स्तरीय सुविधाओं को लागू करने में कठिनाई के कारण इसे आम तौर पर एक [[दुभाषिया (कंप्यूटर सॉफ्टवेयर)]] के रूप में लागू किया जाता है, लेकिन एक संकलक है, SPITBOL संकलक, जो दुभाषिया द्वारा प्रदान की जाने वाली लगभग सभी सुविधाएं प्रदान करता है।
इसकी कुछ बहुत उच्च-स्तरीय सुविधाओं को लागू करने में कठिनाई के कारण इसे सामान्यतः एक [[दुभाषिया (कंप्यूटर सॉफ्टवेयर)]] के रूप में लागू किया जाता है, लेकिन एक संकलक है, स्पिटबॉल संकलक, जो दुभाषिया द्वारा प्रदान की जाने वाली लगभग सभी सुविधाएं प्रदान करता है।


पीडीपी-10 पर क्लासिक कार्यान्वयन काफी धीमा था, और 1972 में बेल लैब्स, होल्मडेल, एन.जे. के जेम्स गिंपेल ने पीडीपी-10 के लिए एसएनओबीओएल4 का मूल कार्यान्वयन तैयार किया जिसे उन्होंने एसआईटीबीओएल नाम दिया। उन्होंने श्रृंखला प्रोसेसिंग में एक स्नातक वर्ग के आधार के रूप में डिजाइन का उपयोग किया जो उन्होंने उस वर्ष [[स्टीवंस इंस्टीट्यूट ऑफ टेक्नोलॉजी]] में पढ़ाया था (इसीलिए इसे SITBOL नाम दिया गया था)। छात्रों को (पीडीपी-10 असेंबलर में) लागू करने के लिए सेक्शन दिए गए थे और पूरा सेमेस्टर SITBOL को लागू करने पर केंद्रित था। यह सेमेस्टर के अंत तक 80% से अधिक पूरा हो गया था और बाद में गर्मियों में प्रोफेसर गिंपेल और कई छात्रों द्वारा पूरा किया गया था। SITBOL एक पूर्ण विशेषताओं वाला, उच्च प्रदर्शन वाला स्नोबॉल4 दुभाषिया था।
PDP-10 पर उत्कृष्ट कार्यान्वयन अत्यंत धीमा था, और 1972 में बेल प्रयोगशाला, होल्मडेल, एन.जे. के जेम्स गिंपेल ने PDP-10 के लिए स्नोबॉल4 का मूल कार्यान्वयन प्रस्तुत किया जिसे उन्होंने सिटबॉल नाम दिया। उन्होंने श्रृंखला प्रसंस्करण में एक स्नातक वर्ग के आधार के रूप में अभिकल्पना का उपयोग किया जो उन्होंने उस वर्ष [[स्टीवंस इंस्टीट्यूट ऑफ टेक्नोलॉजी]] में पढ़ाया था (इसीलिए इसे सिटबॉल नाम दिया गया था)। छात्रों को (PDP-10 समायोजक में) लागू करने के लिए अनुभाग दिए गए थे और पूरा सत्र सिटबॉल को लागू करने पर केंद्रित था। यह सत्र के अंत तक 80% से अधिक पूरा हो गया था और बाद में गर्मियों में प्रोफेसर गिंपेल और कई छात्रों द्वारा पूरा किया गया था। सिटबॉल एक पूर्ण विशेषताओं वाला, उच्च प्रदर्शन वाला स्नोबॉल4 दुभाषिया था।


[[GNAT]] Ada (क्रमादेशन लैंग्वेज) कंपाइलर एक पैकेज (GNAT.Spitbol) के साथ आता है जो सभी Spitbol श्रृंखला प्रकलन सिमेंटिक्स को लागू करता है। इसे एडा कार्यक्रम के भीतर से बुलाया जा सकता है।
[[GNAT]] Ada (क्रमादेशन भाषा) संकलनकर्ता एक संकुल (GNAT.स्पिटबॉल) के साथ आता है जो सभी स्पिटबॉल श्रृंखला प्रकलन अर्थविज्ञान को लागू करता है। इसे एडा कार्यक्रम के भीतर से बुलाया जा सकता है।


[[मिशिगन टर्मिनल सिस्टम]] (MTS) के लिए फाइल एडिटर ने स्नोबॉल4 प्रतिरूप के आधार पर प्रतिरूप मिलान प्रदान किया।<ref>[https://books.google.com/books?id=c9BWAAAAMAAJ Introduction to the MTS file editor], University of Michigan Computing Center, 1986.</ref>
[[मिशिगन टर्मिनल सिस्टम]] (MTS) के लि'''ए फाइल एडिटर ने स्नो'''बॉल4 प्रतिरूप के आधार पर प्रतिरूप मिलान प्रदान किया।<ref>[https://books.google.com/books?id=c9BWAAAAMAAJ Introduction to the MTS file editor], University of Michigan Computing Center, 1986.</ref>
वर्तमान में कई कार्यान्वयन उपलब्ध हैं। फिल बडने द्वारा लिखित Macro स्नोबॉल4 in C एक मुक्त, खुला स्रोत कार्यान्वयन है, जो लगभग किसी भी मंच पर चलने में सक्षम है।<ref>{{cite web| title=SNOBOL4.ORG -- SNOBOL4 Resources |url=http://www.regressive.org/snobol4/}}</ref> Catspaw, Inc ने DOS, Macintosh, Sun, RS/6000, और अन्य सहित कई अलग-अलग कंप्यूटर प्लेटफार्मों के लिए स्नोबॉल4 भाषा का व्यावसायिक कार्यान्वयन प्रदान किया, और ये कार्यान्वयन अब Catspaw से मुक्त उपलब्ध हैं। मिनेसोटा स्नोबॉल4, विक्टर्स बर्स्टिस द्वारा, मूल IBM मेनफ्रेम संस्करण (यहां तक ​​कि फोरट्रान-जैसे FORMAT स्टेटमेंट समर्थन सहित) के निकटतम पीसी कार्यान्वयन भी मुफ्त है।<ref>{{cite web| url=http://www.berstis.com/snobol4.htm |title=The MINNESOTA SNOBOL4 Programming Language}}</ref>
वर्तमान में कई कार्यान्वयन उपलब्ध हैं। फिल बडने द्वारा लिखित Macro स्नोबॉल4 in C एक मुक्त, खुला स्रोत कार्यान्वयन है, जो लगभग किसी भी मंच पर चलने में सक्षम है।<ref>{{cite web| title=SNOBOL4.ORG -- SNOBOL4 Resources |url=http://www.regressive.org/snobol4/}}</ref> Catspaw, Inc ने DOS, Macintosh, Sun, RS/6000, और अन्य सहित कई अलग-अलग कंप्यूटर प्लेटफार्मों के लिए स्नोबॉल4 भाषा का व्यावसायिक कार्यान्वयन प्रदान किया, और ये कार्यान्वयन अब Catspaw से मुक्त उपलब्ध हैं। मिनेसोटा स्नोबॉल4, विक्टर्स बर्स्टिस द्वारा, मूल IBM मेनफ्रेम संस्करण (यहां तक ​​कि फोरट्रान-जैसे FORMAT स्टेटमेंट समर्थन सहित) के निकटतम पीसी कार्यान्वयन भी मुफ्त है।<ref>{{cite web| url=http://www.berstis.com/snobol4.htm |title=The MINNESOTA SNOBOL4 Programming Language}}</ref>
हालांकि स्नोबॉल में स्वयं कोई [[संरचित प्रोग्रामिंग|संरचित क्रमादेशन]] विशेषताएं नहीं हैं, [[बर्फानी तूफ़ान]] नामक एक स्नोबॉल प्रीप्रोसेसर को मिशिगन विश्वविद्यालय में मिशिगन टर्मिनल सिस्टम (MTS) के तहत उपयोग के लिए 1970 के दशक के दौरान फ्रेड जी. स्वार्ट्ज द्वारा डिजाइन और कार्यान्वित किया गया था।<ref name=MTSVolume9-June1979>[https://books.google.ca/books?id=WxVXAAAAMAAJ&pg=PA114&lpg=PA114&dq=snostorm+preprocessor&source=bl&ots=H5fdaCJj5n&sig=xvuW41x302-Je8xI1q8SbMSTM4Y&hl=en&sa=X&ei=E4f3U5jaOaLFigLOyYD4DQ&redir_esc=y#v=onepage&q=snostorm%20preprocessor&f=false "SNOSTORM"], ''MTS Volume 9: SNOBOL4 in MTS'', Computing Center, University of Michigan, June 1979, pages 99-120. Retrieved 1 September 2014.</ref> MTS चलाने वाली आठ से पंद्रह साइटों पर स्नोस्टॉर्म का उपयोग किया गया था। यह 1982 और 1984 के बीच [[यूनिवर्सिटी कॉलेज लंदन]] (यूसीएल) में भी उपलब्ध था।
हालांकि स्नोबॉल में स्वयं कोई [[संरचित प्रोग्रामिंग|संरचित क्रमादेशन]] विशेषताएं नहीं हैं, [[बर्फानी तूफ़ान]] नामक एक स्नोबॉल प्रीप्रोसेसर को मिशिगन विश्वविद्यालय में मिशिगन टर्मिनल सिस्टम (MTS) के तहत उपयोग के लिए 1970 के दशक के दौरान फ्रेड जी. स्वार्ट्ज द्वारा अभिकल्पना और कार्यान्वित किया गया था।<ref name=MTSVolume9-June1979>[https://books.google.ca/books?id=WxVXAAAAMAAJ&pg=PA114&lpg=PA114&dq=snostorm+preprocessor&source=bl&ots=H5fdaCJj5n&sig=xvuW41x302-Je8xI1q8SbMSTM4Y&hl=en&sa=X&ei=E4f3U5jaOaLFigLOyYD4DQ&redir_esc=y#v=onepage&q=snostorm%20preprocessor&f=false "SNOSTORM"], ''MTS Volume 9: SNOBOL4 in MTS'', Computing Center, University of Michigan, June 1979, pages 99-120. Retrieved 1 September 2014.</ref> MTS चलाने वाली आठ से पंद्रह साइटों पर स्नोस्टॉर्म का उपयोग किया गया था। यह 1982 और 1984 के बीच [[यूनिवर्सिटी कॉलेज लंदन]] (यूसीएल) में भी उपलब्ध था।


[[एंड्रयू कोएनिग (प्रोग्रामर)]] द्वारा स्नोकोन स्नोबॉल4 भाषा में ब्लॉक-संरचित निर्माण जोड़ता है। स्नोकोन स्नोबॉल4 के उचित सुपरसेट के बजाय एक स्व-निहित क्रमादेशन भाषा है।<ref>[http://www.snobol4.com/report.htm "The Snocone Programming Language"], Andrew Koenig, USENIX (Portland, Oregon), June 1985. Retrieved 2 September 2014.</ref>
[[एंड्रयू कोएनिग (प्रोग्रामर)|एंड्रयू कोएनिग (क्रमादेशक)]] द्वारा स्नोकोन स्नोबॉल4 भाषा में ब्लॉक-संरचित निर्माण जोड़ता है। स्नोकोन स्नोबॉल4 के उचित सुपरसेट के बजाय एक स्व-निहित क्रमादेशन भाषा है।<ref>[http://www.snobol4.com/report.htm "The Snocone Programming Language"], Andrew Koenig, USENIX (Portland, Oregon), June 1985. Retrieved 2 September 2014.</ref>
SPITBOL कार्यान्वयन ने कई विशेषताओं को भी पेश किया, जो पारंपरिक संरचित क्रमादेशन कीवर्ड का उपयोग नहीं करते हुए, फिर भी कई समकक्ष क्षमताओं को प्रदान करने के लिए उपयोग किया जा सकता है, जिन्हें आमतौर पर संरचित क्रमादेशन के रूप में माना जाता है, विशेष रूप से नेस्टेड if/then/else प्रकार के निर्माण। तब से इन सुविधाओं को नवीनतम स्नोबॉल4 कार्यान्वयन में जोड़ा गया है। वाणिज्यिक उत्पाद के रूप में कई वर्षों के बाद, अप्रैल 2009 में SPITBOL को [[जीएनयू जनरल पब्लिक लाइसेंस]] के तहत मुफ्त सॉफ्टवेयर के रूप में जारी किया गया।
स्पिटबॉल कार्यान्वयन ने कई विशेषताओं को भी प्रस्तुत किया, जो पारंपरिक संरचित क्रमादेशन कीवर्ड का उपयोग नहीं करते हुए, फिर भी कई समकक्ष क्षमताओं को प्रदान करने के लिए उपयोग किया जा सकता है, जिन्हें आमतौर पर संरचित क्रमादेशन के रूप में माना जाता है, विशेष रूप से नेस्टेड if/then/else प्रकार के निर्माण। तब से इन सुविधाओं को नवीनतम स्नोबॉल4 कार्यान्वयन में जोड़ा गया है। वाणिज्यिक उत्पाद के रूप में कई वर्षों के बाद, अप्रैल 2009 में स्पिटबॉल को [[जीएनयू जनरल पब्लिक लाइसेंस]] के तहत मुफ्त सॉफ्टवेयर के रूप में जारी किया गया।


== नामकरण ==
== नामकरण ==
Line 157: Line 159:


== बाहरी संबंध ==
== बाहरी संबंध ==
* [http://www.regressive.org/snobol4/csnobol4 Cस्नोबॉल4] is a free and open source BSD-licensed port of the original Bell Labs स्नोबॉल4 to systems with a C compiler, and includes SPITBOL and Blocks enhancements.
* [http://www.regressive.org/snobol4/csnobol4 Cस्नोबॉल4] is a free and open source BSD-licensed port of the original Bell Labs स्नोबॉल4 to systems with a C compiler, and includes स्पिटबॉल and Blocks enhancements.
* [http://www.regressive.org/snobol4/ Catspaw, Inc. offers implementations of and commercial support for स्नोबॉल4]
* [http://www.regressive.org/snobol4/ Catspaw, Inc. offers implementations of and commercial support for स्नोबॉल4]
* {{curlie|Computers/Programming/Languages/Snobol}}
* {{curlie|Computers/Programming/Languages/Snobol}}

Revision as of 10:18, 23 February 2023

SNOBOL
ParadigmImperative, procedural, unstructured
द्वारा डिज़ाइन किया गयाDavid J. Farber, Ralph E. Griswold and Ivan P. Polonsky
DeveloperDavid J. Farber, Ralph E. Griswold, Ivan P. Polonsky, and Bell Labs
पहली प्रस्तुति1962; 62 years ago (1962)
Stable release
SNOBOL4 / 1967; 57 years ago (1967)
वेबसाइटhttps://www.regressive.org/snobol4/
Major implementations
SNOBOL, SPITBOL
Influenced by
COMIT
Influenced
AWK, SL5, Icon, bs, Lua[1]

स्नोबॉल (श्रृंखला उन्मुख और प्रतीकात्मक भाषा) 1962 और 1967 के बीच AT&T बेल लैबोरेटरीज डेविड जे. फार्बर, राल्फ ई. ग्रिसवॉल्ड और इवान पी. पोलोनस्की द्वारा विकसित क्रमादेशन भाषाओं की एक श्रृंखला है, जो स्नोबॉल4 में समाप्त हुई। यह 1950 और 1960 के दशक के दौरान विकसित कई अवतरण-श्रृंखला-उन्मुख भाषाओं में से एक थी; अन्य में कॉमिट और ट्रैक (क्रमादेशन भाषा) सम्मिलित हैं।

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

स्नोबॉल4 को 1960 के दशक के अंत और 1970 के दशक के प्रारम्भ में बड़े अमेरिकी विश्वविद्यालयों में व्यापक रूप से पढ़ाया गया था और 1970 और 1980 के दशक में मानविकी में पाठ प्रकलन भाषा के रूप में इसका व्यापक रूप से उपयोग किया गया था।

1980 और 1990 के दशक में इसका उपयोग फीका पड़ गया क्योंकि AWK और पर्ल जैसी नई भाषाओं ने नियमित अभिव्यक्तियों के माध्यम से श्रृंखला प्रकलन को प्रचलित बना दिया। स्नोबॉल4 प्रतिरूप BNF व्याकरण को समाहित करते हैं, जो संदर्भ-मुक्त व्याकरण के बराबर हैं और नियमित अभिव्यक्तियों की तुलना में अधिक शक्तिशाली हैं।[2] AWK और Perl के मौजूदा संस्करणों में नियमित अभिव्यक्ति वास्तव में हस्तकौशल में नियमित अभिव्यक्तियों के विस्तार हैं, लेकिन स्नोबॉल4 प्रतिरूप के विपरीत नियमित अभिव्यक्तियां आवर्ती नहीं हैं, जो स्नोबॉल4 प्रतिरूप के लिए एक अलग संगणनात्मक लाभ देती हैं।[3] (पुनरावर्ती अभिव्यक्ति पर्ल 5 संस्करण इतिहास में प्रकट हुई थी। पर्ल 5.10, हालांकि, दिसंबर 2007 में जारी किया गया था।[4][5])

बाद में SL5 (1977)[6] और चिह्न (क्रमादेशन भाषा) (1978) भाषाओं को ग्रिसवॉल्ड द्वारा स्नोबॉल4 प्रतिरूप के पश्चअनुमार्गण को अधिक मानक ऐल्गॉल जैसी संरचना के साथ संयोजित करने के लिए अभिकल्पित किया गया था।

विकास

स्नोबॉल1

प्रारंभिक स्नोबॉल भाषा को इसके लेखकों द्वारा बहुपदों के प्रतीकात्मक प्रकलन के साथ काम करने के लिए उपयोग किए जाने वाले उपकरण के रूप में बनाया गया था। यह IBM 7090 के लिए समन्वायोजन भाषा में लिखा गया था। इसमें एक साधारण वाक्यविचार था, केवल एक प्रदत्त प्रकार, श्रृंखला, कोई प्रकार्य नहीं, और कोई घोषणा नहीं और बहुत कम त्रुटि नियंत्रण था। हालाँकि, इसकी सरलता और इसकी व्यक्तिगत प्रकृति होने पर भी इसका उपयोग अन्य समूहों में विस्तृत होने लगा। नतीजतन, लेखकों ने इसे विस्तारित करने और इसे सुव्यवस्थित करने का निर्णय किया।

स्नोबॉल2

स्नोबॉल2 उपस्थित था, लेकिन यह उपयोगकर्ता-परिभाषित कार्यों के बिना एक अल्पकालिक मध्यवर्ती विकास संस्करण था और इसे कभी जारी नहीं किया गया था।

स्नोबॉल3

स्नोबॉल को मानक और उपयोगकर्ता परिभाषित दोनों कार्यों को जोड़ने के लिए फिर से लिखा गया था, और परिणाम स्नोबॉल3 के रूप में जारी किया गया था। स्नोबॉल3 अत्यंत लोकप्रिय हो गया और अन्य क्रमादेशित्रों द्वारा IBM 7090 के अलावा अन्य कंप्यूटरों के लिए फिर से लिखा गया। परिणामस्वरूप, कई असंगत बोलियाँ उत्पन्न हुईं।

स्नोबॉल4

जैसा कि स्नोबॉल3 अधिक लोकप्रिय हो गया, लेखकों को भाषा के विस्तार के लिए अधिक से अधिक अनुरोध प्राप्त हुए। उन्हें उन संस्करणों में असंगति और दोष के बारे में व्यथा भी मिलने लगीं जिन्हें उन्होंने लिखा नहीं था। इसे संबोधित करने के लिए और 1960 के दशक के अंत में प्रस्तुत किए गए नए कंप्यूटरों का लाभ उठाने के लिए, स्नोबॉल4 को कई अतिरिक्त प्रदत्त प्रकार और सुविधाओं के साथ विकसित करने का निर्णय लिया गया था, लेकिन कंप्यूटरों में बेहतर सुवाह्यता की अनुमति देने के लिए एक आभासी यंत्र पर आधारित था।[7] स्नोबॉल4 भाषा अनुवादक अभी भी स्मरांतरण भाषा में लिखा गया था। हालाँकि समायोजक की स्थूल विशेषताओं का उपयोग स्नोबॉल क्रियान्वयन भाषा, SIL के आभासी यंत्र निर्देशों को परिभाषित करने के लिए किया गया था। इसने आभासी यंत्र को प्रद्वार करना अपेक्षाकृत आसान बनाकर भाषा की सुवाह्यता में बहुत सुधार किया, जिसने किसी यन्त्र पर अपने कल्पित निर्देशों को फिर से बनाकर आयोजित किया, जिसमें एक दीर्घ समायोजक या वास्तव में एक उच्च स्तरीय भाषा सम्मिलित थी।[8]

यन्त्र-स्वतंत्र भाषा SIL डगलस मैक्लॉयय द्वारा श्रृंखला प्रकलन दीर्घ के सामान्यीकरण के रूप में उभरी, जिसका प्रारंभिक स्नोबॉल कार्यान्वयन में बड़े अनुपात पर उपयोग किया गया था। 1969 में, मेक्लोरी ने तालिका प्रकार को स्नोबॉल4 में जोड़ने पर दृढ़ रहकर फिर से भाषा को प्रभावित किया।[9][10]


स्नोबॉल4 सुविधाएँ

स्नोबॉल प्रारूप और क्रमादेशन शैली में विशिष्ट है, जो समकालीन प्रक्रियात्मक भाषाओं जैसे कि फोरट्रान और ऐल्गॉल से मौलिक रूप से भिन्न हैं।

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

सभी स्नोबॉल समादेश पंक्ति निम्न स्वरुप के हैं

नामपत्र विषय प्रतिरूप '=' वस्तु ':' स्थानांतरण

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

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

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

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

स्नोबॉल एक कचरा-संग्रहित (कंप्यूटर विज्ञान) ढेर में चर, तार और डेटा संरचनाओं को संग्रहीत करता है।

उदाहरण कार्यक्रम

हैलो, दुनिया! कार्यक्रम इस प्रकार हो सकता है...

<वाक्यविन्यास हाईलाइट लैंग = स्नोबोल>

         आउटपुट = हैलो, विश्व!

अंत </वाक्यविन्यास हाइलाइट>

एक उपयोगकर्ता का नाम पूछने के लिए एक साधारण क्रमानुदेश और फिर इसे आउटपुट वाक्य में प्रयोग करें ... <वाक्यविन्यास हाईलाइट लैंग = स्नोबोल>

         आउटपुट = आपका नाम क्या है?
         उपयोगकर्ता नाम = इनपुट
         OUTPUT = धन्यवाद, उपयोगकर्ता नाम

अंत </वाक्यविन्यास हाइलाइट>

तीन संभावित आउटपुट के बीच चयन करने के लिए...

<वाक्यविन्यास हाईलाइट लैंग = स्नोबोल>

         आउटपुट = आपका नाम क्या है?
         उपयोगकर्ता नाम = इनपुट
         उपयोगकर्ता नाम जे: एस (लव)
         उपयोगकर्ता नाम के: एस (नफरत)

मेह आउटपुट = हाय, उपयोगकर्ता नाम :(END) LOVE OUTPUT = आपसे मिलकर कितना अच्छा लगा, यूजरनेम :(END) हेट आउटपुट = ओह। यह आप हैं, उपयोगकर्ता नाम अंत </वाक्यविन्यास हाइलाइट>

इनपुट का अनुरोध तब तक जारी रखने के लिए जब तक कि कोई और इनपुट न हो...

<वाक्यविन्यास हाईलाइट लैंग = स्नोबोल>

         OUTPUT = यह क्रमानुदेश आपसे व्यक्तिगत नाम पूछेगा
         OUTPUT = जब तक आप रिटर्न दिए बिना रिटर्न दबाते हैं
         NameCount = 0 :(GETINPUT)

दोबारा नाम गणना = नाम गणना + 1

         आउटपुट = नाम नाम गणना: व्यक्तिगत नाम

GETINPUT OUTPUT = कृपया मुझे नाम दें NameCount + 1

         व्यक्तिगत नाम = इनपुट
         व्यक्तिगत नाम लेन (1): एस (फिर से)
         आउटपुट = समाप्त। नाम गणना नाम का अनुरोध किया।

अंत </वाक्यविन्यास हाइलाइट>

कार्यान्वयन

उत्कृष्ट कार्यान्वयन PDP-10 पर था; इसका उपयोग संकलक, औपचारिक व्याकरण और कृत्रिम बुद्धिमत्ता, विशेष रूप से मशीनी अनुवाद और प्राकृतिक भाषाओं की मशीन समझ के अध्ययन के लिए किया गया है। मूल कार्यान्वयन बेल प्रयोगशाला, होल्मडेल, एन.जे. में IBM 7090 पर था। स्नोबॉल4 को विशेष रूप से सुवाह्यता के लिए अभिकल्पित किया गया था; पहला कार्यान्वयन 1966 में IBM 7094 पर प्रारम्भ किया गया था, लेकिन 1967 में IBM 360 पर पूरा हुआ। इसे तेजी से कई अन्य मंच पर रख दिया गया।

इसकी कुछ बहुत उच्च-स्तरीय सुविधाओं को लागू करने में कठिनाई के कारण इसे सामान्यतः एक दुभाषिया (कंप्यूटर सॉफ्टवेयर) के रूप में लागू किया जाता है, लेकिन एक संकलक है, स्पिटबॉल संकलक, जो दुभाषिया द्वारा प्रदान की जाने वाली लगभग सभी सुविधाएं प्रदान करता है।

PDP-10 पर उत्कृष्ट कार्यान्वयन अत्यंत धीमा था, और 1972 में बेल प्रयोगशाला, होल्मडेल, एन.जे. के जेम्स गिंपेल ने PDP-10 के लिए स्नोबॉल4 का मूल कार्यान्वयन प्रस्तुत किया जिसे उन्होंने सिटबॉल नाम दिया। उन्होंने श्रृंखला प्रसंस्करण में एक स्नातक वर्ग के आधार के रूप में अभिकल्पना का उपयोग किया जो उन्होंने उस वर्ष स्टीवंस इंस्टीट्यूट ऑफ टेक्नोलॉजी में पढ़ाया था (इसीलिए इसे सिटबॉल नाम दिया गया था)। छात्रों को (PDP-10 समायोजक में) लागू करने के लिए अनुभाग दिए गए थे और पूरा सत्र सिटबॉल को लागू करने पर केंद्रित था। यह सत्र के अंत तक 80% से अधिक पूरा हो गया था और बाद में गर्मियों में प्रोफेसर गिंपेल और कई छात्रों द्वारा पूरा किया गया था। सिटबॉल एक पूर्ण विशेषताओं वाला, उच्च प्रदर्शन वाला स्नोबॉल4 दुभाषिया था।

GNAT Ada (क्रमादेशन भाषा) संकलनकर्ता एक संकुल (GNAT.स्पिटबॉल) के साथ आता है जो सभी स्पिटबॉल श्रृंखला प्रकलन अर्थविज्ञान को लागू करता है। इसे एडा कार्यक्रम के भीतर से बुलाया जा सकता है।

मिशिगन टर्मिनल सिस्टम (MTS) के लिए फाइल एडिटर ने स्नोबॉल4 प्रतिरूप के आधार पर प्रतिरूप मिलान प्रदान किया।[11] वर्तमान में कई कार्यान्वयन उपलब्ध हैं। फिल बडने द्वारा लिखित Macro स्नोबॉल4 in C एक मुक्त, खुला स्रोत कार्यान्वयन है, जो लगभग किसी भी मंच पर चलने में सक्षम है।[12] Catspaw, Inc ने DOS, Macintosh, Sun, RS/6000, और अन्य सहित कई अलग-अलग कंप्यूटर प्लेटफार्मों के लिए स्नोबॉल4 भाषा का व्यावसायिक कार्यान्वयन प्रदान किया, और ये कार्यान्वयन अब Catspaw से मुक्त उपलब्ध हैं। मिनेसोटा स्नोबॉल4, विक्टर्स बर्स्टिस द्वारा, मूल IBM मेनफ्रेम संस्करण (यहां तक ​​कि फोरट्रान-जैसे FORMAT स्टेटमेंट समर्थन सहित) के निकटतम पीसी कार्यान्वयन भी मुफ्त है।[13] हालांकि स्नोबॉल में स्वयं कोई संरचित क्रमादेशन विशेषताएं नहीं हैं, बर्फानी तूफ़ान नामक एक स्नोबॉल प्रीप्रोसेसर को मिशिगन विश्वविद्यालय में मिशिगन टर्मिनल सिस्टम (MTS) के तहत उपयोग के लिए 1970 के दशक के दौरान फ्रेड जी. स्वार्ट्ज द्वारा अभिकल्पना और कार्यान्वित किया गया था।[14] MTS चलाने वाली आठ से पंद्रह साइटों पर स्नोस्टॉर्म का उपयोग किया गया था। यह 1982 और 1984 के बीच यूनिवर्सिटी कॉलेज लंदन (यूसीएल) में भी उपलब्ध था।

एंड्रयू कोएनिग (क्रमादेशक) द्वारा स्नोकोन स्नोबॉल4 भाषा में ब्लॉक-संरचित निर्माण जोड़ता है। स्नोकोन स्नोबॉल4 के उचित सुपरसेट के बजाय एक स्व-निहित क्रमादेशन भाषा है।[15] स्पिटबॉल कार्यान्वयन ने कई विशेषताओं को भी प्रस्तुत किया, जो पारंपरिक संरचित क्रमादेशन कीवर्ड का उपयोग नहीं करते हुए, फिर भी कई समकक्ष क्षमताओं को प्रदान करने के लिए उपयोग किया जा सकता है, जिन्हें आमतौर पर संरचित क्रमादेशन के रूप में माना जाता है, विशेष रूप से नेस्टेड if/then/else प्रकार के निर्माण। तब से इन सुविधाओं को नवीनतम स्नोबॉल4 कार्यान्वयन में जोड़ा गया है। वाणिज्यिक उत्पाद के रूप में कई वर्षों के बाद, अप्रैल 2009 में स्पिटबॉल को जीएनयू जनरल पब्लिक लाइसेंस के तहत मुफ्त सॉफ्टवेयर के रूप में जारी किया गया।

नामकरण

डेव फार्बर के अनुसार,[16] वह, ग्रिसवॉल्ड और पोलोन्स्की अंत में प्रतीकात्मक अभिव्यक्ति दुभाषिया SEXI के नाम पर पहुंचे।

All went well until one day I was submitting a batch job to assemble the system and as normal on my JOB card — the first card in the deck, I, in BTL standards, punched my job and my name — SEXI Farber.

One of the Comp Center girls looked at it and said, "That's what you think" in a humorous way.

That made it clear that we needed another name!! We sat and talked and drank coffee and shot rubber bands and after much too much time someone said — most likely Ralph — "We don't have a Snowball's chance in hell of finding a name". All of us yelled at once, "WE GOT IT — SNOBOL" in the spirit of all the BOL languages. We then stretched our mind to find what it stood for.

स्नोबॉल के सामान्य संक्षिप्त नाम हैं 'श्रृंखला उन्मुख सिम्बोलिक लैंग्वेज'[17] या (एक परिवर्णी शब्द और इनिशियलिज़्म|अर्ध-प्रारंभिकवाद के रूप में) 'श्रृंखला उन्मुख सिम्बोलिक लैंग्वेज'।[18]


यह भी देखें

संदर्भ

  1. Ierusalimschy, Roberto; de Figueiredo, Luiz Henrique; Celes, Waldemar (2007), "The Evolution of Lua" (PDF), HOPL III: Proceedings of the third ACM SIGPLAN conference on History of programming languages: 26, doi:10.1145/1238844.1238846
  2. Gimpel, J. F. (February 1973). "A theory of discrete patterns and their implementation in SNOBOL4". Communications of the ACM. 16 (2): 91-100. doi:10.1145/361952.361960. S2CID 17059429.
  3. "Dr. Dobb's: Programs That Transform Their Own Source Code; or: the Snobol Foot Joke". Dobbscodetalk.com. Retrieved 2011-12-04.
  4. Contact details. "perlre". perldoc.perl.org. Retrieved 2011-12-04.
  5. "Recursive Regex Tutorial". Retrieved 2017-03-19.
  6. Griswold, Ralph E.; Hanson, David R. (April 1977). "An Overview of SL5". ACM SIGPLAN Notices. 12 (4): 40–50. doi:10.1145/954654.954658. S2CID 38692673.
  7. See Chapter 1 of The Macro Implementation of SNOBOL4
  8. SNOBOL4 has been implemented using C to recreate the virtual machine instructions.
  9. Griswold, Ralph (1978). "A history of the SNOBOL programming languages" (PDF). ACM SIGPLAN Notices. 13 (8): 275–308. doi:10.1145/960118.808393. S2CID 5413577. Archived from the original (PDF) on 2019-03-02.
  10. Wexelblat, Richard L., ed. (2014) [1981]. History of Programming Languages. Academic Press. p. 784. ISBN 9781483266169.
  11. Introduction to the MTS file editor, University of Michigan Computing Center, 1986.
  12. "SNOBOL4.ORG -- SNOBOL4 Resources".
  13. "The MINNESOTA SNOBOL4 Programming Language".
  14. "SNOSTORM", MTS Volume 9: SNOBOL4 in MTS, Computing Center, University of Michigan, June 1979, pages 99-120. Retrieved 1 September 2014.
  15. "The Snocone Programming Language", Andrew Koenig, USENIX (Portland, Oregon), June 1985. Retrieved 2 September 2014.
  16. WORTH READING Wikipedia entry on SNOBOL — the TRUE story NOT Wikipedias (Dave Farber, Interesting People mailing list, 26 December 2008)
  17. Computers and the humanities 1:158, 1967.
  18. Belzer, Jack; Holzman, Albert G.; Kent, Allen, eds. (1979). "SNOBOL". Encyclopedia of Computer Science and Technology. Vol. 13. CRC Press. p. 173. ISBN 0-8247-2263-9.


अग्रिम पठन

  • Emmer, Mark B. (1985). SNOBOL4+: The SNOBOL4 Language for the Personal Computer User. Prentice Hall. ISBN 0-13-815119-9.
  • Gimpel, James F. (1976). Algorithms in SNOBOL4. Wiley. ISBN 0-471-30213-9. republished Salida, CO: Catspaw, 1986 (ISBN 0-939793-00-8).
  • Griswold, Ralph E. (1972). The Macro Implementation of SNOBOL4. W.H. Freeman. ISBN 0-7167-0447-1.
  • Griswold, Ralph E.; Poage, J.F.; Polonsky, I.P. (1968). The SNOBOL4 Programming Language. Prentice Hall. ISBN 0-13-815373-6.
  • Griswold, Ralph E. (1975). String and List Processing in SNOBOL4: Techniques and Applications. Prentice Hall. ISBN 0-13-853010-6.
  • Hockey, Susan M. (1985). Snobol Programming for the Humanities. Clarendon Press. ISBN 0-19-824676-5.


बाहरी संबंध