1

我想读取大量文件,处理每个文件并将每个文件的结果保存在一个.mat文件中。每个文件的处理都是独立于其他文件的,所以我想尝试使用parfor. 我编写了以下 Matlab 脚本文件:

load filelist
obj = package.name.SomeObject();
matlabpool local 5
parfor i=1:length(filelist)
    result = obj.compute(filelist{i});
    [~, name, ~] = fileparts(filelist{i});
    save(['~/path/' name], 'result');
end % file loop
matlabpool close

当我尝试在我的计算机上运行它时,Matlab 池被初始化(connected to 5 workers),但随后出现以下错误消息:

Error using parallel_function (line 589)
Undefined function or variable "cleaner".

Error in readfiles (line 14)
parfor i=1:length(filelist)

Error in run (line 64)
evalin('caller', [script ';']);

你知道问题可能出在哪里吗?

4

1 回答 1

1

我不知道为什么(可能与此问题有关),但是通过将代码包含在函数中并调用该函数(而不是通过调用脚本文件run script.m)来解决问题。它还需要创建一个parsave函数(请参阅此处的说明)。

于 2013-06-06T08:29:28.060 回答