<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div>It is worth noting that Maybe a and [a] are rather special cases. The former is the monoid you get from adjoining a unit to a semigroup. The latter is the free monoid. Most other monoids for things wrapped in an applicative are either based on the Alternative instance which inherently provides a monoidal structure or based on lifting a monoid pointwise into the data type. </div><div id="AppleMailSignature"><br></div><div id="AppleMailSignature">Here we have at least 3-4 possible, quite reasonable, monoids at play, and no real reason to choose any one of them over the others. In that situation, our general practice thus far has been to resist choosing if a choice hasn't already been made, simply because there is no real manner other than memorization / code inspection for a user to know which instance we happened to pick.</div><div id="AppleMailSignature"><br></div><div id="AppleMailSignature">I'm -1 on adding the instance proposed here.<br><br>Sent from my iPhone</div><div><br>On May 3, 2018, at 7:40 PM, 박신환 <<a href="mailto:ndospark320@naver.com">ndospark320@naver.com</a>> wrote:<br><br></div><blockquote type="cite"><div><style>p{margin-top:0px;margin-bottom:0px;}</style><!--  --><div style="font-size:10pt; font-family:NanumGothic, 나눔고딕, sans-serif;"><p>I aim to make the semantic consistent compared to that of other type classes (here Maybe).</p><p> </p><p>Also note that your instance is identical to upcoming Ap, as Ap (ZipList a). I also aim to make Monoids as diverse as possible. </p><p> </p><p> </p><p style="font-size:10pt;font-family:sans-serif;padding:0 0 0 10pt"><span>-----Original Message-----</span><br><b>From:</b> "Andrew Martin"<<a href="mailto:andrew.thaddeus@gmail.com">andrew.thaddeus@gmail.com</a>> <br><b>To:</b> "박신환"<<a href="mailto:ndospark320@naver.com">ndospark320@naver.com</a>>; <br><b>Cc:</b> "Haskell Libraries"<<a href="mailto:libraries@haskell.org">libraries@haskell.org</a>>; <br><b>Sent:</b> 2018-05-03 (목) 21:05:24<br><b>Subject:</b> Re: Monoid for ZipList<br> </p><div dir="ltr">There is another possible instance. We can instead write:<div> </div><div>    instance Semigroup a => Semigroup (ZipList a) where</div><div>      (<>) = liftA2 (<>)</div><div>    instance Monoid a => Monoid (ZipList a) where</div><div>      mempty = pure mempty</div><div> </div><div>This behaves differently, and it is also law-abiding.</div></div><div> </div>



</div>

<table style="display:none"><tbody><tr><td><img src="https://mail.naver.com/readReceipt/notify/?img=JqFCbHFTpz%2FYaqgZKrRZMqi0p4tXpoI0F4ErFA2ZKz3oMrEdKqvZaA34Mob9Kq0gMX%2B0MouZ74lR74lcWNFlbX30WLloWrdQarwGMNiCb400bdIcMBFOp6wn74eZpm%3D%3D.gif" border="0"></td></tr></tbody></table></div></blockquote><blockquote type="cite"><div><span>_______________________________________________</span><br><span>Libraries mailing list</span><br><span><a href="mailto:Libraries@haskell.org">Libraries@haskell.org</a></span><br><span><a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries">http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries</a></span><br></div></blockquote></body></html>