7

我熟悉matlabpool, 和parfor用法,但我仍然需要加快计算速度。

我的 1GB 网络中有一台功能更强大的计算机。两台计算机都有 R2010b,并且具有相同的代码和路径。

使用两台计算机进行并行计算的最简单方法是什么?

我今天使用的代码示例:

--- main.m---

matlabpool('open', 3);
% ...
x = randn(1e5,1);
y = nan(size(x));
parfor k = 1 : length(x)
    y(k) = myfunc(x(k));
end

--- myfunc.m---

function y = myfunc(x)
    y = x; % some computation
return
4

1 回答 1

4

对于真正的集群计算,您需要分布式计算工具箱,您可以在并行计算信息页面上阅读:

在不更改代码的情况下,您可以在计算机集群或网格计算服务上运行相同的应用程序(使用 MATLAB Distributed Computing Server™)。您可以交互或批量运行并行应用程序。

但是安装(=购买)一个工具箱只是为了将一台计算机添加到工作池中可能有点太贵了。幸运的是还有其他选择:http: //www.mathworks.com/matlabcentral/fileexchange/13775

我个人没有使用过这个,但认为它绝对值得一看。

于 2012-07-30T17:19:19.390 回答