हास्केल - कार्य

हास्केल में फ़ंक्शंस एक प्रमुख भूमिका निभाते हैं, क्योंकि यह एक कार्यात्मक प्रोग्रामिंग भाषा है। अन्य भाषाओं की तरह, हास्केल की अपनी कार्यात्मक परिभाषा और घोषणा है।

  • फ़ंक्शन घोषणा में फ़ंक्शन नाम और इसके आउटपुट के साथ इसकी तर्क सूची शामिल होती है।

  • फ़ंक्शन परिभाषा वह जगह है जहां आप वास्तव में एक फ़ंक्शन को परिभाषित करते हैं।

आइए हम छोटे उदाहरण लेते हैं add इस अवधारणा को विस्तार से समझने के लिए कार्य करें।

add :: Integer -> Integer -> Integer   --function declaration 
add x y =  x + y                       --function definition 

main = do 
   putStrLn "The addition of the two numbers is:"  
   print(add 2 5)    --calling a function

यहां, हमने अपने कार्य को पहली पंक्ति में और दूसरी पंक्ति में घोषित किया है, हमने अपना वास्तविक कार्य लिखा है जो दो तर्क देगा और एक पूर्णांक प्रकार का उत्पादन करेगा।

अधिकांश अन्य भाषाओं की तरह, हास्केल से कोड का संकलन शुरू होता है mainतरीका। हमारा कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

The addition of the two numbers is:
7

पैटर्न मिलान

पैटर्न मिलान विशिष्ट प्रकार के अभिव्यक्तियों के मिलान की प्रक्रिया है। यह आपके कोड को सरल बनाने की तकनीक के अलावा और कुछ नहीं है। इस तकनीक को किसी भी प्रकार की टाइप क्लास में लागू किया जा सकता है। अगर-एल्स का उपयोग पैटर्न मिलान के वैकल्पिक विकल्प के रूप में किया जा सकता है।

पैटर्न मिलान को गतिशील बहुरूपता का एक प्रकार माना जा सकता है जहां रनटाइम के दौरान, विभिन्न तरीकों को अपने तर्क सूची के आधार पर निष्पादित किया जा सकता है।

निम्नलिखित कोड ब्लॉक पर एक नज़र डालें। यहां हमने किसी संख्या के भाज्य की गणना के लिए पैटर्न मिलान की तकनीक का उपयोग किया है।

fact :: Int -> Int 
fact 0 = 1 
fact n = n * fact ( n - 1 ) 

main = do 
   putStrLn "The factorial of 5 is:" 
   print (fact 5)

हम सभी जानते हैं कि किसी संख्या के भाज्य की गणना कैसे की जाती है। संकलक एक तर्क के साथ "तथ्य" नामक फ़ंक्शन की खोज शुरू करेगा। यदि तर्क 0 के बराबर नहीं है, तो संख्या वास्तविक तर्क की तुलना में 1 के साथ एक ही फ़ंक्शन को कॉल करती रहेगी।

जब तर्क का पैटर्न ठीक 0 से मेल खाता है, तो यह हमारे पैटर्न को "तथ्य 0 = 1" कहेगा। हमारा कोड निम्न आउटपुट का उत्पादन करेगा -

The factorial of 5 is:
120

गार्ड

Guardsएक अवधारणा है जो पैटर्न मिलान के समान है। पैटर्न मिलान में, हम आमतौर पर एक या अधिक अभिव्यक्तियों से मेल खाते हैं, लेकिन हम उपयोग करते हैंguards एक अभिव्यक्ति की कुछ संपत्ति का परीक्षण करने के लिए।

हालाँकि यह सलाह दी जाती है कि पैटर्न से मेल खाते हुए का उपयोग करें guards, लेकिन एक डेवलपर के दृष्टिकोण से, guardsअधिक पठनीय और सरल है। पहली बार उपयोगकर्ताओं के लिए,guards इफ-एल्स बयानों के समान दिख सकते हैं, लेकिन वे कार्यात्मक रूप से भिन्न हैं।

निम्नलिखित कोड में, हमने अपने को संशोधित किया है factorial की अवधारणा का उपयोग करके कार्यक्रम guards

fact :: Integer -> Integer 
fact n | n == 0 = 1 
       | n /= 0 = n * fact (n-1) 
main = do 
   putStrLn "The factorial of 5 is:"  
   print (fact 5)

यहां, हमने दो घोषित किए हैं guards, "|" और बुला रहा हैfact से कार्य करते हैं main। आंतरिक रूप से, कंपाइलर उसी तरीके से काम करेगा जैसे पैटर्न के मामले में निम्नलिखित आउटपुट प्राप्त करने के लिए -

The factorial of 5 is:
120

कहां कारण

Whereएक कीवर्ड या इनबिल्ट फंक्शन है जिसका उपयोग रनटाइम में एक वांछित आउटपुट उत्पन्न करने के लिए किया जा सकता है। जब फ़ंक्शन गणना जटिल हो जाती है तो यह बहुत उपयोगी हो सकता है।

एक परिदृश्य पर विचार करें जहां आपका इनपुट कई मापदंडों के साथ एक जटिल अभिव्यक्ति है। ऐसे मामलों में, आप "जहां" खंड का उपयोग करके पूरी अभिव्यक्ति को छोटे भागों में तोड़ सकते हैं।

निम्नलिखित उदाहरण में, हम एक जटिल गणितीय अभिव्यक्ति ले रहे हैं। हम दिखाएंगे कि आप हास्केल का उपयोग करके एक बहुपद समीकरण [x ^ 2 - 8x + 6] की जड़ें कैसे पा सकते हैं।

roots :: (Float, Float, Float) -> (Float, Float)  
roots (a,b,c) = (x1, x2) where 
   x1 = e + sqrt d / (2 * a) 
   x2 = e - sqrt d / (2 * a) 
   d = b * b - 4 * a * c  
   e = - b / (2 * a)  
main = do 
   putStrLn "The roots of our Polynomial equation are:" 
   print (roots(1,-8,6))

दिए गए बहुपद समारोह की जड़ों की गणना करने के लिए हमारी अभिव्यक्ति की जटिलता पर ध्यान दें। यह काफी जटिल है। इसलिए, हम अभिव्यक्ति का उपयोग करके अभिव्यक्ति को तोड़ रहे हैंwhereखंड। उपरोक्त कोड का कोड निम्न आउटपुट उत्पन्न करेगा -

The roots of our Polynomial equation are:
(7.1622777,0.8377223)

पुनरावृत्ति समारोह

पुनरावृत्ति एक ऐसी स्थिति है जहां एक फ़ंक्शन बार-बार खुद को कॉल करता है। हास्केल एक से अधिक बार किसी भी अभिव्यक्ति को लूप करने की कोई सुविधा प्रदान नहीं करता है। इसके बजाय, हास्केल चाहता है कि आप अपनी पूरी कार्यक्षमता को विभिन्न कार्यों के संग्रह में तोड़ दें और अपनी कार्यक्षमता को लागू करने के लिए पुनरावर्तन तकनीक का उपयोग करें।

आइए हम अपने पैटर्न मिलान उदाहरण पर फिर से विचार करें, जहां हमने किसी संख्या के गुणन की गणना की है। एक संख्या के भाज्य का पता लगाना रिकर्सन का उपयोग करने का एक क्लासिक मामला है। यहाँ, आप "पुनरावृत्ति से किसी भी भिन्न मिलान कैसे कर सकते हैं?" इन दोनों के बीच का अंतर उनके उपयोग करने के तरीके में है। पैटर्न की मैचिंग टर्मिनल की कमी को स्थापित करने पर काम करती है, जबकि पुनरावृत्ति एक फ़ंक्शन कॉल है।

निम्नलिखित उदाहरण में, हमने 5 के भाज्य की गणना करने के लिए पैटर्न मिलान और पुनरावृत्ति दोनों का उपयोग किया है।

fact :: Int -> Int 
fact 0 = 1 
fact n = n * fact ( n - 1 ) 

main = do 
   putStrLn "The factorial of 5 is:" 
   print (fact 5)

यह निम्नलिखित उत्पादन का उत्पादन करेगा -

The factorial of 5 is:
120

उच्च आदेश समारोह

अब तक, हमने जो देखा है, वह यह है कि हास्केल फंक्शन में से एक लेता है type इनपुट के रूप में और एक और उत्पादन typeआउटपुट के रूप में, जो अन्य अनिवार्य भाषाओं में बहुत समान है। हायर ऑर्डर फ़ंक्शंस हास्केल की एक अनूठी विशेषता है जहां आप एक फ़ंक्शन को इनपुट या आउटपुट तर्क के रूप में उपयोग कर सकते हैं।

यद्यपि यह एक आभासी अवधारणा है, लेकिन वास्तविक दुनिया के कार्यक्रमों में, हर फ़ंक्शन जिसे हम हास्केल में परिभाषित करते हैं, आउटपुट प्रदान करने के लिए उच्च-क्रम तंत्र का उपयोग करते हैं। यदि आपको हास्केल के पुस्तकालय समारोह को देखने का मौका मिलता है, तो आप पाएंगे कि अधिकांश पुस्तकालय कार्यों को उच्चतर क्रम में लिखा गया है।

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

import Data.Char  
import Prelude hiding (map) 

map :: (a -> b) -> [a] -> [b] 
map _ [] = [] 
map func (x : abc) = func x : map func abc  
main = print $ map toUpper "tutorialspoint.com"

उपरोक्त उदाहरण में, हमने उपयोग किया है toUpper प्रकार वर्ग का कार्य Charहमारे इनपुट को अपरकेस में बदलने के लिए। यहां, विधि "मानचित्र" एक फ़ंक्शन को एक तर्क के रूप में ले रहा है और आवश्यक आउटपुट वापस कर रहा है। यहाँ इसका उत्पादन है -

sh-4.3$ ghc -O2 --make *.hs -o main -threaded -rtsopts
sh-4.3$ main
"TUTORIALSPOINT.COM"

लैम्ब्डा एक्सप्रेशन

हमें कभी-कभी एक फ़ंक्शन लिखना पड़ता है जो एक आवेदन के पूरे जीवनकाल में केवल एक बार उपयोग होने वाला है। इस तरह की स्थितियों से निपटने के लिए, हास्केल डेवलपर्स एक अन्य अनाम ब्लॉक का उपयोग करते हैं, जिसे जाना जाता हैlambda expression या lambda function

एक परिभाषा के बिना एक फ़ंक्शन को लंबो फ़ंक्शन कहा जाता है। एक लैम्ब्डा फ़ंक्शन को "\" वर्ण द्वारा निरूपित किया जाता है। आइए हम निम्नलिखित उदाहरण लेते हैं जहां हम किसी फ़ंक्शन को बनाए बिना इनपुट मान को 1 से बढ़ाएंगे।

main = do 
   putStrLn "The successor of 4 is:"  
   print ((\x -> x + 1) 4)

यहां, हमने एक अनाम फ़ंक्शन बनाया है जिसमें कोई नाम नहीं है। यह पूर्णांक 4 को एक तर्क के रूप में लेता है और आउटपुट मूल्य को प्रिंट करता है। हम मूल रूप से एक फ़ंक्शन को ठीक से घोषित किए बिना भी काम कर रहे हैं। यही लंबोदर भावों का सौंदर्य है।

हमारी लैम्ब्डा अभिव्यक्ति निम्नलिखित उत्पादन का उत्पादन करेगी -

sh-4.3$ main
The successor of 4 is:
5