- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这个问题在这里已经有了答案:
Is there a monad that doesn't have a corresponding monad transformer (except IO)?
(4 个回答)
3年前关闭。
Monad 转换器以所有标准 monad(Reader、Writer、State、Cont、List 等)而闻名,但这些 monad 转换器中的每一个都以略有不同的方式工作。给定具有 monad 实例的类型构造函数的定义,没有用于构造 monad 转换器的通用方法或公式。因此,不能保证根据某些任意业务需求设计的 monad 数据类型将具有 monad 转换器。有这么明显的例子吗?
相关工作
Another question解释了两个单子(monad)的仿函数组合不一定是单子(monad)。另见 this question .这些例子并没有回答当前的问题——它们只是说明了没有构建 monad 转换器的通用方法的问题。这些例子表明,给定两个单子(monad) M 和 N,我们有时会发现 M (N a) 是单子(monad),有时 N (M a) 是单子(monad),有时两者都不是单子(monad)。但这既没有说明如何为 M 或 N 构造 monad 转换器,也没有说明它是否存在。
An answer to another question认为IO
monad 不能有一个 monad 转换器,因为如果它有一个 IOT
, 我们可以申请 IOT
至 List
,然后将一个空列表( lift []
)提升到生成的 monad 中,将不得不撤消 IO monad“更早”执行的副作用。这个论点是基于 IO
的想法。 monad“实际上执行”了可能无法撤消的副作用。然而,IO
monad 不是显式类型构造函数。
讨论
在每个明确给出 monad 类型的示例中,都可以以某种方式找到 monad 转换器——有时需要一定的独创性。例如,ListT
Haskell 库中存在的转换器是 relatively recently发现以微妙的方式不正确,但最终通过更改 ListT
的定义解决了问题。 .
没有转换器的单子(monad)的标准示例是单子(monad),例如 IO
,实际上不是由显式类型构造函数定义的 - IO
是由库以某种方式在低级别定义的不透明“魔术”类型。显然不能定义 IO
作为显式类型构造函数,具有由纯函数给出的 monad 实例。 IO
示例表明,如果我们允许 monad 实例包含具有不纯副作用的隐藏低级代码,则 monad 转换器可能无法存在。因此,让我们将注意力限制在使用纯函数实现的 monad 上。
似乎没有一种算法可以从 monad 的源代码中自动推导出 monad 转换器。我们甚至知道这总是可能的吗?
为了更清楚地说明我所说的 monad 的“显式示例”是什么意思:假设我声称
type Q u v a = ((u -> (a, Maybe a)) -> v) -> u -> (a, Maybe a)
Monad
相对于类型参数
a
的实例,我为
Monad
的实现生成了源代码
Q u v
的实例作为纯函数
return
和
join
.那么我们知道
Q u v
吗?有一个 monad 转换器
QT u v
使得
QT u v Id
相当于
Q u v
, monad 更改器(mutator)的定律成立吗?那么我们知道如何构造
QT
吗?明确的?我不。
type F a = r -> Either (a, a) (a, a, Maybe a)
以及一个 monad 实例的实现,用于查找 monad 转换器的代码;让我们将自己限制为由 ->
的任意组合构成的类型构造函数。 、元组和 Either
为简单起见;或 type F a = r -> Either (a, a, a) (a, a, Maybe a)
或其他什么,这样这是合法的 Monad
,带有 Monad
由纯函数给出的实例,但我们可以证明 F
没有单子(monad)变压器。 最佳答案
这不是答案,但对于评论来说太大了。我们可以写
{-# LANGUAGE GeneralizedNewtypeDeriving
, DeriveFunctor #-}
import Control.Monad.Free
-- All the IO primops you could ever need
data IOF a = PutStrLn String a
| GetLine (String -> a)
deriving Functor
newtype MyIO a = MyIO {unMyIO :: Free IOF a}
deriving (Functor, Applicative, Monad)
import Control.Monad.Trans.Free
newtype IOT m a = IOT {unIOT :: FreeT IOF m a}
deriving (Functor, Applicative, Monad, MonadTrans)
IO
被排除在外,尽管这种情况下的同构不是“内部的”。
关于haskell - 没有 monad 转换器的 monad 的显式示例是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50260591/
我在完成这个用于转换咖啡价格的 JavaScript 时遇到问题。我下载了一个调试器,它一直告诉我价格未定义,我不明白。这是脚本。 Coffee House
我有一个使用以下方法的 JSF 转换器: @Override public Object getAsObject(FacesContext context, UIComponent compo
我正在寻找类似paint.net 或Gimp 的东西,但对于音频文件,并在Windows 上运行。 最佳答案 Audacity太棒了 关于audio - 免费的声音编辑器/转换器?,我们在Stack
我目前正在使用以下代码来缩进 XML: transformer.setOutputProperty(OutputKeys.INDENT, "yes"); transformer.setOutputPr
我收到以下错误:Conversion Error setting value 'home' for 'null Converter'. Home是所显示内容的字符串表示形式。 对我来说,这没有意义。这
我的 UI 中有很多数字要处理。我希望它们中的一些没有小数位,一些是小数点后 2 位,而另一些是小数点后(3 位或 4 位小数)。 我有一个名为 DoubleToStringConverter 的转换
我正在制作一个货币转换器。转换器需要一个最小范围和最大范围,如果货币值高于或低于这些范围,转换器将要求您更改范围以能够转换货币。例如,如果用户将范围设置在 min-range 3 和 max-rang
我正在使用 Spring Shell 2 CLI,并尝试通过反射在运行时从定义的接口(interface)生成命令。 更新:接口(interface)的实现也是在运行时生成的。 我正在使用 Confi
我正在尝试编写一个通用的 Converter 以在我的代码中的多个类似情况下使用。我有一组子类,我只想使用一个 Converter 来处理,所以我想将一些东西(类类型/一些参数/等)传递给 Conve
我正在尝试读取一个在每个单元格中包含多个值的 csv 文件,并且我想将它们编码为单个 int 格式的字节以存储在 Pandas 单元格中,(例如 (1, 1) -> 771)。为此,我想使用 read
我正在 VC2013 中开发一个 c# Windows Phone 8.1 应用程序,并偶然发现了一个奇怪的问题。 为了使我的代码更“干净”,我决定将应用程序的不同部分放入不同的文件夹中。在 c# 代
是否有将 Puppet 脚本转换为 Chef 的转换器? 我找到了将 Chef 脚本转换为 Puppet 的 ruby 脚本 https://github.com/relistan/chef2pu
我已经开始寻找很好的解决方案,如何使用 Spring CassandraOperations 很好地持久化实体。问题开始是因为我的实体中的某些字段不受 cassandra 支持,例如乔达日期时间。 解
我知道如何实现单链表 monad 转换器,但无法运行其对应的数组。问题是存在分组效应,这使得转换器仅对可交换基 monad 有效。这是一个示例,为了简单起见,转换器和基础 monad 都是数组,并且没
当我尝试将值转换器从定义的枚举状态绑定(bind)到刷子时,我的 XAML 设计器中出现错误: 未找到“OKStatus”资源。 该应用程序在运行时运行良好,但我无法在设计器中看到我的 GUI。 我的
我需要使用列表单子(monad)变压器。我读到 ListT IO 存在潜在问题来自 Control.Monad.List , 自 IO不是可交换的,所以我在看 ListT done right .但我
不用多想,在我看来,一大组 Prolog 的功能可以实现为关系演算(a.k.a. SQL)。 有没有人听说过任何工具可以自动将 Prolog 转换为 SQL? 最佳答案 推荐: https://www
假设我在十六进制值(包括 alpha)中有这种颜色: x [1] "255 36 0" 但是,查看您请求的结果,您似乎在 x 中将 alpha 值作为第一个十六进制数。 - 所以你需要创建一个子字符
我正在寻找可用于跟踪程序进度的 monad 转换器。要解释如何使用它,请考虑以下代码: procedure :: ProgressT IO () procedure = task "Print som
我有一个非常基本的需求,即从数据库中获取一些数据并返回一个 DTO。我发现使用 nHibernate 连接多个表和“投影”可以说,到 DTO 是相当多的代码。在查看了几个示例后,大多数示例都不起作用,
我是一名优秀的程序员,十分优秀!