4.(这一部分涉及Workbench,故不译)
5. 记住将来要用到的数据
这一点对于任何语言都是有益的,在Mathematica的体系中你应该记住下面的结构:
这会记住任何f在特定参数下的返回值,所以被重复调用是不用再次计算.这是用内存交换时间的做法,所以如果计算量非常大的话这种做法是不合适的.但是对于小规模的程序,这是非常有用的.让我们用这个方法来拯救我在第三点举的那个蛋疼程序:把第一条规则修改一下:
现在,求解fib[35]只需要计算主规则33次,所以速度快得令人难以置信.要点是:调用以前的结果避免了重复的递归.
6.并行计算
越来越多的Mathematica操作(线性代数,图像处理,统计分析)会自动地进行并行计算,Compile也能通过人工设定并行处理.对于其他类型的操作和远程并行,你可以使用内置的并行编程架构.
有一系列的工具可用于并行操作,但是对于独立的任务,仅仅使用ParallelTable,ParallelMap和ParallelTry就可以达到很好的效果.它们中的每一个都能自动调度计算过程中的通信,任务管理,和结果收集工作.这些调度工作会消耗一点时间,但这是值得的.
你的Mathematica拥有4个计算核心,如果你有更多的CPU资源,还可以借助girdMathematica扩展并行能力.下面的例子中ParallelTable就让我获得了双倍的性能,因为我的机器是双核的.更多的核可以带来更佳的性能.
在Mathematica中,万事皆能并行.你可以发送并行任务到远程硬件上以C代码形式或者在GPU上运行.
7.用Sow和Reap累积大规模数据.
Mathematica 的数据结构很灵活,所以AppendTo不会假定你要追加的数而不是文件,声音或图像.这样导致的结果是,AppendTo每次都会把原数据复制下来,调整结构以容纳新追加的数据.随着数据量的增加运行会越来越慢.(Append的效果也是类似的).
我们使用Sow和Reap. Sow抛出你要累积的值,Reap收集它们并在最后生成数据.下面的两段代码是等价的,后者速度却快了很多.