एपिग्राम (प्रोग्रामिंग भाषा): Difference between revisions
(Created page with "{{short description|Functional programming language}} {{multiple issues| {{Notability|date=August 2019}} {{No footnotes|date=August 2019}} {{One source|date=February 2023}} {{...") |
No edit summary |
||
(5 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
{{short description|Functional programming language}} | {{short description|Functional programming language}} | ||
{{Infobox programming language | {{Infobox programming language | ||
| name = | | name = एपिग्राम | ||
| logo = | | logo = | ||
| paradigm = [[Functional programming|Functional]] | | paradigm = [[Functional programming|Functional]] | ||
Line 26: | Line 20: | ||
}} | }} | ||
एपिग्राम [[आश्रित प्रकार]] | '''एपिग्राम''' [[आश्रित प्रकार]] के साथ एक [[कार्यात्मक प्रोग्रामिंग|फंक्शनल प्रोग्रामिंग]] भाषा है, और एकीकृत विकास वातावरण (आईडीई) सामान्यतः भाषा के साथ पैक किया जाता है। प्रोग्राम विशिष्टताओं को व्यक्त करने के लिए एपिग्राम की [[प्रकार प्रणाली]] पर्याप्त सशक्त है। लक्ष्य सामान्य प्रोग्रामिंग से एकीकृत कार्यक्रमों और प्रमाणों में एक सुचारु संक्रमण का समर्थन करना है जिनकी शुद्धता को [[ संकलक ]] द्वारा जांच और प्रमाणित किया जा सकता है। एपिग्राम ''करी-हावर्ड पत्राचार'' का उपयोग करता है, इसे ''प्रस्तावों को प्रकार सिद्धांत'' भी कहा जाता है, और यह अंतर्ज्ञानवादी प्रकार सिद्धांत पर आधारित है। | ||
एपिग्राम प्रोटोटाइप को जेम्स मैककिन्ना के साथ संयुक्त कार्य के आधार पर [[कॉनर मैकब्राइड]] द्वारा कार्यान्वित किया गया था। इसका विकास [[नॉटिंघम]], डरहम, इंग्लैंड, [[स्कॉट एंड्रयू]] और रॉयल होलोवे, [[यूनाइटेड किंगडम]] (यूके) में लंदन विश्वविद्यालय में एपिग्राम समूह द्वारा जारी रखा गया है। एपिग्राम प्रणाली का वर्तमान प्रायोगिक कार्यान्वयन एक उपयोगकर्ता मैनुअल, एक ट्यूटोरियल और कुछ पृष्ठभूमि सामग्री के साथ मुफ्त में उपलब्ध है। इस सिस्टम का उपयोग [[ | एपिग्राम प्रोटोटाइप को जेम्स मैककिन्ना के साथ संयुक्त कार्य के आधार पर [[कॉनर मैकब्राइड]] द्वारा कार्यान्वित किया गया था। इसका विकास [[नॉटिंघम]], डरहम, इंग्लैंड, [[स्कॉट एंड्रयू]] और रॉयल होलोवे, [[यूनाइटेड किंगडम]] (यूके) में लंदन विश्वविद्यालय में एपिग्राम समूह द्वारा जारी रखा गया है। एपिग्राम प्रणाली का वर्तमान प्रायोगिक कार्यान्वयन एक उपयोगकर्ता मैनुअल, एक ट्यूटोरियल और कुछ पृष्ठभूमि सामग्री के साथ मुफ्त में उपलब्ध है। इस सिस्टम का उपयोग [[लिनक्स]], [[माइक्रोसॉफ्ट विंडोज़]] और [[मैकओएस]] के अंतर्गत किया गया है। | ||
वर्तमान में इसका रखरखाव नहीं किया गया है, और संस्करण 2, जिसका उद्देश्य ऑब्जर्वेशनल टाइप थ्योरी को लागू करना था, कभी भी आधिकारिक तौर पर जारी नहीं किया गया था लेकिन [[GitHub]] में | वर्तमान में इसका रखरखाव नहीं किया गया है, और संस्करण 2, जिसका उद्देश्य ऑब्जर्वेशनल टाइप थ्योरी को लागू करना था, कभी भी आधिकारिक तौर पर जारी नहीं किया गया था लेकिन [[GitHub|गिटहब]] में उपस्थित है। | ||
== सिंटेक्स == | == सिंटेक्स == | ||
एपिग्राम [[LaTeX]] और [[ASCII]] में संस्करणों के साथ, दो-आयामी, [[प्राकृतिक कटौती]] शैली वाक्यविन्यास का उपयोग करता है। यहां द एपिग्राम ट्यूटोरियल से कुछ उदाहरण दिए गए हैं: | एपिग्राम [[LaTeX|लाटेक्स]] और [[ASCII|एएससीआईआई]] में संस्करणों के साथ, दो-आयामी, [[प्राकृतिक कटौती|प्राकृतिक निगमन]] शैली वाक्यविन्यास का उपयोग करता है। यहां ''द एपिग्राम ट्यूटोरियल'' से कुछ उदाहरण दिए गए हैं: | ||
=== उदाहरण === | === उदाहरण === | ||
Line 59: | Line 53: | ||
:<math>\mathsf{NatInd}\ P\ mz\ ms\ \mathsf{zero} \equiv mz</math> | :<math>\mathsf{NatInd}\ P\ mz\ ms\ \mathsf{zero} \equiv mz</math> | ||
:<math>\mathsf{NatInd}\ P\ mz\ ms\ (\mathsf{suc}\ n) \equiv ms\ n\ (NatInd\ P\ mz\ ms\ n)</math> | :<math>\mathsf{NatInd}\ P\ mz\ ms\ (\mathsf{suc}\ n) \equiv ms\ n\ (NatInd\ P\ mz\ ms\ n)</math> | ||
...और ASCII में: | ...और [[ASCII|एएससीआईआई]] में: | ||
{{sxhl|2=idris|1= | |||
NatInd : all P : Nat -> * => P zero -> | NatInd : all P : Nat -> * => P zero -> | ||
(all n : Nat => P n -> P (suc n)) -> | (all n : Nat => P n -> P (suc n)) -> | ||
Line 74: | Line 68: | ||
::: <math>\mathsf{plus\ zero}\ y \Rightarrow y</math> | ::: <math>\mathsf{plus\ zero}\ y \Rightarrow y</math> | ||
:::: <math>\quad\quad \mathsf{plus}\ (\mathsf{suc}\ x)\ y \Rightarrow \mathsf{suc} (\mathsf{plus}\ x\ y)\ \}\ \}</math> | :::: <math>\quad\quad \mathsf{plus}\ (\mathsf{suc}\ x)\ y \Rightarrow \mathsf{suc} (\mathsf{plus}\ x\ y)\ \}\ \}</math> | ||
...और ASCII में: | ...और [[ASCII|एएससीआईआई]] में: | ||
{{sxhl|2=idris|1= | {{sxhl|2=idris|1= | ||
plus x y <= rec x { | plus x y <= rec x { | ||
Line 84: | Line 78: | ||
}} | }} | ||
== आश्रित प्रकार == | == आश्रित प्रकार (डिपेंडेंट टाइप्स) == | ||
एपिग्राम अनिवार्य रूप से दो एक्सटेंशन को छोड़कर, [[सामान्यीकृत बीजगणितीय डेटा प्रकार]] एक्सटेंशन के साथ एक टाइप किया हुआ लैम्ब्डा कैलकुलस है। सबसे पहले, प्रकार प्रथम श्रेणी की इकाइयाँ हैं <math>\star</math>; प्रकार प्रकार की मनमानी अभिव्यक्तियाँ हैं <math>\star</math>, और प्रकार तुल्यता को प्रकार के सामान्य रूपों के संदर्भ में परिभाषित किया गया है। दूसरा, इसका एक आश्रित कार्य प्रकार है; के बजाय <math>P \rightarrow Q</math>, <math>\forall x : P \Rightarrow Q</math>, | एपिग्राम अनिवार्य रूप से दो एक्सटेंशन को छोड़कर, [[सामान्यीकृत बीजगणितीय डेटा प्रकार]] एक्सटेंशन के साथ एक टाइप किया हुआ लैम्ब्डा कैलकुलस है। सबसे पहले, प्रकार प्रथम श्रेणी की इकाइयाँ हैं <math>\star</math>; प्रकार प्रकार की मनमानी अभिव्यक्तियाँ हैं <math>\star</math>, और प्रकार तुल्यता को प्रकार के सामान्य रूपों के संदर्भ में परिभाषित किया गया है। दूसरा, इसका एक आश्रित कार्य प्रकार है; के बजाय <math>P \rightarrow Q</math>, <math>\forall x : P \Rightarrow Q</math>, जहाँ <math>x</math> में बंधा हुआ है <math>Q</math> उस मान के लिए जो फ़ंक्शन का तर्क (प्रकार का) है <math>P</math>) अंततः लेता है। | ||
पूर्ण आश्रित प्रकार, जैसा कि एपिग्राम में लागू किया गया है, एक शक्तिशाली अमूर्तता है। ([[ आश्रित एमएल ]] के विपरीत, निर्भर मूल्य किसी भी वैध प्रकार का हो सकता है।) आश्रित प्रकारों द्वारा | पूर्ण आश्रित प्रकार, जैसा कि एपिग्राम में लागू किया गया है, एक शक्तिशाली अमूर्तता है। ([[ आश्रित एमएल |आश्रित एमएल]] के विपरीत, निर्भर मूल्य किसी भी वैध प्रकार का हो सकता है।) आश्रित प्रकारों द्वारा लाये गए नये औपचारिक विनिर्देश क्षमताओं का एक नमूना ''द एपिग्राम ट्यूटोरियल'' में पाया जा सकता है। | ||
== यह भी देखें == | == यह भी देखें == | ||
Line 99: | Line 93: | ||
*{{Cite report |last1=Chapman |first1=James |last2=Altenkirch |first2=Thorsten |last3=McBride |first3=Conor |date=2006 |title=Epigram Reloaded: A Standalone Typechecker for ETT}} | *{{Cite report |last1=Chapman |first1=James |last2=Altenkirch |first2=Thorsten |last3=McBride |first3=Conor |date=2006 |title=Epigram Reloaded: A Standalone Typechecker for ETT}} | ||
*{{Cite report |last1=Chapman |first1=James |last2=Dagand |first2=Pierre-Évariste |last3=McBride |first3=Conor |last4=Morris |first4=Peter |date=2010 |title=The gentle art of levitation}} | *{{Cite report |last1=Chapman |first1=James |last2=Dagand |first2=Pierre-Évariste |last3=McBride |first3=Conor |last4=Morris |first4=Peter |date=2010 |title=The gentle art of levitation}} | ||
== बाहरी संबंध == | == बाहरी संबंध == | ||
* {{Official website|e-pig.org}} | * {{Official website|e-pig.org}} | ||
Line 106: | Line 98: | ||
* {{GitHub|mietek/epigram2|Epigram2}} | * {{GitHub|mietek/epigram2|Epigram2}} | ||
* [https://web.archive.org/web/20060209235723/http://www.macs.hw.ac.uk/~fairouz/projects/EffProClaLog.html EPSRC] on ALF, lego and related; archived version from 2006 | * [https://web.archive.org/web/20060209235723/http://www.macs.hw.ac.uk/~fairouz/projects/EffProClaLog.html EPSRC] on ALF, lego and related; archived version from 2006 | ||
== संदर्भ == | == संदर्भ == | ||
{{Reflist}} | {{Reflist}} | ||
[[Category:Created On 08/07/2023]] | [[Category:Created On 08/07/2023]] | ||
[[Category:Lua-based templates]] | |||
[[Category:Machine Translated Page]] | |||
[[Category:Official website not in Wikidata]] | |||
[[Category:Pages with script errors]] | |||
[[Category:Templates Vigyan Ready]] | |||
[[Category:Templates that add a tracking category]] | |||
[[Category:Templates that generate short descriptions]] | |||
[[Category:Templates using TemplateData]] | |||
[[Category:कार्यात्मक भाषाएँ]] | |||
[[Category:निर्भरता से टाइप की जाने वाली भाषाएँ]] | |||
[[Category:प्रमाण सहायक]] | |||
[[Category:बंद की गई प्रोग्रामिंग भाषाएँ]] | |||
[[Category:शैक्षणिक प्रोग्रामिंग भाषाएँ]] |
Latest revision as of 10:13, 28 July 2023
Paradigm | Functional |
---|---|
द्वारा डिज़ाइन किया गया | Conor McBride James McKinna |
Developer | Unmaintained |
पहली प्रस्तुति | 2004 |
Stable release | 1
/ October 11, 2006 |
टाइपिंग अनुशासन | strong, static, dependent |
ओएस | Cross-platform: Linux, Windows, macOS |
लाइसेंस | MIT[1] |
वेबसाइट | web |
Influenced by | |
ALF | |
Influenced | |
Agda, Idris |
एपिग्राम आश्रित प्रकार के साथ एक फंक्शनल प्रोग्रामिंग भाषा है, और एकीकृत विकास वातावरण (आईडीई) सामान्यतः भाषा के साथ पैक किया जाता है। प्रोग्राम विशिष्टताओं को व्यक्त करने के लिए एपिग्राम की प्रकार प्रणाली पर्याप्त सशक्त है। लक्ष्य सामान्य प्रोग्रामिंग से एकीकृत कार्यक्रमों और प्रमाणों में एक सुचारु संक्रमण का समर्थन करना है जिनकी शुद्धता को संकलक द्वारा जांच और प्रमाणित किया जा सकता है। एपिग्राम करी-हावर्ड पत्राचार का उपयोग करता है, इसे प्रस्तावों को प्रकार सिद्धांत भी कहा जाता है, और यह अंतर्ज्ञानवादी प्रकार सिद्धांत पर आधारित है।
एपिग्राम प्रोटोटाइप को जेम्स मैककिन्ना के साथ संयुक्त कार्य के आधार पर कॉनर मैकब्राइड द्वारा कार्यान्वित किया गया था। इसका विकास नॉटिंघम, डरहम, इंग्लैंड, स्कॉट एंड्रयू और रॉयल होलोवे, यूनाइटेड किंगडम (यूके) में लंदन विश्वविद्यालय में एपिग्राम समूह द्वारा जारी रखा गया है। एपिग्राम प्रणाली का वर्तमान प्रायोगिक कार्यान्वयन एक उपयोगकर्ता मैनुअल, एक ट्यूटोरियल और कुछ पृष्ठभूमि सामग्री के साथ मुफ्त में उपलब्ध है। इस सिस्टम का उपयोग लिनक्स, माइक्रोसॉफ्ट विंडोज़ और मैकओएस के अंतर्गत किया गया है।
वर्तमान में इसका रखरखाव नहीं किया गया है, और संस्करण 2, जिसका उद्देश्य ऑब्जर्वेशनल टाइप थ्योरी को लागू करना था, कभी भी आधिकारिक तौर पर जारी नहीं किया गया था लेकिन गिटहब में उपस्थित है।
सिंटेक्स
एपिग्राम लाटेक्स और एएससीआईआई में संस्करणों के साथ, दो-आयामी, प्राकृतिक निगमन शैली वाक्यविन्यास का उपयोग करता है। यहां द एपिग्राम ट्यूटोरियल से कुछ उदाहरण दिए गए हैं:
उदाहरण
प्राकृतिक संख्याएँ
निम्नलिखित घोषणा प्राकृतिक संख्याओं को परिभाषित करती है:
( ! ( ! ( n : Nat !
data !---------! where !----------! ; !-----------!
! Nat : * ) !zero : Nat) !suc n : Nat)
घोषणापत्र में ऐसा कहा गया है Nat
टाइप सिस्टम#प्रकारों के प्रकार वाला एक प्रकार है *
(यानी, यह एक सरल प्रकार है) और दो कंस्ट्रक्टर: zero
और suc
. निर्माता suc
एक सिंगल लेता है Nat
तर्क और रिटर्न ए Nat
. यह हास्केल (प्रोग्रामिंग भाषा) घोषणा के बराबर हैdata Nat = Zero | Suc Nat
.
LaTeX में, कोड इस प्रकार प्रदर्शित होता है:
क्षैतिज-रेखा संकेतन को यह मानकर पढ़ा जा सकता है कि (जो शीर्ष पर है) वह सत्य है, हम यह अनुमान लगा सकते हैं कि (जो नीचे है) सत्य है। उदाहरण के लिए, मान लीजिए n
प्रकार का है Nat
, तब suc n
प्रकार का है Nat
. यदि शीर्ष पर कुछ भी नहीं है, तो निचला कथन हमेशा सत्य होता है:zero
प्रकार का है Nat
(सभी मामलों में)।
प्राकृतिक पर प्रत्यावर्तन
...और एएससीआईआई में:
NatInd : all P : Nat -> * => P zero ->
(all n : Nat => P n -> P (suc n)) ->
all n : Nat => P n
NatInd P mz ms zero => mz
NatInd P mz ms (suc n) => ms n (NatInd P mz ms n)
जोड़
...और एएससीआईआई में:
plus x y <= rec x {
plus x y <= case x {
plus zero y => y
plus (suc x) y => suc (plus x y)
}
}
आश्रित प्रकार (डिपेंडेंट टाइप्स)
एपिग्राम अनिवार्य रूप से दो एक्सटेंशन को छोड़कर, सामान्यीकृत बीजगणितीय डेटा प्रकार एक्सटेंशन के साथ एक टाइप किया हुआ लैम्ब्डा कैलकुलस है। सबसे पहले, प्रकार प्रथम श्रेणी की इकाइयाँ हैं ; प्रकार प्रकार की मनमानी अभिव्यक्तियाँ हैं , और प्रकार तुल्यता को प्रकार के सामान्य रूपों के संदर्भ में परिभाषित किया गया है। दूसरा, इसका एक आश्रित कार्य प्रकार है; के बजाय , , जहाँ में बंधा हुआ है उस मान के लिए जो फ़ंक्शन का तर्क (प्रकार का) है ) अंततः लेता है।
पूर्ण आश्रित प्रकार, जैसा कि एपिग्राम में लागू किया गया है, एक शक्तिशाली अमूर्तता है। (आश्रित एमएल के विपरीत, निर्भर मूल्य किसी भी वैध प्रकार का हो सकता है।) आश्रित प्रकारों द्वारा लाये गए नये औपचारिक विनिर्देश क्षमताओं का एक नमूना द एपिग्राम ट्यूटोरियल में पाया जा सकता है।
यह भी देखें
- एएलएफ (प्रमाण सहायक), एपिग्राम के पूर्ववर्तियों के बीच एक प्रमाण सहायक।
अग्रिम पठन
- McBride, Conor; McKinna, James (2004). "The view from the left". Journal of Functional Programming. 14: 69–111. doi:10.1017/S0956796803004829. S2CID 6232997.
- McBride, Conor (2004). The Epigram Prototype, a nod and two winks (Report).
- McBride, Conor (2004). The Epigram Tutorial (Report).
- Altenkirch, Thorsten; McBride, Conor; McKinna, James (2005). Why Dependent Types Matter (Report).
- Chapman, James; Altenkirch, Thorsten; McBride, Conor (2006). Epigram Reloaded: A Standalone Typechecker for ETT (Report).
- Chapman, James; Dagand, Pierre-Évariste; McBride, Conor; Morris, Peter (2010). The gentle art of levitation (Report).
बाहरी संबंध
- Official website
- Epigram 1 on GitHub
- Epigram2 on GitHub
- EPSRC on ALF, lego and related; archived version from 2006
संदर्भ
- ↑ "Epigram – Official website". Retrieved 28 November 2015.