हास्केल - मोनाड्स

Monadsकुछ और नहीं बल्कि कुछ अतिरिक्त सुविधाओं के साथ एपेक्टिव फ़ंक्टर का एक प्रकार है। यह एक प्रकार का वर्ग है, जिसे तीन मूलभूत नियमों के रूप में जाना जाता हैmonadic rules

तीनों नियम मोनाद घोषणा पर सख्ती से लागू होते हैं जो इस प्रकार है -

class Monad m where  
   return :: a -> m a 
   (>>=) :: m a -> (a -> m b) -> m b 
   (>>) :: m a -> m b -> m b 
   x >> y = x >>= \_ -> y 
   fail :: String -> m a  
   fail msg = error msg

मोनाद घोषणा पर लागू होने वाले तीन बुनियादी कानून हैं -

  • Left Identity Law - returnफ़ंक्शन मान को परिवर्तित नहीं करता है और इसे मोनाड में कुछ भी नहीं बदलना चाहिए। इसे "वापसी> => एमएफ = एमएफ" के रूप में व्यक्त किया जा सकता है।

  • Right Identity Law - returnफ़ंक्शन मान को परिवर्तित नहीं करता है और इसे मोनाड में कुछ भी नहीं बदलना चाहिए। इसे "mf> => वापसी = mf" के रूप में व्यक्त किया जा सकता है।

  • Associativity- इस कानून के अनुसार, फनट्रक्टर और मोनाड दोनों उदाहरण एक ही तरीके से काम करना चाहिए। इसे गणितीय रूप से "(एफ> ==> जी)> => एच = एफ> => (जी> = एच)" के रूप में व्यक्त किया जा सकता है।

पहले दो कानून एक ही बिंदु को पुनरावृत्त करते हैं, अर्थात, ए return के दोनों तरफ पहचान व्यवहार होना चाहिए bind ऑपरेटर।

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

main = do
   print([1..10] >>= (\x -> if odd x then [x*2] else []))

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

[2,6,10,14,18]