- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
假设我已经上课了:
class C a b t where
f :: (a, b) -> (t a, t b)
现在有了这个定义,我可以定义实例:
(a,b) -> (Maybe a, Maybe b)
(a,b) -> ([a], [b])
但不适合(据我所知):
(a,b) -> (a,b)
(a,b) -> ((a, a), (b, b))
我可以像这样更改我的类定义:
type family T a b x
class C a b where
f :: (a, b) -> (T a b a, T a b b)
这将允许我执行上述操作,但随后我只能声明一个 f
对于每个 a
和b
.
基本上我希望能够将类型系列传递为 t
在原始定义中,如果已知,则由类型检查器隐式解析。我不想只是成功 f :: (a, b) -> (c, d)
因为我想保持 a
的不变性和b
对他们做了同样的事情,所以 swap . f
与 f . swap
类型相同。我想我可能需要 injective type families (来自 GHC 8.0)但我不确定。但也许还有另一种方法?
最佳答案
这可能会也可能不会回答您的问题,具体取决于您实际需要做什么。
标准解决方案是使用新类型来定义新实例。例如
newtype Pair a = Pair (a, a)
instance C a b Pair where
f = ...
但是,这将导致 f
具有类型
f :: (a, b) -> (Pair a, Pair b)
而不是想要的
f :: (a, b) -> ((a, a), (b, b))
后者可以通过无聊的方式恢复:
f' :: (a, b) -> ((a, a), (b, b))
f' p = case f p of (Pair x, Pair y) -> (x, y)
现在,编写诸如 f'
这样的“适配器”函数感觉是多余的:毕竟我们只是删除了一个 newtype
包装器,它不会改变运行时表示。更糟糕的是,这可能效率低下:考虑将 [Pair a]
转换为 [(a, a)]
。为此,我们需要映射整个列表,因此我们支付 O(n) 基本上什么都不做。
可以使用 safe coercions 构建有效的替代方案:
import Data.Coerce
f'' :: forall a b. (a, b) -> ((a, a), (b, b))
f'' = coerce (f :: (a, b) -> (Pair a, Pair b))
这允许使用newtype
来驱动实例选择,并在它们妨碍时将其删除。
现在,如果您的目标确实是定义没有 newtype
的新实例,那么这并没有多大帮助。相反,如果您想要一种简单的方法来从实例方法中删除 newtype
的包装器,它可以提供帮助。
关于haskell - 泛化类参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32732270/
我想概括 ($)喜欢 Control.Category概括(.) ,并且我已经使用本文末尾的代码 (also ideone) 完成了此操作。 在这段代码中,我创建了一个名为 FunctionObjec
我写这个问题是因为我只找到了有关我的场景的部分信息。 在 Azure 中克隆 VM,在我可以创建尽可能多的副本之后,我需要取消分配和泛化。我没有找到的详细信息是: VM 在核心方面概括了我的“成本”?
我写这个问题是因为我只找到了有关我的场景的部分信息。 在 Azure 中克隆 VM,在我可以创建尽可能多的副本之后,我需要取消分配和泛化。我没有找到的详细信息是: VM 在核心方面概括了我的“成本”?
我正在做一个关于使用邻接列表实现图的教程任务,但构造函数出现问题。 在给定的GraphTester.java中我有: //Constructor cannot be applied to given
我有一个疑问。想象一下,我有三个类别:学生、 worker 、学生/ worker 。 正确的是: ProfissonalArea | |
能否对这段代码进行泛化,以便我可以拥有可变数量的类型/参数? (我真的更喜欢将函数保留在结构之外,以保持代码更干净。) unsigned int const maxID = 2 ^ 8; typede
我想寻求您的帮助以解决我正在尝试解决的涉及 XPath 的问题。 我正在尝试概括用户提供的多个 Xpath,以获得最适合所有提供的示例的 XPath。这是我正在构建的网络抓取系统。 例如:如果用户提供
因此,有一种称为“折叠的通用属性”的东西,确切地说如下: g [] = i; g (x:xs) = f x (g xs) g = fold f i 但是,正如您现在可能的那样,有像 dropWhil
所以我有两种方法: private void updateJobType(, Boolean addTarget, JobType target) { if (addTarget == Boolea
是否有用于搜索图中结构的 levenshtein 距离的概括? 最佳答案 这篇论文可能会引起您的兴趣:Structural Similarity in Graphs 然而,我担心计算这样的距离会非常计
这个问题在这里已经有了答案: How to align checkboxes and their labels consistently cross-browsers (40 个答案) 关闭 9
我一直坚信,如果您复制和粘贴代码,那么会有更优雅的解决方案。我目前正在用 C++ 实现一个字符串后缀特里树,并且有两个实际上相同的函数,只是它们的返回语句不同。 第一个函数检查子字符串是否存在,第二个
我在 MVC 模式中的模型设计方面遇到了问题,并且我坚持使用 C# 的静态类型。 我想做的只是制作一组执行所有数据库插入、更新、删除操作的类。该组由从数据库中的每个表映射的类子组和访问表类的表模型类子
我在一个非常静态的环境中编程,希望以尽可能最好的方式概括问题/代码,使其干净并避免任何样板代码。这是我的情况;我正在开发一个位于程序 和扩展 之间的修改系统,其中扩展将转发 API 调用。当我的修改被
我有一个 api,它为我提供了如下方法: 按用户名搜索用户(用户名,限制) getRandomPremiumUsers(限制) getYoungUsers(maxAge, 限制) 我正在实现一个钩子(
除了通常的 ** 之外,大多数 UNIX 正则表达式都有, + , ?*运算符反斜杠运算符,其中 \1,\2,...匹配最后一个括号中的内容,例如 *L=(a*)b\1*匹配(非常规)语言 *a^n
我正在尝试使用复选框概括选择查询,您将看到的变量选择是从前端文件发布的,该文件使用复选框在后端创建数组。然后,该数组用于 select 语句的 SELECT 子句。目前,表头输出正确的 header
我需要构建一个乘积运算符,将两个任意大小的 vector 的乘积作为矩阵返回。 例如产品 u = [u1; u2; u3] 和 v = [v1; v2; v3] 将是u*v' = [u1*v1 u1*
目前,我有一个功能代码可以在我的页面上动态添加和删除表单输入。我有多个表单需要包含在页面上,所以我做了一个事件操作,他们可以按下一个按钮,它会隐藏除相关表单之外的所有表单。这工作正常,但它与我的 jQ
我正在使用 ExoPlayer 2 播放来自网络的音乐。现在我想通过使用漂亮的 SimpleCache 类来缓存下载的音乐。我的问题如下:每次我请求播放歌曲时,服务器都会返回一个不同的 URL(也是针
我是一名优秀的程序员,十分优秀!