कार्यात्मक प्रोग्रामिंग - लैम्ब्डा कैलकुलस
लैम्ब्डा कैलकुलस एक फ्रेमवर्क है जिसे अलोंजो चर्च द्वारा 1930 के दशक में विकसित किया गया था ताकि कार्यों के साथ संगणना का अध्ययन किया जा सके।
Function creation - चर्च ने नोटेशन की शुरुआत की λx.Eएक फ़ंक्शन को निरूपित करने के लिए जिसमें 'x' एक औपचारिक तर्क है और 'E' कार्यात्मक निकाय है। ये कार्य बिना नाम और एकल तर्क के हो सकते हैं।
Function application - चर्च ने नोटेशन का इस्तेमाल किया E1.E2 फ़ंक्शन के अनुप्रयोग को निरूपित करने के लिए E1 वास्तविक तर्क के लिए E2। और सभी कार्य एकल तर्क पर हैं।
लैम्ब्डा कैलकुलस का सिंटैक्स
लैम्ब्डा कैलकुलस में तीन अलग-अलग प्रकार के भाव शामिल हैं, अर्थात,
E :: = x (चर)
| ई 1 ई 2 (फ़ंक्शन अनुप्रयोग)
| λx.E (फंक्शन क्रिएशन)
कहाँ पे λx.E लैंबडा एब्स्ट्रैक्शन कहलाता है और E को λ-अभिव्यक्तियों के रूप में जाना जाता है।
लैम्ब्डा कैलकुलस का मूल्यांकन
शुद्ध लैम्ब्डा कैलकुलस का कोई अंतर्निहित कार्य नहीं है। आइए हम निम्नलिखित अभिव्यक्ति का मूल्यांकन करें -
(+ (* 5 6) (* 8 3))
यहाँ, हम '+' से शुरू नहीं कर सकते क्योंकि यह केवल संख्याओं पर काम करता है। दो निरर्थक भाव हैं: (* ५ ६) और (*। ३)।
हम या तो पहले कम कर सकते हैं। उदाहरण के लिए -
(+ (* 5 6) (* 8 3))
(+ 30 (* 8 3))
(+ 30 24)
= 54
ule-कटौती नियम
हमें λ को संभालने के लिए एक कमी नियम की आवश्यकता है
(λx . * 2 x) 4
(* 2 4)
= 8
इसे β-कमी कहा जाता है।
औपचारिक पैरामीटर का उपयोग कई बार किया जा सकता है -
(λx . + x x) 4
(+ 4 4)
= 8
जब कई शर्तें होती हैं, तो हम उन्हें निम्नानुसार संभाल सकते हैं -
(λx . (λx . + (− x 1)) x 3) 9
भीतरी x भीतर का है λ और बाहरी एक्स बाहरी एक से संबंधित है।
(λx . + (− x 1)) 9 3
+ (− 9 1) 3
+ 8 3
= 11
मुफ्त और बाध्य चर
एक अभिव्यक्ति में, एक चर की प्रत्येक उपस्थिति या तो "मुक्त" (λ के लिए) या "बाध्य" (एक λ के लिए) है।
of-कमी (λx . E) y हर की जगह x कि में मुक्त होता है E साथ में y। उदाहरण के लिए -
अल्फा रिडक्शन
अल्फा की कमी बहुत सरल है और यह लंबोदर अभिव्यक्ति के अर्थ को बदलने के बिना किया जा सकता है।
λx . (λx . x) (+ 1 x) ↔ α λx . (λy . y) (+ 1 x)
उदाहरण के लिए -
(λx . (λx . + (− x 1)) x 3) 9
(λx . (λy . + (− y 1)) x 3) 9
(λy . + (− y 1)) 9 3
+ (− 9 1) 3
+ 8 3
11
चर्च-रोसेर प्रमेय
चर्च-रोसेर प्रमेय निम्नलिखित बताता है -
यदि E1 E E2 है, तो एक E मौजूद है जैसे कि E1 → E और E2 → E. "किसी भी तरह से कटौती अंततः एक ही परिणाम उत्पन्न कर सकती है।"
यदि E1 → E2, और E2 सामान्य रूप है, तो E1 से E2 तक सामान्य क्रम में कमी है। "सामान्य-क्रम में कमी हमेशा एक सामान्य रूप का उत्पादन करेगी, यदि कोई मौजूद है।"