- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 GHC.TypeLits
,我们可以写一个简单的类型级编号列表(或向量)。
> {-# LANGUAGE TypeOperators, KindSignatures, GADTs, DataKinds, ScopedTypeVariables #-}
> import GHC.TypeLits
> data Vec :: * -> Nat -> * where
> VNil :: Vec e 0
> (:-) :: e -> Vec e n -> Vec e (n+1)
TypeLits
的规范向量定义.直观地,追加操作应如下所示:
> vecAppend :: Vec e n -> Vec e m -> Vec e (n + m)
> vecAppend VNil vec = vec
> vecAppend (a :- as) vec = a :- vecAppend as vec
Could not deduce (((n1 + m) + 1) ~ (n + m))
from the context (n ~ (n1 + 1))
n1 + 1 ~ n
,
(n1 + m) + 1 ~ n1 + 1 + m ~ n + m
,但求解器似乎不知道
+
的交换性和结合性(类型函数通常不是可交换的或关联的!)
> vecAppend :: Vec e (n+1) -> Vec e m -> Vec e ((n + 1) + m)
> vecAppend VNil vec = vec
> vecAppend (a :- as) vec = a :- vecAppend as vec
Could not deduce (((n1 + 1) + m) ~ ((n + m) + 1))
from the context ((n + 1) ~ (n1 + 1))
bound by a pattern with constructor
:- :: forall e (n :: Nat). e -> Vec e n -> Vec e (n + 1),
in an equation for ‘vecAppend’
NB: ‘+’ is a type function, and may not be injective
Expected type: Vec l ((n + 1) + m)
Actual type: Vec l ((n + m) + 1)
Relevant bindings include
l :: Vec l m
as :: Vec l n1
vecAppend :: Vec l (n + 1) -> Vec l m -> Vec l ((n + 1) + m)
> vecAppend ∷ ∀ e n m. Vec e (n+1) → Vec e m → Vec e (n + 1 + m)
> vecAppend VNil l = l
> vecAppend ((a :- (as ∷ Vec e n)) ∷ Vec e (n+1)) (l ∷ Vec e m) = a :- (vecAppend as l ∷ Vec e (n+m))
Could not deduce (n1 ~ n)
from the context ((n + 1) ~ (n1 + 1))
bound by a pattern with constructor
:- :: forall e (n :: Nat). e -> Vec e n -> Vec e (n + 1),
in an equation for ‘vecAppend’
‘n1’ is a rigid type variable bound by
a pattern with constructor
:- :: forall e (n :: Nat). e -> Vec e n -> Vec e (n + 1),
in an equation for ‘vecAppend’
‘n’ is a rigid type variable bound by
the type signature for
vecAppend :: Vec e (n + 1) -> Vec e m -> Vec e ((n + 1) + m)
Expected type: Vec e n1
Actual type: Vec e n
Relevant bindings include
vecAppend :: Vec e (n + 1) -> Vec e m -> Vec e ((n + 1) + m)
In the pattern: as :: Vec e n
In the pattern: a :- (as :: Vec e n)
In the pattern: (a :- (as :: Vec e n)) :: Vec e (n + 1)
3
的样子至
Succ (Succ (Succ Zero)))
在我的类型签名中。
最佳答案
当然有办法。这不是一个好方法,但有一个方法.. 放置 unsafeCoerce
的全部目的在这种语言中,您知道某些内容输入正确,但 GHC 无法自行判断。所以..有办法。
这个故事应该在 GHC 7.10 中得到显着改善。目前的计划是包括一个 SMT 求解器,用于处理类型级 Nat 值。
编辑:
哦。至于为什么使用 Peano naturals 很容易,而使用类型级文字却很难:使用 Peano naturals,添加一个就是应用类型构造函数。 GHC 知道应用类型构造函数是一个单射操作。事实上,它是 GHC 类型系统的关键点之一。因此,当您使用 Peano naturals 时,您仅使用 GHC 已经非常适合处理的结构。
相比之下,GHC 对算术一无所知。它不知道 (+1)
是 Nat
上的单射函数.所以它无法知道它可以导出m ~ n
来自 (m + 1) ~ (n + 1)
.它也没有关于 Nat
上的算术基本属性的想法。 ,例如关联性、分配性和交换性。集成 SMT 求解器背后的想法是,SMT 求解器非常擅长处理这些属性。
不过,使用 GHC 7.8,您可以轻松地将类型级文字转换为 Peano naturals:
{-# LANGUAGE DataKinds, TypeFamilies, TypeOperators, UndecidableInstances #-}
import GHC.TypeLits
data Z
data S a
type family P (n :: Nat) where
P 0 = Z
P n = S (P (n - 1))
P
用于从文字转换为 Peano 表示,如下所示:
*Main> :t undefined :: P 5
undefined :: P 5 :: S (S (S (S (S Z))))
关于haskell - 使用 TypeLits 追加类型级编号列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24734704/
我在 MS Dynamics CRM 中工作,我有一个包含我所有 TypeScript 的 WebResources 项目。我有插件 .net 库 dll,其中包含一些 POCO 对象,这些对象将通过
目前我所有的 TypeScript 类型都位于 Scripts/typings/Library 下。默认情况下,TypeLite 位于“脚本”下方。有没有办法指定输出目录,使其位于自定义库名称下?即S
我刚刚通过 NuGet 将 TypeLite 安装到我的项目中,但它不起作用,并且我尝试过的所有方法都没有帮助...这是安装后创建的文件: 这是我得到的错误: Seve
名称可以更改,如教程中所示: TypeScript.Definitions() .ForLoadedAssemblies() .WithFormatter((type, f) => "
当我的类在我的 Default.aspx.cs 文件中定义时,有人能告诉我我的 Scripts\TypeLite.tt 文件中究竟应该有什么吗? namespace typelite { pu
我将 TypeLITE 用于各种项目和一个简单的网站。我想使用 TypeLITE 从我的 C# 类生成 TypeScript 定义,但我不允许将 TypeLITE dll 添加到每个项目。 让这成为我
Typelite 是否可以生成 TypeScript 类而不是接口(interface)?像这样的东西: public class Person { public string FirstNa
我正试图围绕 GHC 扩展 KindSignatures和 DataKinds .看着Data.Modular包,我大致了解 newtype i `Mod` (n :: Nat) = Mod i de
使用 GHC.TypeLits ,我们可以写一个简单的类型级编号列表(或向量)。 > {-# LANGUAGE TypeOperators, KindSignatures, GADTs, DataKi
使用GHC.TypeLits中的Sing有任何开销吗? ?以程序为例: {-# LANGUAGE DataKinds #-} module Test (test) where import GHC.T
尝试设计一个类型驱动的 API,我一直在尝试使类似以下工作的东西(使用更复杂的代码/尝试,这被简化为阐明我正在寻找的内容所需的最低限度): {-# LANGUAGE DataKinds #-} {-#
我目前正在使用 TypeScript 中的 AngularJS 1.x 和 C# 中的 AspNet WebApi 后端构建客户端。 为了与后端通信,我使用了来自 Angular 的 $resourc
假设我有一些 C# DTO,我想使用 T4 模板和名为 TypeLite 的简洁小库将它们转换为 TypeScript 接口(interface) 在客户端,我有一些具体的 TypeScript 类(
所以我有很多 .Net 库/类,我想为其生成 typescript 定义。 typescript 很棒!我用简单的例子试了一下,它确实工作得很好。我面临的唯一问题是我拥有的组合不适用于它。这是它不起作
考虑 zip 的这个定义对于由 Peano 数字索引的通常向量长度: {-# language DataKinds #-} {-# language KindSignatures
我在玩 GHC.TypeLits 时遇到了问题.考虑以下 GADT: data Foo :: Nat -> * where SmallFoo :: (n Foo n BigFoo ::
刚刚安装了当前的 Haskell 平台 2012.2.0.0, which says it uses base-4.5.0.0 , 和 base-4.5.0.0 includes the GHC.Ty
我尝试使用 TypeLite 从现有的 POCO 类生成 TypeScript 数据对象类。导入 TypeLite NuGet 包时,我在 VS 2015 IDE 中收到一些错误消息,显然 NuGet
到目前为止,我假设 GHC 在编译时执行类型级函数(类型系列)。因此,应该在编译时发出由 TypeError 类型族触发的错误消息。 在下面的示例中,我在运行时遇到了类型错误。 {-# LANGUAG
使用 Peano 风格的类型级自然函数,编写绝对差异类型级函数(又名类型族)相当容易: {-# LANGUAGE DataKinds, StandaloneKindSignatures, TypeFa
我是一名优秀的程序员,十分优秀!