Table of Content
These are Haskell related articles.How Haskell Syntax can Make Your Code Cleaner
Loop in Haskell With Map, Overview
Loop in Haskell With Map, Part One
Loop in Haskell With Map, Part Two
Loop in Haskell With Map, Part Three
Explaining Monad: Overview
Explaining Monad: References
Examining Bind in Haskell: Hello World
Examining Bind in Haskell: Example using Number
Examining Bind in Haskell: Do Notation
Confused? Me too.
This tutorial/ guidance/ article is one of some parts.
References: About Monad.
Examining Bind: Bind
>>=operator. Hello World Example.
<$>operators. Personal Notes. Example using Number.
Monadic Operator: Fish
The first one is overview, then some references. The last three parts is all about Example Code.
Common questions. What monads are ? What monads can do ? How a monad behaves ?
What Monads are good for?
Imagine, you have a paper, solving some math equations. You can write down those equations anywhere in that paper freely, and substitute each equation until it solved. Consider mimic these situation for programming language. Equation subtitution can be done by function call, until it solved. Every function called by dependency.
Now imagine, there is a programming language that everything is function (as mathematical equation), and every function called only by dependency, not by order as it is written. People come from imperative would haunt by this question below.
How do we make a sequence command, called line by line, in such order ?
Here comes Monad in rescue, force a structure to a flow. And here is how Monad works in binding pattern: Monad solve sequencing issue in functional programming, by treat each sequence command as function, and wrapped each input and output returned from the function, into box of special monadic type, in a consistent manner, so that the sequence function can be chained together. Thus making evaluation control possible, running as the order written.
Monad make, different functions composable, by boxing both input and output.
do notation make Monad more simple.
do itself is just a notation,
while Monads take all the horseworks.
Of course this conclusion is oversimplistic.
Monad is an abstraction, more than just for sequencing purpose.
But for now this understanding is enough.
So beginner do not need to worry too much about Monad.
Do notation allows you to write monadic computations using a pseudo-imperative.
It become a must ritual for Haskell beginner, to write in a blog, explaining about Monad.
Why don't they tell me about Monad ? Not in College, nor in Kindergarten.
The Monad Cursed Myth
It was stated by Douglas Crockford that Monad are Cursed.
The moment that it clicks and you understand what it means, you are suddenly incapable of explaining it anyone else.
This curse is made worse by the fact that after you understand it, you’ll begin to see it everywhere
We already have some people, trying to break the curse, by quote Monad in simple sentence.
Monads are like burritos.
I’m sure this guy is a genuinely pure genius. No need to speak spanish in order to understand Burrito. Anyone who ever write Monad would understand. But how do exactly a beginner implement a code is still unclear.
A monad is a purely abstract concept, with no fundamental relationship to anything you've probably ever heard of before.
This is a good read. A key feature of programming languages is their capability for designing abstractions. Monads are just too general a concept to be described by a single descriptive analogy.
Monad is a type constructor, a function called return, and a combinator function called bind or >>=. These three elements work together to encapsulate a strategy for combining computations to produce more complex computations.
Two sentence from the Intro.
Monads were brought to solve the problem of IO in Haskell.
Good explanation for Monad, the most dreaded Topic. Very nice slide.
Some Helpful People
Long discussion here. Get an answer from stackoverflow is instantly faster than reading a book. Just don’t forget the get the understanding by keep reading the concept from holy book. If you can afford to buy printed one.
Saunders Mac Lane
A monad is just a monoid in the category of endofunctors.
You can find a hieroglyphic math explanation, for this quote, in wiki, easily. Mediocre Mortal like me should not be burdened by abstraction. We are not lazy, we just need to write a few line codes. Maybe the author did not write for beginner audience.
Should I get dual degree in Computer Science and Math just to get along with these People ?
Allright. I respect the writer. I just need a little patient. After locking myself all alone in my office in saturday night, reading his explanation. It make sense. In fact his guide explaining in a gentle way. I found many important properties, not covered by other blog.
How does Monad works
After searching for about, what behind Monad, I found a diagram here.
Monad is a special kind of Applicative. Although it is not derived directly. Where Apllicative is special kind of Functor. Applicative itself is abbreviation of ApplicativeFunctor. So here some basic class we need to comprehend.
If you insist, and love operator marching.
We have been doing it in
Don't be Panic
Thank you for Reading.