हास्केल - फ़नकार

Functorहास्केल में विभिन्न प्रकारों के कार्यात्मक प्रतिनिधित्व का एक प्रकार है जिसे मैप किया जा सकता है। यह बहुरूपता को लागू करने की एक उच्च स्तरीय अवधारणा है। हास्केल डेवलपर्स के अनुसार, सभी प्रकार जैसे कि सूची, मानचित्र, वृक्ष, आदि हास्केल फंक्टर का उदाहरण हैं।

Functor एक इनबिल्ट क्लास है जैसे कि फंक्शन डेफिनिशन -

class Functor f where 
   fmap :: (a -> b) -> f a -> f b

इस परिभाषा के द्वारा, हम यह निष्कर्ष निकाल सकते हैं कि Functor एक फ़ंक्शन है जो एक फ़ंक्शन लेता है, कहते हैं, fmap()और एक और फ़ंक्शन देता है। उपरोक्त उदाहरण में,fmap() फ़ंक्शन का एक सामान्यीकृत प्रतिनिधित्व है map()

निम्नलिखित उदाहरण में, हम देखेंगे कि हास्केल फनकार कैसे काम करता है।

main = do  
   print(map (subtract 1) [2,4,8,16])      
   print(fmap (subtract 1) [2,4,8,16])

यहां, हमने दोनों का उपयोग किया है map() तथा fmap()घटाव संचालन के लिए एक सूची पर। आप देख सकते हैं कि दोनों कथन तत्वों की सूची के समान परिणाम देंगे [1,3,7,15]।

दोनों फ़ंक्शन एक और फ़ंक्शन कहलाते हैं subtract() परिणाम प्राप्त करने के लिए।

[1,3,7,15]
[1,3,7,15]

फिर, क्या अंतर है map तथा fmap? अंतर उनके उपयोग में निहित है। Functor विभिन्न डेटा प्रकारों में "अधिक" और "कुछ भी नहीं" जैसे कुछ और कार्यात्मक को लागू करने में हमें सक्षम बनाता है।

main = do 
   print (fmap  (+7)(Just 10)) 
   print (fmap  (+7) Nothing)

उपरोक्त उपरोक्त कोड से टर्मिनल पर निम्न आउटपुट प्राप्त होंगे -

Just 17
Nothing

एपेक्टिव फ़ंक्टर

एक एपेक्टिव फ़ंक्टर एक सामान्य फ़ंक्टर होता है, जिसमें कुछ अतिरिक्त सुविधाएँ होती हैं, जो कि आवेदक प्रकार वर्ग द्वारा प्रदान की जाती हैं।

Functor का उपयोग करते हुए, हम आमतौर पर मौजूदा फ़ंक्शन को उसके अंदर परिभाषित एक अन्य फ़ंक्शन के साथ मैप करते हैं। लेकिन एक फ़ंक्शन को मैप करने का कोई तरीका नहीं है जो एक फ़नकार के अंदर एक और फ़नकार के साथ परिभाषित किया गया है। इसीलिए हमारे पास एक और सुविधा हैApplicative Functor। मैपिंग की यह सुविधा एप्‍लीकेशनल टाइप क्‍लास द्वारा लागू की गई है, जिसके तहत परिभाषित किया गया हैControlमापांक। यह वर्ग हमें काम करने के केवल दो तरीके देता है: एक हैpure और दूसरा है <*>

निम्नलिखित एप्लिकेशन फ़ंक्शनल की वर्ग परिभाषा है।

class (Functor f) => Applicative f where   
   pure :: a -> f a   
   (<*>) :: f (a -> b) -> f a -> f b

कार्यान्वयन के अनुसार, हम दो तरीकों का उपयोग करके एक और फ़नकार का नक्शा बना सकते हैं: "Pure" तथा "<*>"। "शुद्ध" विधि को किसी भी प्रकार का मान लेना चाहिए और यह हमेशा उस मूल्य का एक एपेक्टिव फ़ंक्टर लौटाएगा।

निम्नलिखित उदाहरण से पता चलता है कि एक आवेदन फ़ंक्शनल कैसे कार्य करता है

import Control.Applicative 

f1:: Int -> Int -> Int 
f1 x y = 2*x+y  
main = do  
   print(show $ f1 <$> (Just 1) <*> (Just 2) )

यहाँ, हमने फंक्शन के फंक्शन कॉल में एप्लाइड फंक्शन्स को लागू किया है f1। हमारा कार्यक्रम निम्न आउटपुट देगा।

"Just 4"

Monoids

हम सभी जानते हैं कि हास्केल कार्यों के रूप में सब कुछ परिभाषित करता है। फ़ंक्शन में, हमारे पास हमारे इनपुट को फ़ंक्शन के आउटपुट के रूप में प्राप्त करने के लिए विकल्प हैं। यह क्या एMonoid है।

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

यहाँ मोनॉइड की एक टाइप क्लास परिभाषा है।

class Monoid m where  
   mempty :: m 
   mappend :: m -> m -> m  
   mconcat :: [m] -> m 
   mconcat = foldr mappend mempty

हास्केल में मोनोइड के उपयोग को समझने के लिए निम्नलिखित उदाहरण पर एक नज़र डालें।

multi:: Int->Int 
multi x = x * 1 
add :: Int->Int 
add x = x + 0 

main = do  
   print(multi 9)  
   print (add 7)

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

9
7

यहां, फ़ंक्शन "मल्टी" इनपुट को "1" से गुणा करता है। इसी तरह, फ़ंक्शन "ऐड" इनपुट को "0" के साथ जोड़ता है। दोनों मामलों में, आउटपुट इनपुट के समान होगा। इसलिए, कार्य{(*),1} तथा {(+),0} monoids के आदर्श उदाहरण हैं।