使用matlabpool时更新Waitbar会引发错误

时间:2014-11-18 14:19:52

标签: matlab parallel-processing parfor matlabpool

我目前正在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 

我真的不知道我做错了什么。有人能帮帮我吗?

1 个答案:

答案 0 :(得分:1)

我认为你做'错'的事情就是在parfor循环中使用等待吧哈哈。但严重的是,我担心这是因为迭代不会在parfor循环中按顺序执行,因此禁止使用常规等待条,因为Matlab客户端和执行循环的工作人员之间共享信息的方式。即使你没有写matlabpool('open',4),MATLAB也会打开它,所以问题实际上是等待栏处于parfor循环的事实。

作为一种解决方法,您可能希望查看文件交换的this提交。它是由在Mathworks工作的Edric Ellis编写的,所以我相信他的程序:)

希望有所帮助!