- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
(+)
和 (++)
只是 mappend
的特化;我对吗?为什么需要它们?这是无用的重复,因为 Haskell 有这些强大的类型类和类型推断。
假设我们删除 (+)
和 (++)
并重命名 mappend
(+)
为了视觉方便和打字增益。
对于初学者来说,编码会更直观、更短、更容易理解:
--old and new
1 + 2
--result
3
--old
"Hello" ++ " " ++ "World"
--new
"Hello" + " " + "World"
--result
"Hello World"
--old
Just [1, 2, 3] `mappend` Just [4..6]
--new
Just [1, 2, 3] + Just [4..6]
--result
Just [1, 2, 3, 4, 5, 6]
fmap
与
map
相同或接近,
(.)
,
liftM
,
mapM
,
forM
, ...
fmap
的历史原因,但是幺半群呢? Haskell 委员会是否对此有所计划?它会破坏一些代码,但我听说,虽然我不确定,有一个即将到来的版本会有很大的变化,这是一个很好的机会。太可惜了……至少, fork 买得起吗?
(*)
或
(+)
适合
mappend
.其实我觉得
(*)
应该是
Monoid
的一部分!看:
mempty
和
mconcat
, 我们只有
mappend
.
class Monoid m where
mappend :: m -> m -> m
class Monoid m where
mappend :: m -> m -> m
mmultiply :: m -> m -> m
3 * 3
mempty + 3 + 3 + 3
0 + 3 + 3 + 3
9
Just 3 * Just 4
Just (3 * 4)
Just (3 + 3 + 3 +3)
Just 12
[1, 2, 3] * [10, 20, 30]
[1 * 10, 2 * 10, 3 * 10, ...]
[10, 20, 30, 20, 40, 60, ...]
Monoid
的实例没有必要重新定义它!然后
Monoid
更接近数学;也许我们也可以添加
(-)
和
(/)
上课!
Sum
的情况和
Product
以及功能重复:
mappend
变成
(+)
和新的
mmultiply
只是
(*)
.
mempty
对于
(*)
.
MonoidOperator
中。并定义
Monoid
如下:
class (Monoid m) => MonoidOperator mo m where
mempty :: m
mappend :: m -> m -> m
instance MonoidOperator (+) m where
mempty = 0
mappend = --definition of (+)
instance MonoidOperator (*) where
--...
class Monoid m where
-...
最佳答案
您正在尝试在这里混合一些不同的概念。
算术和列表连接是非常实用的直接操作。如果你写:
[1, 2] ++ [3, 4]
[1, 2, 3, 4]
作为结果。
mappend
不必是字面意思“将这个附加到那个;”它可以有许多其他含义。当你写:
[1, 2] `mappend` [3, 4]
[1, 2, 3, 4] -- concatenation, mempty is []
[4, 6] -- vector addition with truncation, mempty is [0,0..]
[3, 6, 4, 8] -- some inner product, mempty is [1]
[3, 4, 6, 8] -- the cartesian product, mempty is [1]
[3, 4, 1, 2] -- flipped concatenation, mempty is []
[] -- treating lists like `Maybe a`, and letting lists that
-- begin with positive numbers be `Just`s and other lists
-- be `Nothing`s, mempty is []
mappend
对于列表只是连接列表?因为这只是编写 Haskell 报告的人选择作为默认实现的 monoid 的定义,可能是因为它对列表的所有元素类型都有意义。实际上,您可以通过将列表包装在各种新类型中来为列表使用替代的 Monoid 实例;例如,对于列表执行笛卡尔积,有一个替代的 Monoid 实例。
mmultiply
的所有实例定义类似
mproduce
或可能
mproduct
/
Maybe a
之类的东西),这个概念已经存在并被称为
Semiring在数学中(好吧,您的问题中并没有真正涉及关联性,但是无论如何您都在示例中的不同概念之间跳跃-有时坚持关联性,有时不坚持-但总体思路是相同的)。
algebra
中。包裹。
(++)
是有原因的,
(+)
和
mappend
作为单独的概念,因为它们代表完全不同的计算思想。
关于Haskell:重复函数(+)和(++),mappend,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10961483/
(+)和 (++)只是 mappend 的特化;我对吗?为什么需要它们?这是无用的重复,因为 Haskell 有这些强大的类型类和类型推断。 假设我们删除 (+)和 (++)并重命名 mappend
在 Haskell 中,为什么 mappend 的中缀别名是(来自类(class) Monoid)<>而不是 + ?代数类(class) +通常用于幺半群的二元运算符。 最佳答案 函数+特定于数字,而
我有以下带有半群元素的阅读器模式: runFunction :: Reader Env Element runFunction = do a b <> c 在哪里 getA :: Reader
我听说Data.Text将替换 String s 在 future 的 Haskell 版本中。我遇到的一个问题是 (++)仅针对列表定义。连接两个 Text s,我需要使用 text1 `mappe
如果我 beta-reduce 以下表达式: foldr (mappend . Sum) 1 [2] = (mappend . Sum) 2 (foldr (mappend . Sum) 1 []
如果我 beta-reduce 以下表达式: foldr (mappend . Sum) 1 [2] = (mappend . Sum) 2 (foldr (mappend . Sum) 1 []
我是一名优秀的程序员,十分优秀!