- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的程序(Hartree-Fock/iterative SCF)有两个矩阵 F 和 F',它们实际上是用两种不同基数表示的相同矩阵。我刚刚损失了三个小时的调试时间,因为我不小心使用了 F' 而不是 F。在 C++ 中,类型检查器不会捕获此类错误,因为两个变量都是 Eigen::Matrix<double, 2, 2>
对象。
我想知道,对于 Haskell/ML/等等。大家,如果您正在编写这个程序,您是否会构建一个类型系统,其中 F 和 F' 具有不同的类型?那会是什么样子?我基本上是想了解如何将一些逻辑错误外包给类型检查器。
编辑:矩阵的基础就像单位。你可以说 1L,也可以说多少加仑,它们的意思是一样的。或者,举一个向量示例,您可以在笛卡尔坐标中说 (0,1) 或在极坐标中说 (1,pi/2)。但即使含义相同,数值却不同。
编辑:也许单位是错误的类比。我不是在寻找某种记录类型,我可以在其中指定第一个字段为升,第二个字段为加仑,而是寻找一种方式来表示这个矩阵作为一个整体,是根据其他一些矩阵定义的(基),其中基可以是任何相同维度的矩阵。例如,构造函数看起来像 mkMatrix [[1, 2], [3, 4]] [[5, 6], [7, 8]]
然后将该对象添加到另一个矩阵中,仅当两个对象的第二个参数具有相同的矩阵时才会进行类型检查。这有道理吗?
编辑:Wikipedia 上的定义, worked examples
最佳答案
这在 Haskell 中是完全可能的。
静态检查尺寸
Haskell 的数组带有 statically checked dimensions ,可以静态地操作和检查维度,防止索引到错误的维度。一些例子:
这只有效on 2-D arrays :
multiplyMM :: Array DIM2 Double -> Array DIM2 Double -> Array DIM2 Double
来自 repa
的示例应该能让您有所了解。这里,取对角线需要一个二维数组,返回一个相同类型的一维数组。
diagonal :: Array DIM2 e -> Array DIM1 e
或者,来自Matt sottile's repa tutorial ,3D 矩阵变换上的静态检查尺寸:
f :: Array DIM3 Double -> Array DIM2 Double
f u =
let slabX = (Z:.All:.All:.(0::Int))
slabY = (Z:.All:.All:.(1::Int))
u' = (slice u slabX) * (slice u slabX) +
(slice u slabY) * (slice u slabY)
in
R.map sqrt u'
静态检查单位
矩阵编程之外的另一个示例:静态检查 units of dimension ,使其成为令人困惑的类型错误,例如英尺和米,无需进行转换。
Prelude> 3 *~ foot + 1 *~ metre
1.9144 m
例如无法添加不同尺寸的东西,例如体积和长度:
> 1 *~ centi litre + 2 *~ inch
Error:
Expected type: Unit DVolume a1
Actual type: Unit DLength a0
所以,关注the repa
-style array dimension types ,我建议向您的数组类型添加一个 Base
幻像类型参数,并使用它来区分基数。在 Haskell 中,索引 Dim
类型参数给出了数组的等级(即它的形状),你也可以做类似的事情。
或者,如果基数是指单位上的某个维度,则使用维度类型。
所以,是的,这现在几乎是 Haskell 中的一种商品技术,并且有一些使用此类类型进行设计的示例来帮助您入门。
关于haskell - 好的类型系统可以区分不同基数的矩阵吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5850392/
正如标题所说,我需要制作一个函数,在二进制补码中的 2 个碱基、DEC 和 HEX 之间进行转换。该值使用的位数从一开始就已知。 在深入研究之后,我发现了以下算法: 给定一个 DEC 中的数字。 获取
我的用户文档具有以下格式: { userId: "", userAttributes: [ "", "", ... ""
根据这个: Selectivity is the value between 0 and 1, and it is the fraction of rows returned after applyi
这个词有它 FillChar 是用相同值的字节填充内存补丁的最快方法(不是零,因为有 ZeroMemory),但是是否有等效于用相同的序列填充内存(四字节)整数或基数?像 FillInt 或 Fill
我正在努力寻找建模 1 : 0,1 关系的最佳方法(“可能有一个”或“最多有一个”)。我相信这被称为 Z 基数。 例如,假设我有两个类 Widget和 WidgetTest .并非所有 Widget
我使用parseInt找到了一个片段;它用于获取窗口高度。 这是代码: parseInt($(window).height(), 20); 我很困惑为什么使用 20 作为第二个参数。为什么不是 10
要将十进制数转换为基数 2,我使用: int base2 = 10; Convert.ToString(base2, 2); 输出:1010 但是我怎么能做相反的事情呢?即: 输入:1010输出:10
这是一张真实 table 的再现。假设我有这段代码: CREATE TABLE `testTable` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
由于十六进制(基数 16)使用 0-9A-F,并且(我在这里假设)基数 17 使用 0-9A-G,依此类推。什么符号用过一次0-9A-Z都用完了。 最佳答案 你的问题没有标准答案。 “Base 36”
我正在寻找支持 radix 的浏览器列表Number.toString() 中的参数在 JavaScript 中。全部执行toString ,但我找不到他们是否都支持 radix toString 的
这个问题已经有答案了: What is the radix parameter in Java, and how does it work? (6 个回答) 已关闭 5 年前。 public clas
为什么 (73).toString(36) 返回 21 而 (0.73).toString(36) 返回 0。 qa2voha2volfpsnhmyhqia4i 而不是 0.21? 最佳答案 这是因为
我目前正在研究数据库,我看到 degree 和 cardinality 用作相同的术语,或在某些其他学位定义为否。关系中涉及的实体的数量,并进一步分类为一元、二元和三元。 某些放置度数定义为关系类型的
UML(统一建模语言)中的运算符*和运算符0..*有什么区别? 我看到了这两个基数运算符,但是现在我不必使用哪个基数运算符了。 最佳答案 符号“*”是“0 .. *”的快捷方式。在这种情况下使用的正确
我有位于目录“someApp”中的 Angular 应用程序。网址是 http://example-domain/someApp/#/对于一些带有路径的状态 url 是:http://example-
我想一劳永逸地知道如何编写 UML 基数,因为我经常不得不讨论它们(因此非常欢迎证据和来源:) 如果我想解释一下 Mother可以有几个Child任但是 Child有一个而且只有一个 Mother ,
进行字符算术时,规则是以 10 为基数还是以 8 为基数进行计算?我的书上说'A' = 101(基数为8)或65(基数为10),但是当我将基数为8的字符值插入到我的书给出的关于说明这一点的示例中时,我
该程序是将 4 进制数转换为 2 进制数,并且应该就地完成 #include #include void shiftr(char num[],int i) { memmove(num+i,n
这个问题已经有答案了: JavaScript parseInt is giving me wrong number, what I'm doing wrong? [duplicate] (1 个回答)
我遇到了一个小错误,它似乎表明当您传入图像数据作为其源时,在图像完全加载之前调用了 onload 函数。 这是 HTML 这是 JavaScript: var can
我是一名优秀的程序员,十分优秀!