我目前正在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 uitools\private\warnfiguredialog 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
我真的不知道我做错了什么。有人能帮帮我吗?
答案 0 :(得分:1)
我认为你做'错'的事情就是在parfor循环中使用等待吧哈哈。但严重的是,我担心这是因为迭代不会在parfor循环中按顺序执行,因此禁止使用常规等待条,因为Matlab客户端和执行循环的工作人员之间共享信息的方式。即使你没有写matlabpool('open',4)
,MATLAB也会打开它,所以问题实际上是等待栏处于parfor循环的事实。
作为一种解决方法,您可能希望查看文件交换的this提交。它是由在Mathworks工作的Edric Ellis编写的,所以我相信他的程序:)
希望有所帮助!