प्रकार (प्ररूप सिद्धांत)

गणितीय तर्क और कंप्यूटर विज्ञान के क्षेत्र में जिसे प्रकार सिद्धांत  के रूप में जाना जाता है, एक प्रकार एक प्रकार के कंस्ट्रक्टर का प्रकार होता है या, कम सामान्यतः, एक उच्च-क्रम प्रकार के ऑपरेटर का प्रकार होता है। एक प्रकार की प्रणाली अनिवार्य रूप से एक स्तर ऊपर टाइप किया गया लैम्ब्डा कैलकुलस है, जो एक आदिम प्रकार से संपन्न है, जिसे दर्शाया गया है $$*$$ और इसे प्रकार कहा जाता है, जो किसी भी डेटा प्रकार का प्रकार है जिसे किसी पैरामीट्रिक बहुरूपता की आवश्यकता नहीं होती है।

एक प्रकार को कभी-कभी भ्रामक रूप से डेटा प्रकार|(डेटा) प्रकार के प्रकार के रूप में वर्णित किया जाता है, लेकिन यह वास्तव में एक एरिटी विनिर्देशक के रूप में अधिक है। वाक्यात्मक रूप से, बहुरूपी प्रकारों को प्रकार का निर्माणकर्ता मानना ​​स्वाभाविक है, इस प्रकार गैर-बहुरूपी प्रकारों को अशक्त प्रकार का रचनाकार माना जाता है। लेकिन सभी अशक्त रचनाकारों, इस प्रकार सभी मोनोमोर्फिक प्रकारों का एक ही, सरलतम प्रकार होता है; अर्थात् $$*$$.

चूँकि प्रोग्रामिंग भाषाओं में उच्च-क्रम प्रकार के ऑपरेटर असामान्य हैं, अधिकांश प्रोग्रामिंग अभ्यास में, प्रकार का उपयोग डेटा प्रकारों और कंस्ट्रक्टर के प्रकारों के बीच अंतर करने के लिए किया जाता है, जिनका उपयोग पैरामीट्रिक बहुरूपता को लागू करने के लिए किया जाता है। प्रकार, स्पष्ट रूप से या परोक्ष रूप से, उन भाषाओं में प्रकट होते हैं जिनके प्रकार सिस्टम प्रोग्रामेटिक रूप से सुलभ तरीके से पैरामीट्रिक बहुरूपता के लिए जिम्मेदार होते हैं, जैसे कि C++, हास्केल (प्रोग्रामिंग भाषा) और स्काला (प्रोग्रामिंग भाषा).

उदाहरण

 * $$*$$, उच्चारित प्रकार, सभी डेटा प्रकारों का एक प्रकार है जिसे अशक्त प्रकार के कंस्ट्रक्टर के रूप में देखा जाता है, और इस संदर्भ में इसे उचित प्रकार भी कहा जाता है। इसमें सामान्यतः कार्यात्मक प्रोग्रामिंग भाषाओं में फ़ंक्शन प्रकार शामिल होते हैं।
 * $$* \rightarrow *$$ एक एकात्मक कार्य प्रकार का कंस्ट्रक्टर है, उदाहरण के लिए एक सूची प्रकार के कंस्ट्रक्टर का।
 * $$* \rightarrow * \rightarrow *$$ एक विक्षनरी का प्रकार है: बाइनरी प्रकार का कंस्ट्रक्टर (करीइंग के माध्यम से), उदाहरण के लिए एक जोड़ी प्रकार के कंस्ट्रक्टर का, और एक फ़ंक्शन प्रकार के कंस्ट्रक्टर का भी (इसके अनुप्रयोग के परिणाम के साथ भ्रमित न हों, जो स्वयं एक फ़ंक्शन प्रकार है, इस प्रकार $$*$$)
 * $$(* \rightarrow *) \rightarrow *$$ यूनरी प्रकार के कंस्ट्रक्टर से उचित प्रकार तक एक उच्च-क्रम प्रकार का ऑपरेटर है।

हास्केल में प्रकार
(नोट: हास्केल दस्तावेज़ फ़ंक्शन प्रकार और प्रकार दोनों के लिए एक ही तीर का उपयोग करता है।)

हास्केल की प्रकार प्रणाली (प्रोग्रामिंग भाषा) बिल्कुल दो प्रकार शामिल हैं:
 * $$*$$, उच्चारित प्रकार सभी डेटा प्रकारों का प्रकार है।
 * $$k_1 \rightarrow k_2$$ एक यूनरी फ़ंक्शन प्रकार का कंस्ट्रक्टर है, जो एक प्रकार का प्रकार लेता है $$k_1$$ और एक प्रकार का उत्पादन करता है $$k_2$$.

एक निवास प्रकार (जैसा कि हास्केल में उचित प्रकार कहा जाता है) एक ऐसा प्रकार है जिसमें मूल्य होते हैं। उदाहरण के लिए, चित्र को जटिल बनाने वाले प्रकार वर्गों को अनदेखा करना,  प्रकार का मान है , जबकि   प्रकार का मान है   (इंट्स की सूची)। इसलिए,   और   दयालु हो $$*$$, लेकिन उदाहरण के लिए, कोई भी फ़ंक्शन प्रकार भी ऐसा ही करता है   या और भी.

एक टाइप कंस्ट्रक्टर एक या अधिक प्रकार के तर्क लेता है, और पर्याप्त तर्क दिए जाने पर एक डेटा प्रकार तैयार करता है, यानी यह करीइंग के लिए आंशिक एप्लिकेशन का समर्थन करता है। इस प्रकार हास्केल पैरामीट्रिक प्रकार प्राप्त करता है। उदाहरण के लिए, प्रकार  (सूची) एक प्रकार का कंस्ट्रक्टर है - यह सूची के तत्वों के प्रकार को निर्दिष्ट करने के लिए एक एकल तर्क लेता है। इस तरह,   (इंट्स की सूची),   (फ्लोट्स की सूची) और यहां तक ​​कि   (इंट्स की सूचियों की सूची) के वैध अनुप्रयोग हैं   कंस्ट्रक्टर टाइप करें। इसलिए,   एक प्रकार का प्रकार है $$* \rightarrow *$$. क्योंकि  दयालु है $$*$$, आवेदन करना   इसका परिणाम यह होता है , प्रकार का $$*$$. 2- टपल कंस्ट्रक्टर   दयालु है $$* \rightarrow * \rightarrow *$$, 3-ट्यूपल कंस्ट्रक्टर   दयालु है $$* \rightarrow * \rightarrow * \rightarrow *$$ और इसी तरह।

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

एक प्रकार का  सहित कुछ भी हो सकता है $$*$$, लेकिन $$* \rightarrow *$$ आदि। हास्केल डिफ़ॉल्ट रूप से हमेशा प्रकार का अनुमान लगाएगा $$*$$, जब तक कि प्रकार स्पष्ट रूप से अन्यथा इंगित न करे (नीचे देखें)। इसलिए टाइप चेकर निम्नलिखित उपयोग को अस्वीकार कर देगा  : क्योंकि जिस तरह का, $$* \rightarrow *$$ के लिए अपेक्षित प्रकार से मेल नहीं खाता  , जो सदैव है $$*$$.

हालाँकि उच्च-क्रम प्रकार के ऑपरेटरों को अनुमति है। उदाहरण के लिए:

दयालु है $$(* \rightarrow *) \rightarrow * \rightarrow *$$, अर्थात।  एक यूनरी डेटा कंस्ट्रक्टर होने की उम्मीद है, जो इसके तर्क पर लागू होता है, जो एक प्रकार होना चाहिए, और एक अन्य प्रकार लौटाता है।

ग्लासगो हास्केल कंपाइलर का विस्तार है, जो, साथ में  , बहुरूपी प्रकारों की अनुमति देता है। उदाहरण के लिए: GHC 8.0.1 के बाद से, प्रकार और प्रकारों का विलय हो गया है।

यह भी देखें

 * सिस्टम एफ-ओमेगा
 * शुद्ध प्रकार की प्रणाली

संदर्भ

 * , chapter 29, "Type Operators and Kinding"