内容简介:翻译自:https://stackoverflow.com/questions/12831187/haskell-optimizing-differential-equation-solver
我正在学习Haskell,并且我正在尝试尽可能快地编写代码.在本练习中,我正在为一个简单的一维物理系统编写一个 Euler integrator
.
> C代码使用GCC 4.5.4和-O3编译.它运行在1.166秒.
> Haskell代码使用GHC 7.4.1和-O3编译.它运行21.3秒.
>如果我使用-O3 -fllvm编译Haskell,它将在4.022秒内运行.
那么,我是否遗漏了一些优化我的Haskell代码的东西?
PS.:我使用了以下参数:1e-8 5.
C代码:
#include <stdio.h> double p, v, a, t; double func(double t) { return t * t; } void euler(double dt) { double nt = t + dt; double na = func(nt); double nv = v + na * dt; double np = p + nv * dt; p = np; v = nv; a = na; t = nt; } int main(int argc, char ** argv) { double dt, limit; sscanf(argv[1], "%lf", &dt); sscanf(argv[2], "%lf", &limit); p = 0.0; v = 0.0; a = 0.0; t = 0.0; while(t < limit) euler(dt); printf("%f %f %f %f\n", p, v, a, t); return 0; }
Haskell代码:
import System.Environment (getArgs) data EulerState = EulerState !Double !Double !Double !Double deriving(Show) type EulerFunction = Double -> Double main = do [dt, l] <- fmap (map read) getArgs print $runEuler (EulerState 0 0 0 0) (**2) dt l runEuler :: EulerState -> EulerFunction -> Double -> Double -> EulerState runEuler s@(EulerState _ _ _ t) f dt limit = let s' = euler s f dt in case t `compare` limit of LT -> s' `seq` runEuler s' f dt limit _ -> s' euler :: EulerState -> EulerFunction -> Double -> EulerState euler (EulerState p v a t) f dt = (EulerState p' v' a' t') where t' = t + dt a' = f t' v' = v + a'*dt p' = p + v'*dt
通过将 worker-wrapper transformation
应用于runEuler,我得到了很好的提升.
runEuler :: EulerState -> EulerFunction -> Double -> Double -> EulerState runEuler s f dt limit = go s where go s@(EulerState _ _ _ t) = if t < limit then go (euler s f dt) else s
这有助于f内联到循环中(这可能也发生在C版本中),摆脱了大量的开销.
翻译自:https://stackoverflow.com/questions/12831187/haskell-optimizing-differential-equation-solver
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- NiLang:可逆计算,微分万物
- 动态规划求解最长公共子序列
- 机器学习系统SyeML笔记三——自动微分
- 最大子序列的求解-算法之一分析
- 八皇后问题分析和 golang 求解
- 漫画:一文看懂螺旋矩阵求解
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
迎接互联网的明天
邹静 / 电子工业 / 2011-6 / 55.00元
《迎接互联网的明天-玩转3D Web(附盘)》,全书共5章,第1章主要阐述了国内外空前繁荣的3D互联网技术领域,以及这些领域透射出来的潜在商机;第2章主要用当下比较流行的Flash编程语言ActionScript 3,来向大家介绍面向对象编程语言的思想概念,以及一些3D渲染技术的入门知识;第3章注重建模知识的运用,主要运用WireFusion和3ds Max来制作3D网页;第4章主要介绍3D游戏编......一起来看看 《迎接互联网的明天》 这本书的介绍吧!