[英]determining matlab parallel pool size in a batch job on a cluster
我想验证集群是否配置正确,并且我想通过下面的命令将运行以下脚本,并将poolsize输出到文本文件中,以及将屏幕输出定向到的位置(通过批处理管理环境)。 相反,我只看到最后的输出,错误文件中也没有任何内容。 我该如何完成?
命令:
matlab -nosplash -nodesktop < test.m
脚本:
clear;
delete(gcp);
parpool;
poolsize = poolobj.NumWorkers
save poolsize.txt poolsize -ascii
exit();
poolobj = gcp('nocreate'); % If no pool, do not create new one.
if isempty(poolobj)
poolsize = 0;
else
poolsize = poolobj.NumWorkers
end
save poolsizefile poolsize;
poolsize
exit();
(后半部分从未使用过,因此我什至停止尝试,因此退出了第一个出口。)
输出:
>> >> Starting parallel pool (parpool) using the 'local' profile ... Warning: Found 1 pre-existing communicating job(s) created by pool that are
running, and 3 communicating job(s) that are pending or queued. You can use
'delete(myCluster.Jobs)' to remove all jobs created with profile local. To
create 'myCluster' use 'myCluster = parcluster('local')'.
首先,我建议对MATLAB使用-r
选项来运行脚本,因为在进行输入时,有时会出现一些奇怪的现象,例如
matlab -nodisplay -r test
然后,我将第2行更改为state
delete(gcp('nocreate'))
以确保您不会创建仅用于删除池的池。 然后,下一位
poolobj = parpool;
poolsize = poolobj.NumWorkers;
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.