- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想写这个操作
Matrix.Multiply(source,target)
target.Add(offsets)
以这种数学风格
target = Matrix * source + offsets;
但是,我也很关心性能。 (实际上,上述操作将在紧密循环中运行。)我不想为每个矩阵向量乘法创建一个新向量,并为向量加法创建另一个新向量。
如何在 C# 或 F#(或您知道的任何函数式语言)中实现上述操作,以便兼顾风格和性能?
很抱歉这个幼稚的问题。我确信这种愿望是如此根本。
最佳答案
一种众所周知的技术,例如 Repa 的核心高性能数值数组库,是在基本的“二维整数数组”结构之上定义一个更高级别的数据结构,延迟您要执行的操作,以及一个解释/归一化函数,最终将执行这些操作,应用它认为有利可图的任何优化。
具体来说,在您的示例中,我认为大多数当前答案都忽略了这一点,您希望将 A * B + C
重写为
add(multiply(A,B), C)
或面向对象风格电子
A.multiply(B).add(C)
而是
multiply_and_add(A,B,C)
其中 multiply_and_add
是一个特殊的、较低级别的操作,它同时执行这两个操作并且更加优化。类似地,众所周知,对于任意矩阵 A、B、C、D
,乘积 A * B * C * D
可以更有效地计算为 A * ((B * C) * D)
而不是 A * (B * (C * D)))
,具体取决于操作数维度。因此,纯本地方法(在整数数组上表达每个操作)不起作用,您需要表达式全局重写以获得最佳效率——就像 C++ 中的 hackish 模板库所做的那样。
解决方案是从int array array
移动到精化数据类型,例如:
type matrix =
| Raw of int array array
| Add of matrix * matrix
| Mult of matrix * matrix
然后提供一个 eval : matrix -> int array array
函数,通过可能应用特定领域的优化来“解释”那些矩阵描述(本质上是矩阵运算的抽象语法树)。举个简单的例子:
let rec eval = function
| Raw m -> m
| Add(Mult(a,b), c) | Add(c, Mult(a,b)) ->
multiply_and_add (eval a) (eval b) (eval c)
| Add (a, b) -> add (eval a) (eval b)
| Mult (a, b) -> mult (eval a) (eval b)
然后您可以定义您喜欢的语法糖,使 matrix
构造函数更易于阅读。
module Matrix = struct
let (!) m = Raw m
let (+) a b = Add (a, b)
let (*) a b = Mult (a, b)
end
let ... = eval Matrix.(!A * !B + !C)
关于c# - 如何在保持其语法的同时使此函数式代码的性能更高,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20363978/
我有一个 DIV #page,如果我在顶部添加边距,突然出现一个滚动条,即使该元素不大于主体。我怎样才能去掉滚动条? (参见 Fiddle) 我的 HTML I am a div siz
function getClosestValue(standardArray, targetVal) { standardArray = standardArray.sort(function(a,
我有 318x424 的书籍封面图片,我想做的是指定一张图片,并在其下方添加一个文本链接。初始 src 是 about:blank,这样如果响应式设计不显示框架,它就不会占用用户带宽。 框架的 HTM
我被这个问题困了两天了,还是没搞定。 基本上,我有一个二维数组,其中包含某些数字(在给定范围内)之间的关系: 0 = 顺序无关紧要 1 = 第一个数字(左栏中的数字)应该是第一个 2 = 第二个数字(
只有当我在更高的 API 上进行调试时,我才会强制关闭脚本:16,但是当涉及到 API 时它工作正常:10。这可能是我的项目设置问题吗? 这是对服务器的简单请求,以获取 fragment 中的类别列表
给定下表books id | listorder ----+----------- 3 | 1 2 | 2 1 | 3 4 |
我想要那个密码切换功能,好像TextInputLayout有这个功能,而不是 TextInputEditText .但是正如您在下面的代码中看到的,即使我将高度设置为 wrap_content和 ap
似乎从 读取给出空列表,它主要发生在延迟较高的网络上的主机上。是否有更强大的与远程主机交互的方式? use Net::SSH2; # my $ssh = Net::SSH2->new(); # ..
为了在 Play 商店中发布我的应用程序,我必须将 TargetSdkVersion 从 23 更改为 26。在我更改它之前,该应用程序运行良好!现在应用程序在启动时崩溃。我想通了,问题出在这两行:
我尝试了很多解决方案,但找不到一个。我有 3 个不同的列,其中包含不同类型的文本,我需要它们具有相同的高度。但它们是这样不同的:colums有人可以帮忙吗? 代码: .col-sm-2{
我尝试将一个 div 相对于其具有负顶值的父级定位。这工作正常,现在的问题是这个 div,即使它有一个负的 top 值也会使父 div 更大。 我该怎么做才能让父 div 不那么大? Here's a
这是一个一般性问题,可能适用于任何给定的语言,如 C、C++、Java 等。 我认为无论以何种方式实现它,都不会比使用 2 个循环更高效,后者的效率为 n^2。 for(i=0;i O(1) ),要么
我需要查找所有有订单的家庭。我根本不关心订单的数据,只关心它的存在。 (使用 SQL Server) 这样说是不是更有效率: SELECT HouseholdID, LastName, FirstNa
我有一个 UINavigationController,在屏幕顶部有一个 UINavigationBar,在底部有一个 UIToolbar。我想让工具栏高一点。这是我的代码: CGRect toolb
我正在使用自定义字体。该字体在我的 Windows PC 上完美运行,但在我的 Mac (Yosemite OSX) 上运行不佳。正如您在图片中看到的,Mac 上的字体比 Windows 上的字体稍大
我正在尝试使用 FaSTLane 将我的应用程序作为 alpha 版本部署到 Play 商店,但出现此错误: Google Api 错误:multiApkShadowedActiveApk:任何设备都
我在这里找不到神奇的调味料。看起来 API 不支持它,所以我想我正在寻找一些 CSS 来使 slider 更大。 我得到的是左边的,但我想把它设计成右边的样子?任何 CSS 技巧或以前有人这样做过。
如果我运行这段代码: float a=1.123456789; printf("The float value is %f\n",a); double b=1.123456789876543 prin
我正在尝试使用 strip binary 来剥离我的目标文件。我在 gcc-7 上构建了最新的 binutils,但我的代码库使用 gcc-4.9.2。Binutils 是为 64 位架构构建的,我的
有没有办法让 iPhone 应用的“内容”区域感知到更大的导航栏? 类似这些问题: iOS: Adding a fixed image just below the navigation bar iO
我是一名优秀的程序员,十分优秀!