पैरामीट्रिक बहुरूपता: Difference between revisions

From Vigyanwiki
(Created page with "{{Short description|Basis of generic programming}} {{polymorphism}} प्रोग्रामिंग भाषाओं और प्रकार के सिद्...")
 
No edit summary
Line 1: Line 1:
{{Short description|Basis of generic programming}}
{{Short description|Basis of generic programming}}
{{polymorphism}}
{{polymorphism}}
[[प्रोग्रामिंग भाषा]]ओं और प्रकार के सिद्धांत में, पैरामीट्रिक बहुरूपता कोड के एक टुकड़े को एक सामान्य प्रकार देने की अनुमति देता है, वास्तविक प्रकारों के स्थान पर चर का उपयोग करके, और फिर आवश्यकतानुसार विशेष प्रकार के साथ तत्काल।<ref name="TAPL" />{{rp|340}} पैरामीट्रिक रूप से बहुरूपी कार्यों और डेटा प्रकारों को कभी-कभी क्रमशः सामान्य कार्य और सामान्य डेटा प्रकार कहा जाता है, और वे [[सामान्य प्रोग्रामिंग]] का आधार बनाते हैं।
[[प्रोग्रामिंग भाषा]]ओं और प्रकार के सिद्धांत में, पैरामीट्रिक बहुरूपता कोड के टुकड़े को सामान्य प्रकार देने की अनुमति देता है, वास्तविक प्रकारों के स्थान पर चर का उपयोग करके, और फिर आवश्यकतानुसार विशेष प्रकार के साथ तत्काल।<ref name="TAPL" />{{rp|340}} पैरामीट्रिक रूप से बहुरूपी कार्यों और डेटा प्रकारों को कभी-कभी क्रमशः सामान्य कार्य और सामान्य डेटा प्रकार कहा जाता है, और वे [[सामान्य प्रोग्रामिंग]] का आधार बनाते हैं।


पैरामीट्रिक बहुरूपता की तुलना [[तदर्थ बहुरूपता]] से की जा सकती है। पैरामीट्रिक रूप से बहुरूपी परिभाषाएँ 'एकसमान' हैं: वे जिस प्रकार के तात्कालिक हैं, उसकी परवाह किए बिना समान रूप से व्यवहार करते हैं।<ref name="TAPL" />{{rp|340}}<ref name="Strachey 1967" />{{rp|37}} इसके विपरीत, तदर्थ बहुरूपी परिभाषाओं को प्रत्येक प्रकार के लिए एक अलग परिभाषा दी जाती है। इस प्रकार, तदर्थ बहुरूपता आम तौर पर केवल सीमित संख्या में ऐसे विशिष्ट प्रकारों का समर्थन कर सकता है, क्योंकि प्रत्येक प्रकार के लिए एक अलग कार्यान्वयन प्रदान किया जाना है।
पैरामीट्रिक बहुरूपता की तुलना [[तदर्थ बहुरूपता]] से की जा सकती है। पैरामीट्रिक रूप से बहुरूपी परिभाषाएँ 'एकसमान' हैं: वे जिस प्रकार के तात्कालिक हैं, उसकी परवाह किए बिना समान रूप से व्यवहार करते हैं।<ref name="TAPL" />{{rp|340}}<ref name="Strachey 1967" />{{rp|37}} इसके विपरीत, तदर्थ बहुरूपी परिभाषाओं को प्रत्येक प्रकार के लिए अलग परिभाषा दी जाती है। इस प्रकार, तदर्थ बहुरूपता आम तौर पर केवल सीमित संख्या में ऐसे विशिष्ट प्रकारों का समर्थन कर सकता है, क्योंकि प्रत्येक प्रकार के लिए अलग कार्यान्वयन प्रदान किया जाना है।


== मूल परिभाषा ==
== मूल परिभाषा ==


उन कार्यों को लिखना संभव है जो उनके तर्कों के प्रकारों पर निर्भर नहीं होते हैं। उदाहरण के लिए, [[पहचान समारोह]] <math>\mathsf{id}(x) = x</math> बस अपना तर्क अपरिवर्तित लौटाता है। यह स्वाभाविक रूप से संभावित प्रकार के परिवार को जन्म देता है, जैसे <math>\mathsf{Int} \to \mathsf{Int}</math>, <math>\mathsf{Bool} \to \mathsf{Bool}</math>, <math>\mathsf{String} \to \mathsf{String}</math>, और इसी तरह। पैरामीट्रिक बहुरूपता अनुमति देता है <math>\mathsf{id}</math> एक [[सार्वभौमिक परिमाणीकरण]] [[प्रकार चर]] पेश करके एक एकल, सबसे सामान्य एकीकृत प्रकार दिया जाना:
उन कार्यों को लिखना संभव है जो उनके तर्कों के प्रकारों पर निर्भर नहीं होते हैं। उदाहरण के लिए, [[पहचान समारोह]] <math>\mathsf{id}(x) = x</math> बस अपना तर्क अपरिवर्तित लौटाता है। यह स्वाभाविक रूप से संभावित प्रकार के परिवार को जन्म देता है, जैसे <math>\mathsf{Int} \to \mathsf{Int}</math>, <math>\mathsf{Bool} \to \mathsf{Bool}</math>, <math>\mathsf{String} \to \mathsf{String}</math>, और इसी तरह। पैरामीट्रिक बहुरूपता अनुमति देता है <math>\mathsf{id}</math> [[सार्वभौमिक परिमाणीकरण]] [[प्रकार चर]] पेश करके एकल, सबसे सामान्य एकीकृत प्रकार दिया जाना:


:<math>\mathsf{id} : \forall \alpha. \alpha \to \alpha</math>
:<math>\mathsf{id} : \forall \alpha. \alpha \to \alpha</math>
इसके बाद किसी भी ठोस प्रकार को प्रतिस्थापित करके बहुरूपी परिभाषा को तत्काल किया जा सकता है <math>\alpha</math>, संभावित प्रकार के पूरे परिवार की उपज।<ref>{{cite web |last1=Yorgey |first1=Brent |title=More polymorphism and type classes |url=https://www.seas.upenn.edu/~cis1940/spring13/lectures/05-type-classes.html |website=www.seas.upenn.edu |access-date=1 October 2022}}</ref>
इसके बाद किसी भी ठोस प्रकार को प्रतिस्थापित करके बहुरूपी परिभाषा को तत्काल किया जा सकता है <math>\alpha</math>, संभावित प्रकार के पूरे परिवार की उपज।<ref>{{cite web |last1=Yorgey |first1=Brent |title=More polymorphism and type classes |url=https://www.seas.upenn.edu/~cis1940/spring13/lectures/05-type-classes.html |website=www.seas.upenn.edu |access-date=1 October 2022}}</ref>
पहचान कार्य एक विशेष रूप से चरम उदाहरण है, लेकिन कई अन्य कार्य भी पैरामीट्रिक बहुरूपता से लाभान्वित होते हैं। उदाहरण के लिए, ए <math>\mathsf{append}</math> फ़ंक्शन जो दो लिंक की गई सूची को जोड़ता है, सूची के तत्वों का निरीक्षण नहीं करता है, केवल सूची संरचना ही। इसलिए, <math>\mathsf{append}</math> प्रकार का एक समान परिवार दिया जा सकता है, जैसे <math>(([\mathsf{Int}], [\mathsf{Int}]) \to [\mathsf{Int}])</math>, <math>(([\mathsf{Bool}], [\mathsf{Bool}]) \to [\mathsf{Bool}])</math>, और इसी तरह, कहाँ <math>[T]</math> प्रकार के तत्वों की एक सूची को दर्शाता है <math>T</math>. इसलिए सबसे सामान्य प्रकार है
पहचान कार्य विशेष रूप से चरम उदाहरण है, लेकिन कई अन्य कार्य भी पैरामीट्रिक बहुरूपता से लाभान्वित होते हैं। उदाहरण के लिए, ए <math>\mathsf{append}</math> फ़ंक्शन जो दो लिंक की गई सूची को जोड़ता है, सूची के तत्वों का निरीक्षण नहीं करता है, केवल सूची संरचना ही। इसलिए, <math>\mathsf{append}</math> प्रकार का समान परिवार दिया जा सकता है, जैसे <math>(([\mathsf{Int}], [\mathsf{Int}]) \to [\mathsf{Int}])</math>, <math>(([\mathsf{Bool}], [\mathsf{Bool}]) \to [\mathsf{Bool}])</math>, और इसी तरह, कहाँ <math>[T]</math> प्रकार के तत्वों की सूची को दर्शाता है <math>T</math>. इसलिए सबसे सामान्य प्रकार है


:<math>\mathsf{append} : \forall \alpha. ([\alpha], [\alpha]) \to [\alpha]</math>
:<math>\mathsf{append} : \forall \alpha. ([\alpha], [\alpha]) \to [\alpha]</math>
जिसे परिवार में किसी भी प्रकार से तत्काल किया जा सकता है।
जिसे परिवार में किसी भी प्रकार से तत्काल किया जा सकता है।


Parametrically बहुरूपी कार्य जैसे <math>\mathsf{id}</math> और <math>\mathsf{append}</math> कहा जाता है कि एक मनमानी प्रकार पर पैरामिट्रीकृत किया जाता है <math>\alpha</math>.<ref>{{cite web |last1=Wu |first1=Brandon |title=Parametric Polymorphism - SML Help |url=https://smlhelp.github.io/book/concepts/poly.html |website=smlhelp.github.io |access-date=1 October 2022}}</ref> दोनों <math>\mathsf{id}</math> और <math>\mathsf{append}</math> एक ही प्रकार पर परिचालित किया जाता है, लेकिन कार्यों को मनमाने ढंग से कई प्रकारों पर परिचालित किया जा सकता है। उदाहरण के लिए, द <math>\mathsf{fst}</math> और <math>\mathsf{snd}</math> उत्पाद प्रकार के पहले और दूसरे तत्वों को क्रमशः लौटाने वाले कार्यों को निम्न प्रकार दिया जा सकता है:
Parametrically बहुरूपी कार्य जैसे <math>\mathsf{id}</math> और <math>\mathsf{append}</math> कहा जाता है कि मनमानी प्रकार पर पैरामिट्रीकृत किया जाता है <math>\alpha</math>.<ref>{{cite web |last1=Wu |first1=Brandon |title=Parametric Polymorphism - SML Help |url=https://smlhelp.github.io/book/concepts/poly.html |website=smlhelp.github.io |access-date=1 October 2022}}</ref> दोनों <math>\mathsf{id}</math> और <math>\mathsf{append}</math> ही प्रकार पर परिचालित किया जाता है, लेकिन कार्यों को मनमाने ढंग से कई प्रकारों पर परिचालित किया जा सकता है। उदाहरण के लिए, द <math>\mathsf{fst}</math> और <math>\mathsf{snd}</math> उत्पाद प्रकार के पहले और दूसरे तत्वों को क्रमशः लौटाने वाले कार्यों को निम्न प्रकार दिया जा सकता है:


:<math>
:<math>
Line 29: Line 29:


== इतिहास ==
== इतिहास ==
पैरामीट्रिक बहुरूपता को पहली बार 1975 में [[एमएल प्रोग्रामिंग भाषा]] में प्रोग्रामिंग भाषाओं के लिए पेश किया गया था।<ref>Milner, R., Morris, L., Newey, M. "A Logic for Computable Functions with reflexive and polymorphic types", ''Proc. Conference on Proving and Improving Programs'', Arc-et-Senans (1975)</ref> आज यह [[मानक एमएल]], [[OCaml]], F Sharp (प्रोग्रामिंग लैंग्वेज)|F#, Ada (प्रोग्रामिंग लैंग्वेज), [[हास्केल (प्रोग्रामिंग भाषा)]], मरकरी (प्रोग्रामिंग लैंग्वेज), [[विजुअल प्रोलॉग]], [[स्काला (प्रोग्रामिंग भाषा)]], जूलिया (प्रोग्रामिंग लैंग्वेज) में मौजूद है। , [[पायथन (प्रोग्रामिंग भाषा)]], [[टाइपप्रति]], [[सी ++]] और अन्य। [[जावा (प्रोग्रामिंग भाषा)]], सी शार्प (प्रोग्रामिंग लैंग्वेज) | सी #, विजुअल बेसिक .NET और [[वस्तु पास्कल]] में से प्रत्येक ने पैरामीट्रिक बहुरूपता के लिए जेनरिक पेश किए हैं। प्रकार के बहुरूपता के कुछ कार्यान्वयन सतही रूप से पैरामीट्रिक बहुरूपता के समान हैं, जबकि तदर्थ पहलुओं को भी प्रस्तुत करते हैं। एक उदाहरण C++ [[टेम्पलेट विशेषज्ञता]] है।
पैरामीट्रिक बहुरूपता को पहली बार 1975 में [[एमएल प्रोग्रामिंग भाषा]] में प्रोग्रामिंग भाषाओं के लिए पेश किया गया था।<ref>Milner, R., Morris, L., Newey, M. "A Logic for Computable Functions with reflexive and polymorphic types", ''Proc. Conference on Proving and Improving Programs'', Arc-et-Senans (1975)</ref> आज यह [[मानक एमएल]], [[OCaml]], F Sharp (प्रोग्रामिंग लैंग्वेज)|F#, Ada (प्रोग्रामिंग लैंग्वेज), [[हास्केल (प्रोग्रामिंग भाषा)]], मरकरी (प्रोग्रामिंग लैंग्वेज), [[विजुअल प्रोलॉग]], [[स्काला (प्रोग्रामिंग भाषा)]], जूलिया (प्रोग्रामिंग लैंग्वेज) में मौजूद है। , [[पायथन (प्रोग्रामिंग भाषा)]], [[टाइपप्रति]], [[सी ++]] और अन्य। [[जावा (प्रोग्रामिंग भाषा)]], सी शार्प (प्रोग्रामिंग लैंग्वेज) | सी #, विजुअल बेसिक .NET और [[वस्तु पास्कल]] में से प्रत्येक ने पैरामीट्रिक बहुरूपता के लिए जेनरिक पेश किए हैं। प्रकार के बहुरूपता के कुछ कार्यान्वयन सतही रूप से पैरामीट्रिक बहुरूपता के समान हैं, जबकि तदर्थ पहलुओं को भी प्रस्तुत करते हैं। उदाहरण C++ [[टेम्पलेट विशेषज्ञता]] है।


== विधेयता, अभेद्यता, और उच्च-श्रेणी बहुरूपता ==
== विधेयता, अभेद्यता, और उच्च-श्रेणी बहुरूपता ==


=== रैंक -1 (विधेयात्मक) बहुरूपता ===
=== रैंक -1 (विधेयात्मक) बहुरूपता ===
{{refimprove section|date=February 2019}}
[[ढिठाई]] टाइप सिस्टम (जिसे [[prenex]] पॉलीमॉर्फिक सिस्टम के रूप में भी जाना जाता है) में, टाइप वेरिएबल्स को पॉलीमॉर्फिक प्रकारों के साथ तत्काल नहीं किया जा सकता है।<ref name="TAPL">{{cite book|author1=Benjamin C. Pierce|author2=Benjamin C. (Professor Pierce, University of Pennsylvania)|title=Types and Programming Languages|url=https://books.google.com/books?id=ti6zoAC9Ph8C|year=2002|publisher=MIT Press|isbn=978-0-262-16209-8}}</ref>{{rp|pages=359–360}} प्रिडिक्टिव टाइप थ्योरी में इंट्यूशनिस्टिक टाइप थ्योरी | मार्टिन-लोफ टाइप थ्योरी और [[एनयूपीआरएल]] शामिल हैं। यह एमएल-शैली या लेट-पॉलीमॉर्फिज्म के समान है (तकनीकी रूप से एमएल के लेट-पॉलिमोर्फिज्म में कुछ अन्य वाक्य-विन्यास प्रतिबंध हैं)।
[[ढिठाई]] टाइप सिस्टम (जिसे [[prenex]] पॉलीमॉर्फिक सिस्टम के रूप में भी जाना जाता है) में, टाइप वेरिएबल्स को पॉलीमॉर्फिक प्रकारों के साथ तत्काल नहीं किया जा सकता है।<ref name="TAPL">{{cite book|author1=Benjamin C. Pierce|author2=Benjamin C. (Professor Pierce, University of Pennsylvania)|title=Types and Programming Languages|url=https://books.google.com/books?id=ti6zoAC9Ph8C|year=2002|publisher=MIT Press|isbn=978-0-262-16209-8}}</ref>{{rp|pages=359–360}} प्रिडिक्टिव टाइप थ्योरी में इंट्यूशनिस्टिक टाइप थ्योरी | मार्टिन-लोफ टाइप थ्योरी और [[एनयूपीआरएल]] शामिल हैं। यह एमएल-शैली या लेट-पॉलीमॉर्फिज्म के समान है (तकनीकी रूप से एमएल के लेट-पॉलिमोर्फिज्म में कुछ अन्य वाक्य-विन्यास प्रतिबंध हैं)।
यह प्रतिबंध बहुरूपी और गैर-बहुरूपी प्रकारों के बीच अंतर को बहुत महत्वपूर्ण बना देता है; इस प्रकार विधेय प्रणालियों में बहुरूपी प्रकारों को कभी-कभी सामान्य (मोनोमोर्फिक) प्रकारों से अलग करने के लिए प्रकार स्कीमा के रूप में संदर्भित किया जाता है, जिन्हें कभी-कभी मोनोटाइप कहा जाता है।
यह प्रतिबंध बहुरूपी और गैर-बहुरूपी प्रकारों के बीच अंतर को बहुत महत्वपूर्ण बना देता है; इस प्रकार विधेय प्रणालियों में बहुरूपी प्रकारों को कभी-कभी सामान्य (मोनोमोर्फिक) प्रकारों से अलग करने के लिए प्रकार स्कीमा के रूप में संदर्भित किया जाता है, जिन्हें कभी-कभी मोनोटाइप कहा जाता है।


भविष्यवाणी का एक परिणाम यह है कि सभी प्रकारों को एक ऐसे रूप में लिखा जा सकता है जो सभी परिमाणकों को सबसे बाहरी (प्रेनेक्स) स्थिति में रखता है। उदाहरण के लिए, पर विचार करें <math>\mathsf{append}</math> ऊपर वर्णित कार्य, जिसमें निम्न प्रकार हैं:
भविष्यवाणी का परिणाम यह है कि सभी प्रकारों को ऐसे रूप में लिखा जा सकता है जो सभी परिमाणकों को सबसे बाहरी (प्रेनेक्स) स्थिति में रखता है। उदाहरण के लिए, पर विचार करें <math>\mathsf{append}</math> ऊपर वर्णित कार्य, जिसमें निम्न प्रकार हैं:
:<math>\mathsf{append} : \forall \alpha. ([\alpha], [\alpha]) \to [\alpha]</math>
:<math>\mathsf{append} : \forall \alpha. ([\alpha], [\alpha]) \to [\alpha]</math>
इस फ़ंक्शन को सूचियों की एक जोड़ी पर लागू करने के लिए, एक ठोस प्रकार <math>T</math> चर के लिए प्रतिस्थापित किया जाना चाहिए <math>\alpha</math> ऐसा है कि परिणामी फ़ंक्शन प्रकार तर्कों के प्रकार के अनुरूप है। एक अप्रतिबंधित प्रणाली में, <math>T</math> किसी भी प्रकार का हो सकता है, जिसमें एक प्रकार भी शामिल है जो स्वयं बहुरूपी है; इस प्रकार <math>\mathsf{append}</math> किसी भी प्रकार के तत्वों के साथ सूचियों के जोड़े पर लागू किया जा सकता है - यहां तक ​​​​कि बहुरूपी कार्यों की सूचियों पर भी <math>\mathsf{append}</math> अपने आप।
इस फ़ंक्शन को सूचियों की जोड़ी पर लागू करने के लिए, ठोस प्रकार <math>T</math> चर के लिए प्रतिस्थापित किया जाना चाहिए <math>\alpha</math> ऐसा है कि परिणामी फ़ंक्शन प्रकार तर्कों के प्रकार के अनुरूप है। अप्रतिबंधित प्रणाली में, <math>T</math> किसी भी प्रकार का हो सकता है, जिसमें प्रकार भी शामिल है जो स्वयं बहुरूपी है; इस प्रकार <math>\mathsf{append}</math> किसी भी प्रकार के तत्वों के साथ सूचियों के जोड़े पर लागू किया जा सकता है - यहां तक ​​​​कि बहुरूपी कार्यों की सूचियों पर भी <math>\mathsf{append}</math> अपने आप।
भाषा एमएल में बहुरूपता विधेय है।{{citation needed|date=February 2019}} ऐसा इसलिए है क्योंकि भविष्यवाणी, अन्य प्रतिबंधों के साथ, [[प्रकार प्रणाली]] को इतना सरल बनाती है कि पूर्ण प्रकार का अनुमान हमेशा संभव होता है।
भाषा एमएल में बहुरूपता विधेय है।{{citation needed|date=February 2019}} ऐसा इसलिए है क्योंकि भविष्यवाणी, अन्य प्रतिबंधों के साथ, [[प्रकार प्रणाली]] को इतना सरल बनाती है कि पूर्ण प्रकार का अनुमान हमेशा संभव होता है।


एक व्यावहारिक उदाहरण के रूप में, OCaml (ML (प्रोग्रामिंग लैंग्वेज) का एक वंशज या बोली) टाइप इंट्रेंस करता है और इम्प्रेडिकेटिव पॉलीमॉर्फिज्म का समर्थन करता है, लेकिन कुछ मामलों में जब इम्प्रेडिकेटिव पॉलीमॉर्फिज्म का उपयोग किया जाता है, तो सिस्टम का [[अनुमान टाइप करें]] तब तक अधूरा होता है जब तक कि कुछ स्पष्ट प्रकार के एनोटेशन इसके द्वारा प्रदान नहीं किए जाते हैं। प्रोग्रामर।
व्यावहारिक उदाहरण के रूप में, OCaml (ML (प्रोग्रामिंग लैंग्वेज) का वंशज या बोली) टाइप इंट्रेंस करता है और इम्प्रेडिकेटिव पॉलीमॉर्फिज्म का समर्थन करता है, लेकिन कुछ मामलों में जब इम्प्रेडिकेटिव पॉलीमॉर्फिज्म का उपयोग किया जाता है, तो सिस्टम का [[अनुमान टाइप करें]] तब तक अधूरा होता है जब तक कि कुछ स्पष्ट प्रकार के एनोटेशन इसके द्वारा प्रदान नहीं किए जाते हैं। प्रोग्रामर।


=== उच्च-रैंक बहुरूपता ===
=== उच्च-रैंक बहुरूपता ===
कुछ प्रकार के सिस्टम एक इम्प्रिडिकेटिव फंक्शन टाइप कंस्ट्रक्टर का समर्थन करते हैं, भले ही अन्य प्रकार के कंस्ट्रक्टर प्रेडिक्टिव रहते हैं। उदाहरण के लिए, प्रकार <math>(\forall \alpha. \alpha \rightarrow \alpha) \rightarrow T</math> एक ऐसी प्रणाली में अनुमति है जो उच्च-श्रेणी के बहुरूपता का समर्थन करती है, भले ही <math>[\forall \alpha. \alpha \rightarrow \alpha]</math> नहीं हो सकता।<ref>{{cite web |author1=Kwang Yul Seo |title=Kwang's Haskell Blog - Higher rank polymorphism |url=https://kseo.github.io/posts/2016-12-27-higher-rank-polymorphism.html |website=kseo.github.io |access-date=30 September 2022}}</ref>
कुछ प्रकार के सिस्टम इम्प्रिडिकेटिव फंक्शन टाइप कंस्ट्रक्टर का समर्थन करते हैं, भले ही अन्य प्रकार के कंस्ट्रक्टर प्रेडिक्टिव रहते हैं। उदाहरण के लिए, प्रकार <math>(\forall \alpha. \alpha \rightarrow \alpha) \rightarrow T</math> ऐसी प्रणाली में अनुमति है जो उच्च-श्रेणी के बहुरूपता का समर्थन करती है, भले ही <math>[\forall \alpha. \alpha \rightarrow \alpha]</math> नहीं हो सकता।<ref>{{cite web |author1=Kwang Yul Seo |title=Kwang's Haskell Blog - Higher rank polymorphism |url=https://kseo.github.io/posts/2016-12-27-higher-rank-polymorphism.html |website=kseo.github.io |access-date=30 September 2022}}</ref>
एक प्रकार को रैंक k का कहा जाता है (कुछ निश्चित पूर्णांक k के लिए) यदि इसकी जड़ से a तक कोई रास्ता नहीं है <math>\forall</math> क्वांटिफायर k या अधिक तीरों के बाईं ओर जाता है, जब एक पेड़ के रूप में टाइप किया जाता है।<ref name="TAPL" />{{rp|359}} एक प्रकार की प्रणाली को रैंक-के बहुरूपता का समर्थन करने के लिए कहा जाता है यदि यह रैंक के साथ के से कम या उसके बराबर के प्रकारों को स्वीकार करता है। उदाहरण के लिए, एक प्रकार की प्रणाली जो रैंक -2 बहुरूपता का समर्थन करती है, अनुमति देगी <math>(\forall \alpha. \alpha \rightarrow \alpha) \rightarrow T</math> लेकिन नहीं <math>((\forall \alpha. \alpha \rightarrow \alpha) \rightarrow T) \rightarrow T</math>. एक प्रकार की प्रणाली जो मनमाना रैंक के प्रकारों को स्वीकार करती है, उसे रैंक-एन बहुरूपी कहा जाता है।
प्रकार को रैंक k का कहा जाता है (कुछ निश्चित पूर्णांक k के लिए) यदि इसकी जड़ से a तक कोई रास्ता नहीं है <math>\forall</math> क्वांटिफायर k या अधिक तीरों के बाईं ओर जाता है, जब पेड़ के रूप में टाइप किया जाता है।<ref name="TAPL" />{{rp|359}} प्रकार की प्रणाली को रैंक-के बहुरूपता का समर्थन करने के लिए कहा जाता है यदि यह रैंक के साथ के से कम या उसके बराबर के प्रकारों को स्वीकार करता है। उदाहरण के लिए, प्रकार की प्रणाली जो रैंक -2 बहुरूपता का समर्थन करती है, अनुमति देगी <math>(\forall \alpha. \alpha \rightarrow \alpha) \rightarrow T</math> लेकिन नहीं <math>((\forall \alpha. \alpha \rightarrow \alpha) \rightarrow T) \rightarrow T</math>. प्रकार की प्रणाली जो मनमाना रैंक के प्रकारों को स्वीकार करती है, उसे रैंक-एन बहुरूपी कहा जाता है।


रैंक-2 बहुरूपता के लिए प्रकार अनुमान निर्णायक है, लेकिन रैंक-3 और उससे ऊपर के लिए, यह नहीं है।<ref>{{cite journal |last1=Kfoury |first1=A. J. |last2=Wells |first2=J. B. |title=Principality and decidable type inference for finite-rank intersection types |journal=Proceedings of the 26th ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages |date=1 January 1999 |pages=161–174 |doi=10.1145/292540.292556 |publisher=Association for Computing Machinery|isbn=1581130953 |s2cid=14183560 |doi-access=free }}</ref><ref name="TAPL" />{{rp|359}}
रैंक-2 बहुरूपता के लिए प्रकार अनुमान निर्णायक है, लेकिन रैंक-3 और उससे ऊपर के लिए, यह नहीं है।<ref>{{cite journal |last1=Kfoury |first1=A. J. |last2=Wells |first2=J. B. |title=Principality and decidable type inference for finite-rank intersection types |journal=Proceedings of the 26th ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages |date=1 January 1999 |pages=161–174 |doi=10.1145/292540.292556 |publisher=Association for Computing Machinery|isbn=1581130953 |s2cid=14183560 |doi-access=free }}</ref><ref name="TAPL" />{{rp|359}}
Line 53: Line 52:


=== प्रतिकूल बहुरूपता ===
=== प्रतिकूल बहुरूपता ===
इम्प्रिडिकेटिव पोलिमोर्फिज्म (जिसे प्रथम श्रेणी का पॉलीमॉर्फिज्म भी कहा जाता है) पैरामीट्रिक पॉलीमॉर्फिज्म का सबसे शक्तिशाली रूप है।<ref name="TAPL" />{{rp|340}} [[औपचारिक तर्क]] में, एक परिभाषा को अप्रतिबंधात्मकता कहा जाता है यदि यह स्व-संदर्भित है; टाइप थ्योरी में, यह एक प्रकार के क्वांटिफायर के डोमेन में होने की क्षमता को संदर्भित करता है। यह पॉलिमॉर्फिक प्रकारों सहित किसी भी प्रकार के चर के किसी भी प्रकार के इन्स्टेन्शियशन की अनुमति देता है। पूर्ण प्रतिबाधा का समर्थन करने वाली प्रणाली का एक उदाहरण [[सिस्टम एफ]] है, जो तत्काल करने की अनुमति देता है <math>\forall \alpha. \alpha \to \alpha</math> किसी भी प्रकार से, स्वयं सहित।
इम्प्रिडिकेटिव पोलिमोर्फिज्म (जिसे प्रथम श्रेणी का पॉलीमॉर्फिज्म भी कहा जाता है) पैरामीट्रिक पॉलीमॉर्फिज्म का सबसे शक्तिशाली रूप है।<ref name="TAPL" />{{rp|340}} [[औपचारिक तर्क]] में, परिभाषा को अप्रतिबंधात्मकता कहा जाता है यदि यह स्व-संदर्भित है; टाइप थ्योरी में, यह प्रकार के क्वांटिफायर के डोमेन में होने की क्षमता को संदर्भित करता है। यह पॉलिमॉर्फिक प्रकारों सहित किसी भी प्रकार के चर के किसी भी प्रकार के इन्स्टेन्शियशन की अनुमति देता है। पूर्ण प्रतिबाधा का समर्थन करने वाली प्रणाली का उदाहरण [[सिस्टम एफ]] है, जो तत्काल करने की अनुमति देता है <math>\forall \alpha. \alpha \to \alpha</math> किसी भी प्रकार से, स्वयं सहित।


टाइप थ्योरी में, सबसे अधिक बार अध्ययन किए जाने वाले इम्प्रेडिकेटिव टाइप लैम्ब्डा कैलकुलस | टाइप किए गए λ-कैलकुली [[लैम्ब्डा घन]], विशेष रूप से सिस्टम एफ पर आधारित होते हैं।
टाइप थ्योरी में, सबसे अधिक बार अध्ययन किए जाने वाले इम्प्रेडिकेटिव टाइप लैम्ब्डा कैलकुलस | टाइप किए गए λ-कैलकुली [[लैम्ब्डा घन]], विशेष रूप से सिस्टम एफ पर आधारित होते हैं।
Line 59: Line 58:
== परिबद्ध पैरामीट्रिक बहुरूपता ==
== परिबद्ध पैरामीट्रिक बहुरूपता ==
{{main|Bounded quantification}}
{{main|Bounded quantification}}
1985 में, [[लुका कार्डेली]] और [[पीटर वेगनर]] ने प्रकार के मापदंडों पर सीमा की अनुमति देने के लाभों को पहचाना।{{sfn|Cardelli|Wegner|1985}} कई परिचालनों के लिए डेटा प्रकारों के कुछ ज्ञान की आवश्यकता होती है, लेकिन अन्यथा पैरामीट्रिक रूप से कार्य कर सकते हैं। उदाहरण के लिए, यह जाँचने के लिए कि क्या कोई वस्तु किसी सूची में शामिल है, हमें समानता के लिए वस्तुओं की तुलना करने की आवश्यकता है। मानक एमएल में, फॉर्म के टाइप पैरामीटर ''a'' प्रतिबंधित हैं ताकि समानता ऑपरेशन उपलब्ध हो, इस प्रकार फ़ंक्शन में ''a × ''a list → bool और ''a केवल परिभाषित प्रकार का एक प्रकार हो सकता है समानता। हास्केल (प्रोग्रामिंग लैंग्वेज) में, [[वर्ग टाइप करें]] से संबंधित प्रकारों की आवश्यकता के द्वारा बाउंडिंग हासिल की जाती है; इस प्रकार एक ही फ़ंक्शन का प्रकार होता है <math display=inline>\mathrm{Eq} \, \alpha \, \Rightarrow \alpha \, \rightarrow \left[\alpha \right] \rightarrow \mathrm{Bool}</math> हास्केल में। पैरामीट्रिक बहुरूपता का समर्थन करने वाली अधिकांश वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में, मापदंडों को किसी दिए गए प्रकार के उपप्रकारों के लिए विवश किया जा सकता है ([[उपप्रकार बहुरूपता]] और सामान्य प्रोग्रामिंग पर लेख देखें)।
1985 में, [[लुका कार्डेली]] और [[पीटर वेगनर]] ने प्रकार के मापदंडों पर सीमा की अनुमति देने के लाभों को पहचाना।{{sfn|Cardelli|Wegner|1985}} कई परिचालनों के लिए डेटा प्रकारों के कुछ ज्ञान की आवश्यकता होती है, लेकिन अन्यथा पैरामीट्रिक रूप से कार्य कर सकते हैं। उदाहरण के लिए, यह जाँचने के लिए कि क्या कोई वस्तु किसी सूची में शामिल है, हमें समानता के लिए वस्तुओं की तुलना करने की आवश्यकता है। मानक एमएल में, फॉर्म के टाइप पैरामीटर ''a'' प्रतिबंधित हैं ताकि समानता ऑपरेशन उपलब्ध हो, इस प्रकार फ़ंक्शन में ''a × ''a list → bool और ''a केवल परिभाषित प्रकार का प्रकार हो सकता है समानता। हास्केल (प्रोग्रामिंग लैंग्वेज) में, [[वर्ग टाइप करें]] से संबंधित प्रकारों की आवश्यकता के द्वारा बाउंडिंग हासिल की जाती है; इस प्रकार ही फ़ंक्शन का प्रकार होता है <math display=inline>\mathrm{Eq} \, \alpha \, \Rightarrow \alpha \, \rightarrow \left[\alpha \right] \rightarrow \mathrm{Bool}</math> हास्केल में। पैरामीट्रिक बहुरूपता का समर्थन करने वाली अधिकांश वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में, मापदंडों को किसी दिए गए प्रकार के उपप्रकारों के लिए विवश किया जा सकता है ([[उपप्रकार बहुरूपता]] और सामान्य प्रोग्रामिंग पर लेख देखें)।''


== यह भी देखें ==
== यह भी देखें ==
Line 138: Line 137:
{{Data types}}
{{Data types}}


<!--Categories-->[[Category: सामान्य प्रोग्रामिंग]] [[Category: बहुरूपता (कंप्यूटर विज्ञान)]] [[Category: प्रकार सिद्धांत]]  
[[Category: सामान्य प्रोग्रामिंग]] [[Category: बहुरूपता (कंप्यूटर विज्ञान)]] [[Category: प्रकार सिद्धांत]]  





Revision as of 11:38, 16 February 2023

प्रोग्रामिंग भाषाओं और प्रकार के सिद्धांत में, पैरामीट्रिक बहुरूपता कोड के टुकड़े को सामान्य प्रकार देने की अनुमति देता है, वास्तविक प्रकारों के स्थान पर चर का उपयोग करके, और फिर आवश्यकतानुसार विशेष प्रकार के साथ तत्काल।[1]: 340  पैरामीट्रिक रूप से बहुरूपी कार्यों और डेटा प्रकारों को कभी-कभी क्रमशः सामान्य कार्य और सामान्य डेटा प्रकार कहा जाता है, और वे सामान्य प्रोग्रामिंग का आधार बनाते हैं।

पैरामीट्रिक बहुरूपता की तुलना तदर्थ बहुरूपता से की जा सकती है। पैरामीट्रिक रूप से बहुरूपी परिभाषाएँ 'एकसमान' हैं: वे जिस प्रकार के तात्कालिक हैं, उसकी परवाह किए बिना समान रूप से व्यवहार करते हैं।[1]: 340 [2]: 37  इसके विपरीत, तदर्थ बहुरूपी परिभाषाओं को प्रत्येक प्रकार के लिए अलग परिभाषा दी जाती है। इस प्रकार, तदर्थ बहुरूपता आम तौर पर केवल सीमित संख्या में ऐसे विशिष्ट प्रकारों का समर्थन कर सकता है, क्योंकि प्रत्येक प्रकार के लिए अलग कार्यान्वयन प्रदान किया जाना है।

मूल परिभाषा

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

इसके बाद किसी भी ठोस प्रकार को प्रतिस्थापित करके बहुरूपी परिभाषा को तत्काल किया जा सकता है , संभावित प्रकार के पूरे परिवार की उपज।[3] पहचान कार्य विशेष रूप से चरम उदाहरण है, लेकिन कई अन्य कार्य भी पैरामीट्रिक बहुरूपता से लाभान्वित होते हैं। उदाहरण के लिए, ए फ़ंक्शन जो दो लिंक की गई सूची को जोड़ता है, सूची के तत्वों का निरीक्षण नहीं करता है, केवल सूची संरचना ही। इसलिए, प्रकार का समान परिवार दिया जा सकता है, जैसे , , और इसी तरह, कहाँ प्रकार के तत्वों की सूची को दर्शाता है . इसलिए सबसे सामान्य प्रकार है

जिसे परिवार में किसी भी प्रकार से तत्काल किया जा सकता है।

Parametrically बहुरूपी कार्य जैसे और कहा जाता है कि मनमानी प्रकार पर पैरामिट्रीकृत किया जाता है .[4] दोनों और ही प्रकार पर परिचालित किया जाता है, लेकिन कार्यों को मनमाने ढंग से कई प्रकारों पर परिचालित किया जा सकता है। उदाहरण के लिए, द और उत्पाद प्रकार के पहले और दूसरे तत्वों को क्रमशः लौटाने वाले कार्यों को निम्न प्रकार दिया जा सकता है:

अभिव्यक्ति में , पर प्रवर्तित किया जाता है और पर प्रवर्तित किया जाता है को कॉल में , तो समग्र अभिव्यक्ति का प्रकार है .

पैरामीट्रिक बहुरूपता को पेश करने के लिए प्रयुक्त सिंटैक्स (प्रोग्रामिंग भाषाएं) प्रोग्रामिंग भाषाओं के बीच महत्वपूर्ण रूप से भिन्न होता है। उदाहरण के लिए, कुछ प्रोग्रामिंग भाषाओं में, जैसे हास्केल, परिमाणक (तर्क)तर्क) अंतर्निहित है और इसे छोड़ा जा सकता है।[5] अन्य भाषाओं को कुछ या सभी पैरामीट्रिक पॉलीमॉर्फिक फ़ंक्शन की कॉल साइटों पर स्पष्ट रूप से तत्काल होने की आवश्यकता होती है।

इतिहास

पैरामीट्रिक बहुरूपता को पहली बार 1975 में एमएल प्रोग्रामिंग भाषा में प्रोग्रामिंग भाषाओं के लिए पेश किया गया था।[6] आज यह मानक एमएल, OCaml, F Sharp (प्रोग्रामिंग लैंग्वेज)|F#, Ada (प्रोग्रामिंग लैंग्वेज), हास्केल (प्रोग्रामिंग भाषा), मरकरी (प्रोग्रामिंग लैंग्वेज), विजुअल प्रोलॉग, स्काला (प्रोग्रामिंग भाषा), जूलिया (प्रोग्रामिंग लैंग्वेज) में मौजूद है। , पायथन (प्रोग्रामिंग भाषा), टाइपप्रति, सी ++ और अन्य। जावा (प्रोग्रामिंग भाषा), सी शार्प (प्रोग्रामिंग लैंग्वेज) | सी #, विजुअल बेसिक .NET और वस्तु पास्कल में से प्रत्येक ने पैरामीट्रिक बहुरूपता के लिए जेनरिक पेश किए हैं। प्रकार के बहुरूपता के कुछ कार्यान्वयन सतही रूप से पैरामीट्रिक बहुरूपता के समान हैं, जबकि तदर्थ पहलुओं को भी प्रस्तुत करते हैं। उदाहरण C++ टेम्पलेट विशेषज्ञता है।

विधेयता, अभेद्यता, और उच्च-श्रेणी बहुरूपता

रैंक -1 (विधेयात्मक) बहुरूपता

ढिठाई टाइप सिस्टम (जिसे prenex पॉलीमॉर्फिक सिस्टम के रूप में भी जाना जाता है) में, टाइप वेरिएबल्स को पॉलीमॉर्फिक प्रकारों के साथ तत्काल नहीं किया जा सकता है।[1]: 359–360  प्रिडिक्टिव टाइप थ्योरी में इंट्यूशनिस्टिक टाइप थ्योरी | मार्टिन-लोफ टाइप थ्योरी और एनयूपीआरएल शामिल हैं। यह एमएल-शैली या लेट-पॉलीमॉर्फिज्म के समान है (तकनीकी रूप से एमएल के लेट-पॉलिमोर्फिज्म में कुछ अन्य वाक्य-विन्यास प्रतिबंध हैं)। यह प्रतिबंध बहुरूपी और गैर-बहुरूपी प्रकारों के बीच अंतर को बहुत महत्वपूर्ण बना देता है; इस प्रकार विधेय प्रणालियों में बहुरूपी प्रकारों को कभी-कभी सामान्य (मोनोमोर्फिक) प्रकारों से अलग करने के लिए प्रकार स्कीमा के रूप में संदर्भित किया जाता है, जिन्हें कभी-कभी मोनोटाइप कहा जाता है।

भविष्यवाणी का परिणाम यह है कि सभी प्रकारों को ऐसे रूप में लिखा जा सकता है जो सभी परिमाणकों को सबसे बाहरी (प्रेनेक्स) स्थिति में रखता है। उदाहरण के लिए, पर विचार करें ऊपर वर्णित कार्य, जिसमें निम्न प्रकार हैं:

इस फ़ंक्शन को सूचियों की जोड़ी पर लागू करने के लिए, ठोस प्रकार चर के लिए प्रतिस्थापित किया जाना चाहिए ऐसा है कि परिणामी फ़ंक्शन प्रकार तर्कों के प्रकार के अनुरूप है। अप्रतिबंधित प्रणाली में, किसी भी प्रकार का हो सकता है, जिसमें प्रकार भी शामिल है जो स्वयं बहुरूपी है; इस प्रकार किसी भी प्रकार के तत्वों के साथ सूचियों के जोड़े पर लागू किया जा सकता है - यहां तक ​​​​कि बहुरूपी कार्यों की सूचियों पर भी अपने आप। भाषा एमएल में बहुरूपता विधेय है।[citation needed] ऐसा इसलिए है क्योंकि भविष्यवाणी, अन्य प्रतिबंधों के साथ, प्रकार प्रणाली को इतना सरल बनाती है कि पूर्ण प्रकार का अनुमान हमेशा संभव होता है।

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

उच्च-रैंक बहुरूपता

कुछ प्रकार के सिस्टम इम्प्रिडिकेटिव फंक्शन टाइप कंस्ट्रक्टर का समर्थन करते हैं, भले ही अन्य प्रकार के कंस्ट्रक्टर प्रेडिक्टिव रहते हैं। उदाहरण के लिए, प्रकार ऐसी प्रणाली में अनुमति है जो उच्च-श्रेणी के बहुरूपता का समर्थन करती है, भले ही नहीं हो सकता।[7] प्रकार को रैंक k का कहा जाता है (कुछ निश्चित पूर्णांक k के लिए) यदि इसकी जड़ से a तक कोई रास्ता नहीं है क्वांटिफायर k या अधिक तीरों के बाईं ओर जाता है, जब पेड़ के रूप में टाइप किया जाता है।[1]: 359  प्रकार की प्रणाली को रैंक-के बहुरूपता का समर्थन करने के लिए कहा जाता है यदि यह रैंक के साथ के से कम या उसके बराबर के प्रकारों को स्वीकार करता है। उदाहरण के लिए, प्रकार की प्रणाली जो रैंक -2 बहुरूपता का समर्थन करती है, अनुमति देगी लेकिन नहीं . प्रकार की प्रणाली जो मनमाना रैंक के प्रकारों को स्वीकार करती है, उसे रैंक-एन बहुरूपी कहा जाता है।

रैंक-2 बहुरूपता के लिए प्रकार अनुमान निर्णायक है, लेकिन रैंक-3 और उससे ऊपर के लिए, यह नहीं है।[8][1]: 359 


प्रतिकूल बहुरूपता

इम्प्रिडिकेटिव पोलिमोर्फिज्म (जिसे प्रथम श्रेणी का पॉलीमॉर्फिज्म भी कहा जाता है) पैरामीट्रिक पॉलीमॉर्फिज्म का सबसे शक्तिशाली रूप है।[1]: 340  औपचारिक तर्क में, परिभाषा को अप्रतिबंधात्मकता कहा जाता है यदि यह स्व-संदर्भित है; टाइप थ्योरी में, यह प्रकार के क्वांटिफायर के डोमेन में होने की क्षमता को संदर्भित करता है। यह पॉलिमॉर्फिक प्रकारों सहित किसी भी प्रकार के चर के किसी भी प्रकार के इन्स्टेन्शियशन की अनुमति देता है। पूर्ण प्रतिबाधा का समर्थन करने वाली प्रणाली का उदाहरण सिस्टम एफ है, जो तत्काल करने की अनुमति देता है किसी भी प्रकार से, स्वयं सहित।

टाइप थ्योरी में, सबसे अधिक बार अध्ययन किए जाने वाले इम्प्रेडिकेटिव टाइप लैम्ब्डा कैलकुलस | टाइप किए गए λ-कैलकुली लैम्ब्डा घन, विशेष रूप से सिस्टम एफ पर आधारित होते हैं।

परिबद्ध पैरामीट्रिक बहुरूपता

1985 में, लुका कार्डेली और पीटर वेगनर ने प्रकार के मापदंडों पर सीमा की अनुमति देने के लाभों को पहचाना।[9] कई परिचालनों के लिए डेटा प्रकारों के कुछ ज्ञान की आवश्यकता होती है, लेकिन अन्यथा पैरामीट्रिक रूप से कार्य कर सकते हैं। उदाहरण के लिए, यह जाँचने के लिए कि क्या कोई वस्तु किसी सूची में शामिल है, हमें समानता के लिए वस्तुओं की तुलना करने की आवश्यकता है। मानक एमएल में, फॉर्म के टाइप पैरामीटर a प्रतिबंधित हैं ताकि समानता ऑपरेशन उपलब्ध हो, इस प्रकार फ़ंक्शन में a × a list → bool और a केवल परिभाषित प्रकार का प्रकार हो सकता है समानता। हास्केल (प्रोग्रामिंग लैंग्वेज) में, वर्ग टाइप करें से संबंधित प्रकारों की आवश्यकता के द्वारा बाउंडिंग हासिल की जाती है; इस प्रकार ही फ़ंक्शन का प्रकार होता है हास्केल में। पैरामीट्रिक बहुरूपता का समर्थन करने वाली अधिकांश वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में, मापदंडों को किसी दिए गए प्रकार के उपप्रकारों के लिए विवश किया जा सकता है (उपप्रकार बहुरूपता और सामान्य प्रोग्रामिंग पर लेख देखें)।

यह भी देखें

टिप्पणियाँ

  1. 1.0 1.1 1.2 1.3 1.4 1.5 Benjamin C. Pierce; Benjamin C. (Professor Pierce, University of Pennsylvania) (2002). Types and Programming Languages. MIT Press. ISBN 978-0-262-16209-8.
  2. Strachey, Christopher (1967), Fundamental Concepts in Programming Languages (Lecture notes), Copenhagen: International Summer School in Computer Programming. Republished in: Strachey, Christopher (1 April 2000). "Fundamental Concepts in Programming Languages". Higher-Order and Symbolic Computation (in English). 13 (1): 11–49. doi:10.1023/A:1010000313106. ISSN 1573-0557. S2CID 14124601.
  3. Yorgey, Brent. "More polymorphism and type classes". www.seas.upenn.edu. Retrieved 1 October 2022.
  4. Wu, Brandon. "Parametric Polymorphism - SML Help". smlhelp.github.io. Retrieved 1 October 2022.
  5. "Haskell 2010 Language Report § 4.1.2 Syntax of Types". www.haskell.org. Retrieved 1 October 2022. With one exception (that of the distinguished type variable in a class declaration (Section 4.3.1)), the type variables in a Haskell type expression are all assumed to be universally quantified; there is no explicit syntax for universal quantification.
  6. Milner, R., Morris, L., Newey, M. "A Logic for Computable Functions with reflexive and polymorphic types", Proc. Conference on Proving and Improving Programs, Arc-et-Senans (1975)
  7. Kwang Yul Seo. "Kwang's Haskell Blog - Higher rank polymorphism". kseo.github.io. Retrieved 30 September 2022.
  8. Kfoury, A. J.; Wells, J. B. (1 January 1999). "Principality and decidable type inference for finite-rank intersection types". Proceedings of the 26th ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages. Association for Computing Machinery: 161–174. doi:10.1145/292540.292556. ISBN 1581130953. S2CID 14183560.
  9. Cardelli & Wegner 1985.


संदर्भ