सहसंयोजन: Difference between revisions

From Vigyanwiki
(Created page with "{{about|computer science|the term in abstract algebra|Change of rings|the use of this term in medicine and anaesthesia|coinduction (anaesthetics)}} {{multiple issues| {{techni...")
 
No edit summary
Line 1: Line 1:
{{about|computer science|the term in abstract algebra|Change of rings|the use of this term in medicine and anaesthesia|coinduction (anaesthetics)}}
{{about|computer science|the term in abstract algebra|Change of rings|the use of this term in medicine and anaesthesia|coinduction (anaesthetics)}}
{{multiple issues|
[[कंप्यूटर विज्ञान]] में, सहसंयोजन समवर्ती इंटरैक्टिंग [[ऑब्जेक्ट (कंप्यूटिंग)]] के सिस्टम के गुणों को परिभाषित करने और साबित करने की तकनीक है।
{{technical|date=October 2011}}
{{primary sources|date=November 2019}}
}}
[[कंप्यूटर विज्ञान]] में, सहसंयोजन समवर्ती इंटरैक्टिंग [[ऑब्जेक्ट (कंप्यूटिंग)]] के सिस्टम के गुणों को परिभाषित करने और साबित करने की एक तकनीक है।


सहसंयोजन [[संरचनात्मक प्रेरण]] का [[गणित]]ीय दोहरा (श्रेणी सिद्धांत) है।{{citation needed|date=January 2023}} संयोगात्मक रूप से परिभाषित प्रकारों को कोडाटा के रूप में जाना जाता है और आमतौर पर [[अनंतता]] [[डेटा संरचनाएं]] होती हैं, जैसे [[स्ट्रीम (कंप्यूटिंग)]]।
सहसंयोजन [[संरचनात्मक प्रेरण]] का [[गणित]]ीय दोहरा (श्रेणी सिद्धांत) है। संयोगात्मक रूप से परिभाषित प्रकारों को कोडाटा के रूप में जाना जाता है और आमतौर पर [[अनंतता]] [[डेटा संरचनाएं]] होती हैं, जैसे [[स्ट्रीम (कंप्यूटिंग)]]।


एक परिभाषा या विनिर्देश (कंप्यूटिंग) के रूप में, सहसंयोजन वर्णन करता है कि किसी वस्तु को कैसे देखा जा सकता है, तोड़ा जा सकता है या सरल वस्तुओं में नष्ट किया जा सकता है। एक [[प्रमाण (गणित)]] तकनीक के रूप में, इसका उपयोग यह दिखाने के लिए किया जा सकता है कि एक समीकरण ऐसे विनिर्देश के सभी संभावित [[कार्यान्वयन (कंप्यूटिंग)]] से संतुष्ट है।
एक परिभाषा या विनिर्देश (कंप्यूटिंग) के रूप में, सहसंयोजन वर्णन करता है कि किसी वस्तु को कैसे देखा जा सकता है, तोड़ा जा सकता है या सरल वस्तुओं में नष्ट किया जा सकता है। [[प्रमाण (गणित)]] तकनीक के रूप में, इसका उपयोग यह दिखाने के लिए किया जा सकता है कि समीकरण ऐसे विनिर्देश के सभी संभावित [[कार्यान्वयन (कंप्यूटिंग)]] से संतुष्ट है।


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


प्रोग्रामिंग में, सह-तर्क प्रोग्रामिंग (संक्षिप्तता के लिए सह-एलपी) तर्क प्रोग्रामिंग और संयोगात्मक तर्क प्रोग्रामिंग का एक प्राकृतिक सामान्यीकरण है, जो बदले में तर्क प्रोग्रामिंग के अन्य विस्तारों को सामान्यीकृत करता है, जैसे कि अनंत पेड़, आलसी विधेय, और समवर्ती संचार विधेय। सह-एलपी में तर्कसंगत पेड़ों, अनंत गुणों की पुष्टि, आलसी मूल्यांकन, समवर्ती तर्क प्रोग्रामिंग, मॉडल जांच, [[द्विसमानता]] प्रमाण इत्यादि के अनुप्रयोग हैं।<ref>{{Cite web|url=http://lambda-the-ultimate.org/node/2513|title = Co-Logic Programming &#124; Lambda the Ultimate}}</ref> सह-एलपी के प्रायोगिक कार्यान्वयन [[डलास में टेक्सास विश्वविद्यालय]] से उपलब्ध हैं<ref>{{Cite web|url=http://www.utdallas.edu/~gupta/|title = Gopal Gupta's Home Page}}</ref> और [[लॉगटॉक]] में (उदाहरण के लिए देखें <ref>{{Cite web|url=https://github.com/LogtalkDotOrg/logtalk3/tree/master/examples/coinduction|title = Logtalk3/Examples/Coinduction at master · LogtalkDotOrg/Logtalk3|website = [[GitHub]]}}</ref>) और [[एसडब्ल्यूआई-प्रोलॉग]]।
प्रोग्रामिंग में, सह-तर्क प्रोग्रामिंग (संक्षिप्तता के लिए सह-एलपी) तर्क प्रोग्रामिंग और संयोगात्मक तर्क प्रोग्रामिंग का प्राकृतिक सामान्यीकरण है, जो बदले में तर्क प्रोग्रामिंग के अन्य विस्तारों को सामान्यीकृत करता है, जैसे कि अनंत पेड़, आलसी विधेय, और समवर्ती संचार विधेय। सह-एलपी में तर्कसंगत पेड़ों, अनंत गुणों की पुष्टि, आलसी मूल्यांकन, समवर्ती तर्क प्रोग्रामिंग, मॉडल जांच, [[द्विसमानता]] प्रमाण इत्यादि के अनुप्रयोग हैं।<ref>{{Cite web|url=http://lambda-the-ultimate.org/node/2513|title = Co-Logic Programming &#124; Lambda the Ultimate}}</ref> सह-एलपी के प्रायोगिक कार्यान्वयन [[डलास में टेक्सास विश्वविद्यालय]] से उपलब्ध हैं<ref>{{Cite web|url=http://www.utdallas.edu/~gupta/|title = Gopal Gupta's Home Page}}</ref> और [[लॉगटॉक]] में (उदाहरण के लिए देखें <ref>{{Cite web|url=https://github.com/LogtalkDotOrg/logtalk3/tree/master/examples/coinduction|title = Logtalk3/Examples/Coinduction at master · LogtalkDotOrg/Logtalk3|website = [[GitHub]]}}</ref>) और [[एसडब्ल्यूआई-प्रोलॉग]]।


== विवरण ==
== विवरण ==
में <ref>{{Cite web|url=https://mitpress.mit.edu/9780262303828/types-and-programming-languages/|title = प्रकार और प्रोग्रामिंग भाषाएँ|author = Benjamin Pierce|website = The MIT Press}}</ref> प्रेरण के सिद्धांत और सह-आगमन के सिद्धांत दोनों का एक संक्षिप्त विवरण दिया गया है। हालाँकि यह लेख मुख्य रूप से प्रेरण से संबंधित नहीं है, फिर भी उनके कुछ हद तक सामान्यीकृत रूपों पर एक साथ विचार करना उपयोगी है। सिद्धांतों को बताने के लिए कुछ प्रारंभिक बातों की आवश्यकता होती है।
में <ref>{{Cite web|url=https://mitpress.mit.edu/9780262303828/types-and-programming-languages/|title = प्रकार और प्रोग्रामिंग भाषाएँ|author = Benjamin Pierce|website = The MIT Press}}</ref> प्रेरण के सिद्धांत और सह-आगमन के सिद्धांत दोनों का संक्षिप्त विवरण दिया गया है। हालाँकि यह लेख मुख्य रूप से प्रेरण से संबंधित नहीं है, फिर भी उनके कुछ हद तक सामान्यीकृत रूपों पर साथ विचार करना उपयोगी है। सिद्धांतों को बताने के लिए कुछ प्रारंभिक बातों की आवश्यकता होती है।


=== प्रारंभिक ===
=== प्रारंभिक ===


होने देना <math>U</math> एक सेट हो और <math>F</math> एक मोनोटोनिक फ़ंक्शन बनें#क्रम सिद्धांत में <math>2^U \rightarrow 2^U</math>, वह है:
होने देना <math>U</math> सेट हो और <math>F</math> मोनोटोनिक फ़ंक्शन बनें#क्रम सिद्धांत में <math>2^U \rightarrow 2^U</math>, वह है:


: <math> X \subseteq Y \Rightarrow F(X) \subseteq F(Y) </math>
: <math> X \subseteq Y \Rightarrow F(X) \subseteq F(Y) </math>
Line 27: Line 23:
: यदि X, F-संगत है <math>X \subseteq F(X) </math>
: यदि X, F-संगत है <math>X \subseteq F(X) </math>
: <math>X = F(X) </math>
: <math>X = F(X) </math>
इन शब्दों को निम्नलिखित तरीके से सहज रूप से समझा जा सकता है। लगता है कि <math>X</math> अभिकथनों का एक समूह है, और <math>F(X)</math> वह ऑपरेशन है जो इसके निहितार्थ लेता है <math>X</math>. तब <math>X</math> एफ-बंद है जब आप पहले से ही दावा किए गए से अधिक निष्कर्ष नहीं निकाल सकते हैं <math>X</math> एफ-संगत है जब आपके सभी दावे अन्य दावों द्वारा समर्थित हैं (यानी कोई गैर-एफ-तार्किक धारणाएं नहीं हैं)।
इन शब्दों को निम्नलिखित तरीके से सहज रूप से समझा जा सकता है। लगता है कि <math>X</math> अभिकथनों का समूह है, और <math>F(X)</math> वह ऑपरेशन है जो इसके निहितार्थ लेता है <math>X</math>. तब <math>X</math> एफ-बंद है जब आप पहले से ही दावा किए गए से अधिक निष्कर्ष नहीं निकाल सकते हैं <math>X</math> एफ-संगत है जब आपके सभी दावे अन्य दावों द्वारा समर्थित हैं (यानी कोई गैर-एफ-तार्किक धारणाएं नहीं हैं)।


नैस्टर-टार्स्की प्रमेय हमें बताता है कि सबसे कम निश्चित बिंदु <math>F</math> (संकेतित <math>\mu F</math>) सभी एफ-बंद सेटों के प्रतिच्छेदन द्वारा दिया गया है, जबकि सबसे बड़ा निश्चित-बिंदु (निरूपित)। <math>\nu F</math>) सभी एफ-संगत सेटों के संघ द्वारा दिया गया है। अब हम प्रेरण और सह-आगमन के सिद्धांतों को बता सकते हैं।
नैस्टर-टार्स्की प्रमेय हमें बताता है कि सबसे कम निश्चित बिंदु <math>F</math> (संकेतित <math>\mu F</math>) सभी एफ-बंद सेटों के प्रतिच्छेदन द्वारा दिया गया है, जबकि सबसे बड़ा निश्चित-बिंदु (निरूपित)। <math>\nu F</math>) सभी एफ-संगत सेटों के संघ द्वारा दिया गया है। अब हम प्रेरण और सह-आगमन के सिद्धांतों को बता सकते हैं।
Line 39: Line 35:
==चर्चा==
==चर्चा==


जैसा कि कहा गया है, सिद्धांत कुछ हद तक अपारदर्शी हैं, लेकिन निम्नलिखित तरीके से उपयोगी ढंग से सोचा जा सकता है। मान लीजिए आप किसी संपत्ति को साबित करना चाहते हैं <math>\mu F</math>. प्रेरण के सिद्धांत के अनुसार, यह एक एफ-बंद सेट प्रदर्शित करने के लिए पर्याप्त है <math>X</math> जिसके लिए संपत्ति धारण की जाती है। वैसे, मान लीजिए आप यह दिखाना चाहते हैं <math>x \in \nu F</math>. फिर यह एक एफ-संगत सेट प्रदर्शित करने के लिए पर्याप्त है <math>x</math> का सदस्य माना जाता है।
जैसा कि कहा गया है, सिद्धांत कुछ हद तक अपारदर्शी हैं, लेकिन निम्नलिखित तरीके से उपयोगी ढंग से सोचा जा सकता है। मान लीजिए आप किसी संपत्ति को साबित करना चाहते हैं <math>\mu F</math>. प्रेरण के सिद्धांत के अनुसार, यह एफ-बंद सेट प्रदर्शित करने के लिए पर्याप्त है <math>X</math> जिसके लिए संपत्ति धारण की जाती है। वैसे, मान लीजिए आप यह दिखाना चाहते हैं <math>x \in \nu F</math>. फिर यह एफ-संगत सेट प्रदर्शित करने के लिए पर्याप्त है <math>x</math> का सदस्य माना जाता है।


== उदाहरण ==
== उदाहरण ==


=== [[डेटा प्रकार]] के एक सेट को परिभाषित करना ===
=== [[डेटा प्रकार]] के सेट को परिभाषित करना ===


डेटाटाइप के निम्नलिखित व्याकरण पर विचार करें:
डेटाटाइप के निम्नलिखित व्याकरण पर विचार करें:
Line 51: Line 47:


: <math> F(X) = \{\bot, \top\} \cup \{ x \times y : x,y \in X \} </math>
: <math> F(X) = \{\bot, \top\} \cup \{ x \times y : x,y \in X \} </math>
इस संदर्भ में, <math>x \times y</math> मतलब स्ट्रिंग का संयोजन <math>x</math>, प्रतीक <math>\times</math>, और स्ट्रिंग <math>y</math>. अब हमें अपने डेटाटाइप्स के सेट को एक फिक्सपॉइंट के रूप में परिभाषित करना चाहिए <math>F</math>, लेकिन यह मायने रखता है कि हम सबसे कम या सबसे बड़ा फिक्सपॉइंट लेते हैं या नहीं।
इस संदर्भ में, <math>x \times y</math> मतलब स्ट्रिंग का संयोजन <math>x</math>, प्रतीक <math>\times</math>, और स्ट्रिंग <math>y</math>. अब हमें अपने डेटाटाइप्स के सेट को फिक्सपॉइंट के रूप में परिभाषित करना चाहिए <math>F</math>, लेकिन यह मायने रखता है कि हम सबसे कम या सबसे बड़ा फिक्सपॉइंट लेते हैं या नहीं।


मान लीजिए हम लेते हैं <math>\mu F</math> हमारे डेटाटाइप्स के सेट के रूप में। प्रेरण के सिद्धांत का उपयोग करके, हम निम्नलिखित दावे को सिद्ध कर सकते हैं:
मान लीजिए हम लेते हैं <math>\mu F</math> हमारे डेटाटाइप्स के सेट के रूप में। प्रेरण के सिद्धांत का उपयोग करके, हम निम्नलिखित दावे को सिद्ध कर सकते हैं:
Line 57: Line 53:
: सभी डेटाप्रकार <math>\mu F</math> परिमित हैं
: सभी डेटाप्रकार <math>\mu F</math> परिमित हैं


इस निष्कर्ष पर पहुंचने के लिए, सभी परिमित तारों के समुच्चय पर विचार करें <math>\Sigma</math>. स्पष्ट रूप से <math>F</math> एक अनंत स्ट्रिंग उत्पन्न नहीं कर सकता, इसलिए यह पता चला कि यह सेट एफ-बंद है और निष्कर्ष इस प्रकार है।
इस निष्कर्ष पर पहुंचने के लिए, सभी परिमित तारों के समुच्चय पर विचार करें <math>\Sigma</math>. स्पष्ट रूप से <math>F</math> अनंत स्ट्रिंग उत्पन्न नहीं कर सकता, इसलिए यह पता चला कि यह सेट एफ-बंद है और निष्कर्ष इस प्रकार है।


अब मान लीजिए कि हम लेते हैं <math>\nu F</math> हमारे डेटाटाइप्स के सेट के रूप में। हम निम्नलिखित दावे को साबित करने के लिए सह-आगमन के सिद्धांत का उपयोग करना चाहेंगे:
अब मान लीजिए कि हम लेते हैं <math>\nu F</math> हमारे डेटाटाइप्स के सेट के रूप में। हम निम्नलिखित दावे को साबित करने के लिए सह-आगमन के सिद्धांत का उपयोग करना चाहेंगे:
Line 81: Line 77:
tail (S a astream) = astream
tail (S a astream) = astream
</syntaxhighlight>
</syntaxhighlight>
यह एक ऐसी परिभाषा प्रतीत होती है जो गैर-अच्छी तरह से स्थापित_सेट_सिद्धांत है| अच्छी तरह से स्थापित नहीं है, लेकिन फिर भी यह प्रोग्रामिंग में उपयोगी है और इसके बारे में तर्क किया जा सकता है। किसी भी स्थिति में, एक स्ट्रीम तत्वों की एक अनंत सूची है जिसमें से आप पहले तत्व का निरीक्षण कर सकते हैं, या दूसरी स्ट्रीम प्राप्त करने के लिए एक तत्व को सामने रख सकते हैं।
यह ऐसी परिभाषा प्रतीत होती है जो गैर-अच्छी तरह से स्थापित_सेट_सिद्धांत है| अच्छी तरह से स्थापित नहीं है, लेकिन फिर भी यह प्रोग्रामिंग में उपयोगी है और इसके बारे में तर्क किया जा सकता है। किसी भी स्थिति में, स्ट्रीम तत्वों की अनंत सूची है जिसमें से आप पहले तत्व का निरीक्षण कर सकते हैं, या दूसरी स्ट्रीम प्राप्त करने के लिए तत्व को सामने रख सकते हैं।


=== [[ कोलजेब्रा में ]]|एफ-कोलजेब्रा के साथ संबंध<ref>{{Cite book|chapter-url=https://link.springer.com/chapter/10.1007/978-3-642-32202-0_2|chapter = Generic Programming with Adjunctions|author = Ralf Hinze| title=सामान्य और अनुक्रमित प्रोग्रामिंग|website = Springer| series=Lecture Notes in Computer Science | year=2012 | volume=7470 | pages=47–129 | doi=10.1007/978-3-642-32202-0_2 | isbn=978-3-642-32201-3 }}</ref> ===
=== [[ कोलजेब्रा में ]]|एफ-कोलजेब्रा के साथ संबंध<ref>{{Cite book|chapter-url=https://link.springer.com/chapter/10.1007/978-3-642-32202-0_2|chapter = Generic Programming with Adjunctions|author = Ralf Hinze| title=सामान्य और अनुक्रमित प्रोग्रामिंग|website = Springer| series=Lecture Notes in Computer Science | year=2012 | volume=7470 | pages=47–129 | doi=10.1007/978-3-642-32202-0_2 | isbn=978-3-642-32201-3 }}</ref> ===
Line 92: Line 88:


: <math> \mathrm{out}: \nu F \rightarrow F(\nu F) = A \times \nu F </math>
: <math> \mathrm{out}: \nu F \rightarrow F(\nu F) = A \times \nu F </math>
यह एक और कोलजेब्रा को प्रेरित करता है <math>F(\nu F)</math> संबद्ध रूपवाद के साथ <math>F(\mathrm{out})</math>. क्योंकि <math>\nu F</math> अंतिम है, एक अद्वितीय रूपवाद है
यह और कोलजेब्रा को प्रेरित करता है <math>F(\nu F)</math> संबद्ध रूपवाद के साथ <math>F(\mathrm{out})</math>. क्योंकि <math>\nu F</math> अंतिम है, अद्वितीय रूपवाद है


: <math> \overline{F(\mathrm{out})}: F(\nu F) \rightarrow \nu F </math>
: <math> \overline{F(\mathrm{out})}: F(\nu F) \rightarrow \nu F </math>
Line 99: Line 95:
: <math> \mathrm{out} \circ \overline{F(\mathrm{out})} = F\left(\overline{F(\mathrm{out})}\right) \circ F(\mathrm{out})  
: <math> \mathrm{out} \circ \overline{F(\mathrm{out})} = F\left(\overline{F(\mathrm{out})}\right) \circ F(\mathrm{out})  
= F\left(\overline{F(\mathrm{out})} \circ \mathrm{out}\right)</math>
= F\left(\overline{F(\mathrm{out})} \circ \mathrm{out}\right)</math>
रचना <math>\overline{F(\mathrm{out})} \circ \mathrm{out}</math> एक और एफ-कोलजेब्रा समरूपता को प्रेरित करता है <math>\nu F \rightarrow \nu F</math>. तब से <math>\nu F</math> अंतिम है, यह समरूपता अद्वितीय है और इसलिए <math>\mathrm{id}_{\nu F}</math>. कुल मिलाकर हमारे पास है:
रचना <math>\overline{F(\mathrm{out})} \circ \mathrm{out}</math> और एफ-कोलजेब्रा समरूपता को प्रेरित करता है <math>\nu F \rightarrow \nu F</math>. तब से <math>\nu F</math> अंतिम है, यह समरूपता अद्वितीय है और इसलिए <math>\mathrm{id}_{\nu F}</math>. कुल मिलाकर हमारे पास है:


: <math> \overline{F(\mathrm{out})} \circ \mathrm{out} = \mathrm{id}_{\nu F} </math>
: <math> \overline{F(\mathrm{out})} \circ \mathrm{out} = \mathrm{id}_{\nu F} </math>
: <math> \mathrm{out} \circ \overline{F(\mathrm{out})} = F\left(\overline{F(\mathrm{out})}\right) \circ \mathrm{out}) = \mathrm{id}_{F(\nu F)} </math>
: <math> \mathrm{out} \circ \overline{F(\mathrm{out})} = F\left(\overline{F(\mathrm{out})}\right) \circ \mathrm{out}) = \mathrm{id}_{F(\nu F)} </math>
यह समरूपता का साक्षी है <math>\nu F \simeq F(\nu F)</math>, जो स्पष्ट शब्दों में इंगित करता है <math>\nu F</math> का एक निश्चित बिंदु है <math>F</math> और अंकन को उचित ठहराता है।
यह समरूपता का साक्षी है <math>\nu F \simeq F(\nu F)</math>, जो स्पष्ट शब्दों में इंगित करता है <math>\nu F</math> का निश्चित बिंदु है <math>F</math> और अंकन को उचित ठहराता है।


==== अंतिम कोलजेब्रा के रूप में स्ट्रीम करें ====
==== अंतिम कोलजेब्रा के रूप में स्ट्रीम करें ====

Revision as of 08:52, 5 August 2023

कंप्यूटर विज्ञान में, सहसंयोजन समवर्ती इंटरैक्टिंग ऑब्जेक्ट (कंप्यूटिंग) के सिस्टम के गुणों को परिभाषित करने और साबित करने की तकनीक है।

सहसंयोजन संरचनात्मक प्रेरण का गणितीय दोहरा (श्रेणी सिद्धांत) है। संयोगात्मक रूप से परिभाषित प्रकारों को कोडाटा के रूप में जाना जाता है और आमतौर पर अनंतता डेटा संरचनाएं होती हैं, जैसे स्ट्रीम (कंप्यूटिंग)

एक परिभाषा या विनिर्देश (कंप्यूटिंग) के रूप में, सहसंयोजन वर्णन करता है कि किसी वस्तु को कैसे देखा जा सकता है, तोड़ा जा सकता है या सरल वस्तुओं में नष्ट किया जा सकता है। प्रमाण (गणित) तकनीक के रूप में, इसका उपयोग यह दिखाने के लिए किया जा सकता है कि समीकरण ऐसे विनिर्देश के सभी संभावित कार्यान्वयन (कंप्यूटिंग) से संतुष्ट है।

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

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

विवरण

में [4] प्रेरण के सिद्धांत और सह-आगमन के सिद्धांत दोनों का संक्षिप्त विवरण दिया गया है। हालाँकि यह लेख मुख्य रूप से प्रेरण से संबंधित नहीं है, फिर भी उनके कुछ हद तक सामान्यीकृत रूपों पर साथ विचार करना उपयोगी है। सिद्धांतों को बताने के लिए कुछ प्रारंभिक बातों की आवश्यकता होती है।

प्रारंभिक

होने देना सेट हो और मोनोटोनिक फ़ंक्शन बनें#क्रम सिद्धांत में , वह है:

जब तक अन्यथा न कहा जाए, एकरस माना जाएगा।

X, F-बंद है यदि
यदि X, F-संगत है

इन शब्दों को निम्नलिखित तरीके से सहज रूप से समझा जा सकता है। लगता है कि अभिकथनों का समूह है, और वह ऑपरेशन है जो इसके निहितार्थ लेता है . तब एफ-बंद है जब आप पहले से ही दावा किए गए से अधिक निष्कर्ष नहीं निकाल सकते हैं एफ-संगत है जब आपके सभी दावे अन्य दावों द्वारा समर्थित हैं (यानी कोई गैर-एफ-तार्किक धारणाएं नहीं हैं)।

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

परिभाषा

प्रेरण का सिद्धांत: यदि तो, एफ-बंद है
सहसंयोजन का सिद्धांत: यदि तो, F-संगत है


चर्चा

जैसा कि कहा गया है, सिद्धांत कुछ हद तक अपारदर्शी हैं, लेकिन निम्नलिखित तरीके से उपयोगी ढंग से सोचा जा सकता है। मान लीजिए आप किसी संपत्ति को साबित करना चाहते हैं . प्रेरण के सिद्धांत के अनुसार, यह एफ-बंद सेट प्रदर्शित करने के लिए पर्याप्त है जिसके लिए संपत्ति धारण की जाती है। वैसे, मान लीजिए आप यह दिखाना चाहते हैं . फिर यह एफ-संगत सेट प्रदर्शित करने के लिए पर्याप्त है का सदस्य माना जाता है।

उदाहरण

डेटा प्रकार के सेट को परिभाषित करना

डेटाटाइप के निम्नलिखित व्याकरण पर विचार करें:

अर्थात्, प्रकारों के सेट में निचला प्रकार भी शामिल है , शीर्ष प्रकार , और (गैर-समरूप) सूचियाँ। इन प्रकारों को वर्णमाला के ऊपर तारों से पहचाना जा सकता है . होने देना सभी स्ट्रिंग्स को निरूपित करें . फ़ंक्शन पर विचार करें :

इस संदर्भ में, मतलब स्ट्रिंग का संयोजन , प्रतीक , और स्ट्रिंग . अब हमें अपने डेटाटाइप्स के सेट को फिक्सपॉइंट के रूप में परिभाषित करना चाहिए , लेकिन यह मायने रखता है कि हम सबसे कम या सबसे बड़ा फिक्सपॉइंट लेते हैं या नहीं।

मान लीजिए हम लेते हैं हमारे डेटाटाइप्स के सेट के रूप में। प्रेरण के सिद्धांत का उपयोग करके, हम निम्नलिखित दावे को सिद्ध कर सकते हैं:

सभी डेटाप्रकार परिमित हैं

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

अब मान लीजिए कि हम लेते हैं हमारे डेटाटाइप्स के सेट के रूप में। हम निम्नलिखित दावे को साबित करने के लिए सह-आगमन के सिद्धांत का उपयोग करना चाहेंगे:

प्ररूप

यहाँ सभी से मिलकर बनी अनंत सूची को दर्शाता है . सहसंयोजन के सिद्धांत का उपयोग करने के लिए, सेट पर विचार करें:

यह सेट एफ-संगत हो जाता है, और इसलिए . ये उस संदिग्ध बयान पर निर्भर करता है

इसका औपचारिक औचित्य तकनीकी है और स्ट्रिंग्स को Sequence#Formal_definition_and_basic_properties के रूप में व्याख्या करने पर निर्भर करता है, यानी से कार्य करता है . सहज रूप से, यह तर्क उस तर्क के समान है (पुनरावर्ती दशमलव#Repeating_decimals_as_infinite_series देखें)।

प्रोग्रामिंग भाषाओं में सहवर्ती डेटाप्रकार

स्ट्रीम_(कंप्यूटिंग) की निम्नलिखित परिभाषा पर विचार करें:[5]

data Stream a = S a (Stream a)

-- Stream "destructors"
head (S a astream) = a
tail (S a astream) = astream

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

कोलजेब्रा में |एफ-कोलजेब्रा के साथ संबंध[6]

फ़ंक्टर#एंडोफ़ंक्टर पर विचार करें सेट की श्रेणी में:

अंतिम एफ-कोलजेब्रा इसके साथ निम्नलिखित रूपवाद जुड़ा हुआ है:

यह और कोलजेब्रा को प्रेरित करता है संबद्ध रूपवाद के साथ . क्योंकि अंतिम है, अद्वितीय रूपवाद है

ऐसा है कि

रचना और एफ-कोलजेब्रा समरूपता को प्रेरित करता है . तब से अंतिम है, यह समरूपता अद्वितीय है और इसलिए . कुल मिलाकर हमारे पास है:

यह समरूपता का साक्षी है , जो स्पष्ट शब्दों में इंगित करता है का निश्चित बिंदु है और अंकन को उचित ठहराता है।

अंतिम कोलजेब्रा के रूप में स्ट्रीम करें

हम दिखाएंगे कि

स्ट्रीम ए

फ़नकार का अंतिम कोलजेब्रा है . निम्नलिखित कार्यान्वयन पर विचार करें:

out astream = (head astream, tail astream)
out' (a, astream) = S a astream

इन्हें आसानी से परस्पर विपरीत देखा जा सकता है, जिससे समरूपता देखी जा सकती है। अधिक विवरण के लिए संदर्भ देखें.

गणितीय प्रेरण के साथ संबंध

हम प्रदर्शित करेंगे कि कैसे प्रेरण का सिद्धांत गणितीय प्रेरण को समाहित करता है। होने देना प्राकृतिक संख्याओं की कुछ संपत्ति बनें। हम गणितीय प्रेरण की निम्नलिखित परिभाषा लेंगे:

अब फ़ंक्शन पर विचार करें :

इसे देखना कठिन नहीं होना चाहिए . अत: प्रेरण के सिद्धांत द्वारा यदि हम किसी गुण को सिद्ध करना चाहते हैं का , यह दिखाने के लिए पर्याप्त है एफ-बंद है. विस्तार से, हमें चाहिए:

वह है,

जैसा कि कहा गया है, यह बिल्कुल गणितीय प्रेरण है।

यह भी देखें

संदर्भ

  1. "Co-Logic Programming | Lambda the Ultimate".
  2. "Gopal Gupta's Home Page".
  3. "Logtalk3/Examples/Coinduction at master · LogtalkDotOrg/Logtalk3". GitHub.
  4. Benjamin Pierce. "प्रकार और प्रोग्रामिंग भाषाएँ". The MIT Press.
  5. Dexter Kozen , Alexandra Silva. "प्रैक्टिकल कॉइंडक्शन". CiteSeerX 10.1.1.252.3961.
  6. Ralf Hinze (2012). "Generic Programming with Adjunctions". सामान्य और अनुक्रमित प्रोग्रामिंग. pp. 47–129. doi:10.1007/978-3-642-32202-0_2. ISBN 978-3-642-32201-3. {{cite book}}: |website= ignored (help)


अग्रिम पठन

Textbooks
  • Davide Sangiorgi (2012). Introduction to Bisimulation and Coinduction. Cambridge University Press.
  • Davide Sangiorgi and Jan Rutten (2011). Advanced Topics in Bisimulation and Coinduction. Cambridge University Press.
Introductory texts
History
Miscellaneous