सहसंयोजन

From Vigyanwiki
Revision as of 21:54, 24 July 2023 by alpha>Indicwiki (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...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)

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

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

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

कोडाटा उत्पन्न करने और उसमें हेरफेर करने के लिए, आमतौर पर आलसी मूल्यांकन के साथ, 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