我目前正在Matlab工作,这是我第一次尝试并行处理。我的代码工作得很好,直到我在代码顶部添加matlabpool('open',4);
,在底部添加matlabpool('close');
。
如果我添加这两行,我所有的 CPU 内核都处于 100% 的工作负载(就像预期的那样),并且我的代码仍然可以在我在 parfor-loop 中实现的等待栏之外工作。
代码看起来像这样:
matlabpool('open',4);
global bar;
bar = waitbar(0, 'Waitbar');
parfor i=1:1000
//working code
try
waitbar(UPDATED_VALUE, bar, UPDATED_STRING);
end
end
try
close(bar);
end
//display results
matlabpool('close');
我得到的错误如下:
Warning: This functionality is no longer supported under the -nodisplay and -noFigureWindows startup options. For more information, see "Changes to -nodisplay and -noFigureWindows Startup Options" in the MATLAB Release Notes. To view the release note in your system browser, run web('http://www.mathworks.com/access/helpdesk/help/techdoc/rn/br5ktrh-1.html#br5ktrh-3', '-browser')
In uitoolsprivatewarnfiguredialog at 26
In waitbar at 38
In montecarlo>(parfor body) at 41
In parallel_function>make_general_channel/channel_general at 891
In remoteParallelFunction at 28
我真的不知道我做错了什么。有人可以帮我吗?
我认为你做错了"的事情是在 parfor 循环中使用了等待栏哈哈。但说真的,我担心这是因为迭代不是在 parfor 循环中按顺序执行的,因此禁止使用常规的等待栏,因为 Matlab 客户端和执行循环的工作人员之间共享信息的方式。即使您没有编写matlabpool('open',4)
MATLAB也会打开它,因此问题实际上是等待栏处于parfor循环中的事实。
作为解决方法,您可能需要查看此提交表单文件交换。它是由在The Mathworks工作的Edric Ellis编写的,所以我会相信他的程序:)
希望对您有所帮助!