- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Haskell 新手。我正在尝试在 Haskell 中创建一种迷你语言,并且希望如果可能的话有一个名为 opp
(“opposite”的缩写)的高阶函数,它将许多熟悉的函数转换为它们明显的函数对立面。例如,opp succ
将是函数 pred
,opp head
将是 last
,依此类推。对于将函数转换为相反函数的含义,我没有一些一般性定义:我只想挑选几个关键示例并声明它们的相反函数。所以我想要一个几乎从未定义的高度多态函数。
困难似乎在于我想通过名称而不是其本质(可以这么说)来识别函数。这种困难的一个表现是,如果我写
opp succ = pred
然后 Haskell 将 succ
视为变量,因此给我一个常量函数,该函数始终采用值 pred
。我真正想说的是,“如果您看到字符串 opp succ
,那么可以将其视为 pred
的另一个名称。”但经过一段时间的搜索后,我不知道如何做到这一点(如果可能的话)。
总而言之,我想定义一个函数
opp::(a -> b) -> (a -> b)
通过说类似的话
opp succ = pred
opp pred = succ
opp head = 最后
opp 最后 = 头
只要我愿意,就可以添加到这个列表中。显然我不能那样做,但是有没有一些不可怕的方法可以达到相同的效果?
最佳答案
是的,你可以,但是你需要 RankNTypes 才能有一个好的实现。
{-# LANGUAGE TypeOperators #-}
{-# LANGUAGE RankNTypes #-}
module Opposites where
class Opposite f where
makeOpposite :: (a -> b) -> (a -> b) -> f a b
data FunctionAndOpposite a b = FunctionAndOpposite (a -> b) (a -> b)
instance Opposite (->) where
makeOpposite = const
instance Opposite FunctionAndOpposite where
makeOpposite = FunctionAndOpposite
opp :: FunctionAndOpposite a b -> a -> b
opp (FunctionAndOpposite _ f) = f
type a :<-> b = forall f. Opposite f => f a b
succ' :: Enum a => a :<-> a
succ' = makeOpposite succ pred
pred' :: Enum a => a :<-> a
pred' = makeOpposite pred succ
head' :: [a] :<-> a
head' = makeOpposite head last
last' :: [a] :<-> a
last' = makeOpposite last head
使用示例:
> head' [1,2,3]
1
> opp head' [1,2,3]
3
工作原理
首先是Opposite
类(class)。这只是描述了一个f a b
可以由 (a -> b)
的两个函数构造而成(正常和相反的功能)。
接下来是数据类型 FunctionAndOpposite
被定义为。这仅存储两个函数。现在标准函数和 this 都是类的实例 Opposite
。函数实例只是丢弃相反的函数。
现在是opp
可以定义函数。这只是从 FunctionAndOpposite
中取出第二个函数。 .
最后我们得到了将所有内容组合在一起的行:
type a :<-> b = forall f. Opposite f => f a b
它定义的是一个类型同义词,它接受两个输入类型 a 和 b,然后返回类型 f a b
,其中f
可以是任何Opposite
(取决于需要什么)。
( :<->
只是使用 TypeOperators
启用的类型的一个奇特名称)。
考虑代码 head' [1,2,3]
。 head'
类型为 forall f. Opposite f => f [a] a
。但是,由于它被用作函数应用程序(因为它之后有一个参数),f
必须是->
。因此,Opposite
的函数实现使用时,将第一个参数返回给 makeOpposite
,即head
(太棒了!)。
但是,可以说 opp head' [1,2,3]
叫做。 opp
类型为 FunctionAndOpposite a b -> a -> b
,所以f
必须是FunctionAndOpposite
。因此,FunctionAndOpposite
Opposite
的实例被调用,使用 makeOpposite
的两个参数创建数据类型。 opp
然后提取第二个函数,即 last
.
顺便说一句,这是使用 lens
中使用的类似技术来完成的。 Isomorphism
的库。同构基本上是一对互为逆的函数。例如(+2)
和(-2)
, reverse
和它本身。一般来说,这可能是一个更有用的概念,因为它允许您通过转换对数据类型运行操作。请参阅Control.Lens.Iso有关更多详细信息,但请注意,要理解这一点,您需要了解镜头概念,这是一项相当大的工作。
关于haskell - 是否可以根据具体情况定义高阶 "opposite"函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24241367/
我是 Robert,我在使用 JavaScript 时遇到了一些问题。 我得到了一个 (这是隐藏的)。我唯一想问你的是:我想检查日期是否在 中已通过。如果通过了我想改变CSS中容器的背景颜色。不幸的
所以我的问题是我想要求输入使用扫描仪的信息,但它根本不打印出来。当它显示跳过的扫描仪的值时,Scanner CheeseType = new Scanner(System.in);,我得到 null。
Fe_Order_Items fe_order_items_id fe_order_specification_id fe_users_id fe_menu_items_id fe_order_ite
人们普遍提到 - “Celery 是一个基于分布式消息传递的异步任务队列/作业队列”。虽然我知道如何使用 Celery 工作人员等。但内心深处我不明白分布式消息传递的真正重要性和意义以及任务队列在其中
我试图理解下面的代码,但有一些我以前从未见过的东西,那就是:“\&\&” 这是代码: int main() { fork() \&\& (fork() || fork()); exit(EXIT_SU
您好,我是论坛新手。 我有很多使用 python 的经验,但没有使用 tkinter 的经验。 这是我的代码: from tkinter import * def Done(): celEn
在 C# 中,假设我们有一个通用类和一个具体类 [Serializable] public class GenericUser { ... [Serializable] public class Co
我尝试使用的库有一个通用抽象类,其中有两个实现该基础的子类。我想编写一个类,它将根据构造函数参数的参数类型自动创建其中一个子级的实例。 基类没有默认构造函数 基类的构造函数也需要其他通用类的实例 代码
我是 Angular 的新手,我一直在尝试了解它的工作原理。我正在制作一个简单的应用程序,其中有人可以通过简单的 html 界面添加用户并使用 SQLite 将其存储在数据库中,然后他们可以编辑或删除
我想创建一个用于存储数据的对象,限制读/写访问。 例如: OBJ obj1; OBJ obj2; // DataOBJ has 2 methods : read() and write() DataO
注入(inject)/隔离密封在 dll 中且不实现接口(interface)的类的首选方法是什么? 我们使用 Ninject。 假设我们有一个类“Server”,我们想要注入(inject)/隔离“
在花费了至少 10 个小时的时间浏览在线资源、视频和教程之后,我有两个关于将我的 Android 应用程序与 mySQL 数据库连接的问题。 保存文件 1) 所有教程都将 php 文件保存在 C/WA
许多有经验的开发人员建议不要使用 Django multi-table inheritance因为它的性能不佳: Django gotcha: concrete inheritance通过 Jacob
我知道我冒着挨揍的风险,但我觉得我在这件事上要绕圈子。为了让模型可用于多个项目,我们已将模型移出到一个单独的项目(一个 DLL)中,作为一系列要实现的接口(interface)。我们的界面上有这一行:
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我遇到了一个特定 mac 的问题,它没有显示我正确构建的某个网站。我测试过的所有其他 mac 和 pc 都能正确显示网站,但是在所有浏览器中这个特定的 mac 显示不正确就像提到的那样,这在其他每台计
给定这段代码 public override void Serialize(BaseContentObject obj) { string file = ObjectDataStoreFold
我已经搜索了网络和我的服务器,但我无法找到我网站的 php.ini。我的网站出现以下错误。 Class 'finfo' not found Details G:\inetpub\wwwroot\lan
SQL 爱好者: 我正在尝试通过玩以下用例来挖掘我一些生疏的 sql 技能: 假设我们有一家有线电视公司,并且有跟踪的数据库表: 电视节目, 观看我们节目的客户,以及 观看事件(特定客户观看特定节目的
我正在设计一个使用 HTML5 网络组件(HTML 导入、影子 DOM、模板和自定义 HTML 元素)的网络应用程序,这些组件是通过普通 JavaScript(无框架)实现的。 Web 应用程序相当简
我是一名优秀的程序员,十分优秀!