सिस्टम एफ: Difference between revisions

From Vigyanwiki
(Created page with "{{short description|Typed lambda calculus}} {{For|the electronic trance music artist|Ferry Corsten}} सिस्टम एफ (पॉलीमॉर्फिक लैम्...")
 
No edit summary
Line 31: Line 31:
बूलियन मानों के लिए निम्नलिखित दो परिभाषाएँ <math>\mathbf{T}</math> और <math>\mathbf{F}</math> उपयोग किया जाता है, चर्च एन्कोडिंग#चर्च बूलियन्स की परिभाषा का विस्तार करते हुए:
बूलियन मानों के लिए निम्नलिखित दो परिभाषाएँ <math>\mathbf{T}</math> और <math>\mathbf{F}</math> उपयोग किया जाता है, चर्च एन्कोडिंग#चर्च बूलियन्स की परिभाषा का विस्तार करते हुए:


: <math>\mathbf{T} = \Lambda\alpha{.}\lambda x^{\alpha} \lambda y^\alpha{.}x</math> <!-- These didn't render without the {}-wrapped around the . -->
: <math>\mathbf{T} = \Lambda\alpha{.}\lambda x^{\alpha} \lambda y^\alpha{.}x</math>
: <math>\mathbf{F} = \Lambda\alpha{.}\lambda x^{\alpha} \lambda y^{\alpha}{.}y</math>
: <math>\mathbf{F} = \Lambda\alpha{.}\lambda x^{\alpha} \lambda y^{\alpha}{.}y</math>
(ध्यान दें कि उपरोक्त दो कार्यों के लिए तीन - दो नहीं - तर्कों की आवश्यकता होती है। बाद वाले दो को लैम्ब्डा अभिव्यक्ति होना चाहिए, लेकिन पहला एक प्रकार होना चाहिए। यह तथ्य इस तथ्य में परिलक्षित होता है कि इन भावों का प्रकार है <math>\forall\alpha.\alpha \to \alpha \to \alpha</math>; α को बांधने वाला यूनिवर्सल क्वांटिफायर लैम्ब्डा एक्सप्रेशन में अल्फा को बांधने वाले Λ से मेल खाता है। साथ ही, ध्यान दें <math>\mathsf{Boolean}</math> के लिए एक सुविधाजनक आशुलिपि है <math>\forall\alpha.\alpha \to \alpha \to \alpha</math>, लेकिन यह स्वयं सिस्टम F का प्रतीक नहीं है, बल्कि एक मेटा-प्रतीक है। वैसे ही, <math> \mathbf{T}</math> और <math> \mathbf{F}</math> सिस्टम F असेंबली के मेटा-प्रतीक, सुविधाजनक आशुलिपि भी हैं ([https://books.google.com/books?id=IL-SI67hjI4C&q=Nicolas+Bourbaki Bourbaki sense] में); अन्यथा, यदि इस तरह के कार्यों को नामित किया जा सकता है (सिस्टम एफ के भीतर), तो लैम्ब्डा-अभिव्यंजक उपकरण की आवश्यकता नहीं होगी जो अज्ञात रूप से कार्यों को परिभाषित करने में सक्षम हो और निश्चित-बिंदु संयोजक के लिए, जो उस प्रतिबंध के आसपास काम करता है।)
(ध्यान दें कि उपरोक्त दो कार्यों के लिए तीन - दो नहीं - तर्कों की आवश्यकता होती है। बाद वाले दो को लैम्ब्डा अभिव्यक्ति होना चाहिए, लेकिन पहला एक प्रकार होना चाहिए। यह तथ्य इस तथ्य में परिलक्षित होता है कि इन भावों का प्रकार है <math>\forall\alpha.\alpha \to \alpha \to \alpha</math>; α को बांधने वाला यूनिवर्सल क्वांटिफायर लैम्ब्डा एक्सप्रेशन में अल्फा को बांधने वाले Λ से मेल खाता है। साथ ही, ध्यान दें <math>\mathsf{Boolean}</math> के लिए एक सुविधाजनक आशुलिपि है <math>\forall\alpha.\alpha \to \alpha \to \alpha</math>, लेकिन यह स्वयं सिस्टम F का प्रतीक नहीं है, बल्कि एक मेटा-प्रतीक है। वैसे ही, <math> \mathbf{T}</math> और <math> \mathbf{F}</math> सिस्टम F असेंबली के मेटा-प्रतीक, सुविधाजनक आशुलिपि भी हैं ([https://books.google.com/books?id=IL-SI67hjI4C&q=Nicolas+Bourbaki Bourbaki sense] में); अन्यथा, यदि इस तरह के कार्यों को नामित किया जा सकता है (सिस्टम एफ के भीतर), तो लैम्ब्डा-अभिव्यंजक उपकरण की आवश्यकता नहीं होगी जो अज्ञात रूप से कार्यों को परिभाषित करने में सक्षम हो और निश्चित-बिंदु संयोजक के लिए, जो उस प्रतिबंध के आसपास काम करता है।)
Line 98: Line 98:


== सिस्टम एफ<sub>&lt;:</sub> ==
== सिस्टम एफ<sub>&lt;:</sub> ==
सिस्टम एफ<sub>&lt;:</sub>, उच्चारित F-sub उपप्रकार के साथ सिस्टम F का विस्तार है। सिस्टम एफ<sub>&lt;:</sub> 1980 के दशक से [[प्रोग्रामिंग भाषा सिद्धांत]] के लिए केंद्रीय महत्व रहा है{{citation needed|date=September 2014}} क्योंकि कार्यात्मक प्रोग्रामिंग भाषाओं का मूल, जैसे एमएल (प्रोग्रामिंग भाषा) परिवार में, पैरामीट्रिक बहुरूपता और [[रिकॉर्ड (कंप्यूटर विज्ञान)]] उपप्रकार दोनों का समर्थन करता है, जिसे सिस्टम एफ में व्यक्त किया जा सकता है<sub>&lt;:</sub>.<ref>{{cite conference
सिस्टम एफ<sub>&lt;:</sub>, उच्चारित F-sub उपप्रकार के साथ सिस्टम F का विस्तार है। सिस्टम एफ<sub>&lt;:</sub> 1980 के दशक से [[प्रोग्रामिंग भाषा सिद्धांत]] के लिए केंद्रीय महत्व रहा है क्योंकि कार्यात्मक प्रोग्रामिंग भाषाओं का मूल, जैसे एमएल (प्रोग्रामिंग भाषा) परिवार में, पैरामीट्रिक बहुरूपता और [[रिकॉर्ड (कंप्यूटर विज्ञान)]] उपप्रकार दोनों का समर्थन करता है, जिसे सिस्टम एफ में व्यक्त किया जा सकता है<sub>&lt;:</sub>.<ref>{{cite conference
   | first = Luca
   | first = Luca
   | last = Cardelli |author2=Martini, Simone |author3=Mitchell, John C. |author4=Scedrov, Andre
   | last = Cardelli |author2=Martini, Simone |author3=Mitchell, John C. |author4=Scedrov, Andre
Line 117: Line 117:
==टिप्पणियाँ==
==टिप्पणियाँ==
{{Reflist}}
{{Reflist}}


==संदर्भ==
==संदर्भ==
Line 148: Line 147:
*{{cite conference |first=J. B. |last=Wells |chapter=Typability and type checking in the second-order lambda-calculus are equivalent and undecidable |title=Proceedings of the 9th Annual [[IEEE]] Symposium on Logic in Computer Science (LICS) |pages=176–185 |year=1994 |doi= 10.1109/LICS.1994.316068|isbn=0-8186-6310-3}} [http://www.macs.hw.ac.uk/~jbw/papers/Wells:Typability-and-Type-Checking-in-the-Second-Order-Lambda-Calculus-Are-Equivalent-and-Undecidable:LICS-1994.ps.gz Postscript version]
*{{cite conference |first=J. B. |last=Wells |chapter=Typability and type checking in the second-order lambda-calculus are equivalent and undecidable |title=Proceedings of the 9th Annual [[IEEE]] Symposium on Logic in Computer Science (LICS) |pages=176–185 |year=1994 |doi= 10.1109/LICS.1994.316068|isbn=0-8186-6310-3}} [http://www.macs.hw.ac.uk/~jbw/papers/Wells:Typability-and-Type-Checking-in-the-Second-Order-Lambda-Calculus-Are-Equivalent-and-Undecidable:LICS-1994.ps.gz Postscript version]
{{refend}}
{{refend}}


== अग्रिम पठन ==
== अग्रिम पठन ==
* {{cite book |last=Pierce |first=Benjamin |title=Types and Programming Languages |publisher=MIT Press |date=2002 |isbn=0-262-16209-1 |chapter=V Polymorphism Ch. 23. Universal Types, Ch. 25. An ML Implementation of System F |chapter-url=https://books.google.com/books?id=ti6zoAC9Ph8C&pg=PA340 |pages=339–362, 381–388}}
* {{cite book |last=Pierce |first=Benjamin |title=Types and Programming Languages |publisher=MIT Press |date=2002 |isbn=0-262-16209-1 |chapter=V Polymorphism Ch. 23. Universal Types, Ch. 25. An ML Implementation of System F |chapter-url=https://books.google.com/books?id=ti6zoAC9Ph8C&pg=PA340 |pages=339–362, 381–388}}
{{Clear}}
==बाहरी संबंध==
==बाहरी संबंध==
{{Wikibooks|Haskell}}
{{Wikibooks|Haskell}}

Revision as of 15:33, 24 May 2023

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

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

कहाँ प्रकार चर है। ऊपरी मामला लोअर-केस के विपरीत पारंपरिक रूप से टाइप-लेवल फ़ंक्शंस को निरूपित करने के लिए उपयोग किया जाता है जिसका उपयोग मूल्य-स्तरीय कार्यों के लिए किया जाता है। (सुपरस्क्रिप्टेड इसका मतलब है कि बाध्य x प्रकार का है ; बृहदान्त्र के बाद की अभिव्यक्ति इसके पहले लैम्ब्डा अभिव्यक्ति का प्रकार है।)

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

गिरार्ड के अनुसार, सिस्टम एफ में एफ को संयोग से चुना गया था।[1]


टाइपिंग नियम

सिस्टम एफ के टाइपिंग नियम निम्नलिखित के अतिरिक्त के साथ केवल टाइप किए गए लैम्ब्डा कैलकुस के हैं:

(1) (2)

कहाँ प्रकार हैं, एक प्रकार चर है, और संदर्भ में इंगित करता है बाध्य है। पहला नियम प्रयोग का है और दूसरा अमूर्तन का। [2] [3]


== तर्क और विधेय == h> प्रकार को इस प्रकार परिभाषित किया गया है: , कहाँ प्रकार चर है। इसका मतलब यह है: सभी कार्यों का प्रकार है जो इनपुट के रूप में एक प्रकार α और प्रकार α के दो भाव लेते हैं, और आउटपुट के रूप में प्रकार α की अभिव्यक्ति उत्पन्न करते हैं (ध्यान दें कि हम विचार करते हैं सही-सहयोगी होना।)

बूलियन मानों के लिए निम्नलिखित दो परिभाषाएँ और उपयोग किया जाता है, चर्च एन्कोडिंग#चर्च बूलियन्स की परिभाषा का विस्तार करते हुए:

(ध्यान दें कि उपरोक्त दो कार्यों के लिए तीन - दो नहीं - तर्कों की आवश्यकता होती है। बाद वाले दो को लैम्ब्डा अभिव्यक्ति होना चाहिए, लेकिन पहला एक प्रकार होना चाहिए। यह तथ्य इस तथ्य में परिलक्षित होता है कि इन भावों का प्रकार है ; α को बांधने वाला यूनिवर्सल क्वांटिफायर लैम्ब्डा एक्सप्रेशन में अल्फा को बांधने वाले Λ से मेल खाता है। साथ ही, ध्यान दें के लिए एक सुविधाजनक आशुलिपि है , लेकिन यह स्वयं सिस्टम F का प्रतीक नहीं है, बल्कि एक मेटा-प्रतीक है। वैसे ही, और सिस्टम F असेंबली के मेटा-प्रतीक, सुविधाजनक आशुलिपि भी हैं (Bourbaki sense में); अन्यथा, यदि इस तरह के कार्यों को नामित किया जा सकता है (सिस्टम एफ के भीतर), तो लैम्ब्डा-अभिव्यंजक उपकरण की आवश्यकता नहीं होगी जो अज्ञात रूप से कार्यों को परिभाषित करने में सक्षम हो और निश्चित-बिंदु संयोजक के लिए, जो उस प्रतिबंध के आसपास काम करता है।)

फिर इन दोनों के साथ -टर्म्स, हम कुछ लॉजिक ऑपरेटर्स को परिभाषित कर सकते हैं (जो टाइप के हैं ):

ध्यान दें कि उपरोक्त परिभाषाओं में, एक प्रकार का तर्क है , यह निर्दिष्ट करते हुए कि अन्य दो पैरामीटर जो दिए गए हैं प्रकार के हैं . जैसा कि चर्च एनकोडिंग में होता है, a की कोई आवश्यकता नहीं है IFTHENELSE कार्य करता है क्योंकि कोई केवल कच्चा उपयोग कर सकता है -टाइप की गई शर्तें निर्णय कार्यों के रूप में। हालांकि, अगर किसी से अनुरोध किया जाता है:

करूंगा। एक विधेय एक कार्य है जो एक देता है -टाइप किया गया मान। सबसे मौलिक विधेय है ISZERO जो लौटता है अगर और केवल अगर इसका तर्क चर्च एन्कोडिंग # चर्च अंक है 0:


सिस्टम एफ संरचनाएं

सिस्टम एफ पुनरावर्ती निर्माणों को मार्टिन-लोफ के प्रकार के सिद्धांत से संबंधित एक प्राकृतिक तरीके से एम्बेड करने की अनुमति देता है। सार संरचनाएं (S) कंस्ट्रक्टर्स का उपयोग करके बनाए गए हैं। ये टाइप किए गए कार्य हैं:

.

पुनरावर्तन तब प्रकट होता है जब S स्वयं एक प्रकार के भीतर प्रकट होता है . यदि आपके पास है m इन कंस्ट्रक्टर्स के प्रकार को परिभाषित कर सकते हैं S जैसा:

उदाहरण के लिए, प्राकृतिक संख्याओं को आगमनात्मक डेटा प्रकार के रूप में परिभाषित किया जा सकता है N कंस्ट्रक्टर्स के साथ

इस संरचना के अनुरूप सिस्टम एफ प्रकार है . इस प्रकार की शर्तों में चर्च अंकों का एक टाइप किया हुआ संस्करण शामिल है, जिनमें से पहले कुछ हैं:

यदि हम करी गई तर्कों के क्रम को उलट देते हैं (अर्थात, ), फिर चर्च अंक के लिए n एक ऐसा फ़ंक्शन है जो फ़ंक्शन लेता है f तर्क के रूप में और रिटर्न करता है nवें की शक्ति f. कहने का तात्पर्य यह है कि, एक चर्च अंक एक उच्च-क्रम का कार्य है - यह एक एकल-तर्क कार्य करता है f, और एक और एकल-तर्क फ़ंक्शन लौटाता है।

प्रोग्रामिंग भाषाओं में प्रयोग

इस आलेख में प्रयुक्त सिस्टम एफ का संस्करण स्पष्ट रूप से टाइप किया गया, या चर्च-शैली, कलन के रूप में है। λ-शर्तों में निहित टंकण सूचना टंकण जाँच को सरल बनाती है। जो वेल्स (1994) ने यह साबित करके एक शर्मनाक खुली समस्या का समाधान किया कि टाइप चेकिंग सिस्टम एफ के करी-शैली संस्करण के लिए निर्णय समस्या है, यानी, जिसमें स्पष्ट प्रकार-चेकिंग एनोटेशन का अभाव है।[4][5] वेल्स के परिणाम का तात्पर्य है कि सिस्टम एफ के लिए प्रकार का अनुमान लगाना असंभव है। हिंडले-मिलनर, या केवल एचएम के रूप में जाना जाने वाला सिस्टम एफ का प्रतिबंध, एक आसान प्रकार का अनुमान एल्गोरिथ्म है और इसका उपयोग कई वैधानिक रूप से टाइप की गई कार्यात्मक प्रोग्रामिंग भाषाओं जैसे हास्केल (प्रोग्रामिंग भाषा) और एमएल प्रोग्रामिंग भाषा परिवार के लिए किया जाता है। समय के साथ, जैसा कि एचएम-शैली प्रकार प्रणालियों के प्रतिबंध स्पष्ट हो गए हैं, भाषाएं अपने प्रकार प्रणालियों के लिए अधिक अभिव्यंजक लॉजिक्स में तेजी से स्थानांतरित हो गई हैं। ग्लासगो हास्केल कंपाइलर एक हास्केल कंपाइलर, एचएम (2008 तक) से आगे निकल जाता है और गैर-वाक्यविन्यास प्रकार की समानता के साथ विस्तारित सिस्टम एफ का उपयोग करता है;[6] OCaml के प्रकार सिस्टम में गैर-एचएम सुविधाओं में सामान्यीकृत बीजगणितीय डेटा प्रकार शामिल हैं।[7][8]


गिरार्ड-रेनॉल्ड्स समरूपता

दूसरे क्रम के अंतर्ज्ञानवादी तर्क में, दूसरे क्रम के बहुरूपी लैम्ब्डा कैलकुलस (F2) की खोज गिरार्ड (1972) और स्वतंत्र रूप से रेनॉल्ड्स (1974) द्वारा की गई थी।[9] गिरार्ड ने प्रतिनिधित्व प्रमेय को सिद्ध किया: कि दूसरे क्रम के अंतर्ज्ञानवादी विधेय तर्क (पी 2) में, प्राकृतिक संख्याओं से लेकर प्राकृतिक संख्याओं तक के कार्यों को कुल सिद्ध किया जा सकता है, पी 2 से एफ 2 में एक प्रक्षेपण बनाते हैं।[9]रेनॉल्ड्स ने अमूर्त प्रमेय को सिद्ध किया: कि F2 में प्रत्येक शब्द एक तार्किक संबंध को संतुष्ट करता है, जिसे तार्किक संबंध P2 में एम्बेड किया जा सकता है।[9]रेनॉल्ड्स ने साबित किया कि रेनॉल्ड्स एम्बेडिंग के बाद एक गिरार्ड प्रक्षेपण पहचान बनाता है, यानी, गिरार्ड-रेनॉल्ड्स आइसोमोर्फिज्म।[9]


सिस्टम एफω

जबकि सिस्टम एफ हेंक बारेंड्रेगट के पहले अक्ष से मेल खाता है|बैरेन्ड्रेग के लैम्ब्डा क्यूब, सिस्टम एफωया उच्च-क्रम बहुरूपी लैम्ब्डा कलन पहली धुरी (बहुरूपता) को दूसरी धुरी (टाइप ऑपरेटर) के साथ जोड़ती है; यह एक अलग, अधिक जटिल प्रणाली है।

सिस्टम एफω प्रणालियों के एक परिवार पर आगमनात्मक रूप से परिभाषित किया जा सकता है, जहां प्रेरण प्रत्येक प्रणाली में अनुमत प्रकार (प्रकार सिद्धांत) पर आधारित है:

  • परमिट प्रकार:
    • (प्रकार के प्रकार) और
    • कहाँ और (प्रकार से प्रकार के प्रकार, जहां तर्क प्रकार निम्न क्रम का है)

सीमा में, हम प्रणाली को परिभाषित कर सकते हैं होना

यानी एफω वह प्रणाली है जो कार्यों को प्रकारों से प्रकारों की अनुमति देती है जहां तर्क (और परिणाम) किसी भी क्रम का हो सकता है।

ध्यान दें कि हालांकि एफω इन मानचित्रणों में तर्कों के क्रम पर कोई प्रतिबंध नहीं लगाता है, यह इन मानचित्रणों के तर्कों के ब्रह्मांड को प्रतिबंधित करता है: उन्हें मूल्यों के बजाय प्रकार होना चाहिए। सिस्टम एफω मान से प्रकार (आश्रित प्रकार) तक मैपिंग की अनुमति नहीं देता है, हालांकि यह मान से मान तक मैपिंग की अनुमति देता है ( अमूर्तता), प्रकार से मूल्यों तक मैपिंग ( अमूर्तता), और प्रकार से प्रकार तक मैपिंग ( प्रकार के स्तर पर अमूर्तता)।

सिस्टम एफ<:

सिस्टम एफ<:, उच्चारित F-sub उपप्रकार के साथ सिस्टम F का विस्तार है। सिस्टम एफ<: 1980 के दशक से प्रोग्रामिंग भाषा सिद्धांत के लिए केंद्रीय महत्व रहा है क्योंकि कार्यात्मक प्रोग्रामिंग भाषाओं का मूल, जैसे एमएल (प्रोग्रामिंग भाषा) परिवार में, पैरामीट्रिक बहुरूपता और रिकॉर्ड (कंप्यूटर विज्ञान) उपप्रकार दोनों का समर्थन करता है, जिसे सिस्टम एफ में व्यक्त किया जा सकता है<:.[10][11]


यह भी देखें

टिप्पणियाँ

  1. Girard, Jean-Yves (1986). "चर प्रकार की प्रणाली एफ, पंद्रह साल बाद". Theoretical Computer Science. 45: 160. doi:10.1016/0304-3975(86)90044-7. However, in [3] it was shown that the obvious rules of conversion for this system, called F by chance, were converging.
  2. Harper R. "प्रोग्रामिंग भाषाओं के लिए व्यावहारिक नींव, दूसरा संस्करण" (PDF). pp. 142–3.
  3. Geuvers H, Nordström B, Dowek G. "गणित के कार्यक्रमों और औपचारिकता के प्रमाण" (PDF). p. 51.
  4. Wells, J.B. (2005-01-20). "जो वेल्स रिसर्च इंटरेस्ट्स". Heriot-Watt University.
  5. Wells, J.B. (1999). "सिस्टम एफ में टाइपेबिलिटी और टाइप चेकिंग समतुल्य और अनिर्णीत हैं". Ann. Pure Appl. Logic. 98 (1–3): 111–156. doi:10.1016/S0168-0072(98)00047-5."The Church Project: Typability and type checking in {S}ystem {F} are equivalent and undecidable". 29 September 2007. Archived from the original on 29 September 2007.
  6. "System FC: equality constraints and coercions". gitlab.haskell.org. Retrieved 2019-07-08.
  7. "OCaml 4.00.1 release notes". ocaml.org. 2012-10-05. Retrieved 2019-09-23.
  8. "OCaml 4.09 reference manual". 2012-09-11. Retrieved 2019-09-23.
  9. 9.0 9.1 9.2 9.3 Philip Wadler (2005) The Girard-Reynolds Isomorphism (second edition) University of Edinburgh, Programming Languages and Foundations at Edinburgh
  10. Cardelli, Luca; Martini, Simone; Mitchell, John C.; Scedrov, Andre (1994). "An extension of system F with subtyping". Information and Computation, vol. 9. North Holland, Amsterdam. pp. 4–56. doi:10.1006/inco.1994.1013.
  11. Pierce, Benjamin (2002). प्रकार और प्रोग्रामिंग भाषाएँ. MIT Press. ISBN 978-0-262-16209-8., Chapter 26: Bounded quantification

संदर्भ

अग्रिम पठन

बाहरी संबंध