我现在已经运行了大约一年半的MATLAB。而且我一直试图让 matlabpool 准备好几乎每三个月一次。在我完全放弃之前,我决定寻求帮助。 :)
我的问题始于 matlabpool 命令。每当我输入 matlabpool 命令时,我都会得到:
One or more output arguments not assigned during call to "system_dependent".
Error in matlabpool>iIsOnClient (line 73)
onclient = ~system_dependent('isdmlworker');
Error in matlabpool>iVerifyJava (line 64)
if iIsOnClient()
Error in matlabpool (line 10)
iVerifyJava();
经过一些研究和不眠之夜,我发现必须使用" Cluster Profile Manager" 解决问题。但我从来没有机会看到它的运作。以下是从并行面板中单击 Cluster Profile Manager 后得到的结果:
com.mathworks.jmi.MatlabException: Feature isdmlworker not found
at com.mathworks.jmi.NativeMatlab.SendMatlabMessage(Native Method)
at com.mathworks.jmi.NativeMatlab.sendMatlabMessage(NativeMatlab.java:266)
at com.mathworks.jmi.MatlabLooper.sendMatlabMessage(MatlabLooper.java:120)
at com.mathworks.jmi.Matlab.mtFeval(Matlab.java:1710)
at com.mathworks.jmi.MatlabWorker.feval(MatlabWorker.java:197)
at com.mathworks.toolbox.distcomp.ui.profile.model.MatlabProfileManager$1.runOnMatlabThread(MatlabProfileManager.java:80)
at com.mathworks.jmi.MatlabWorker$2.run(MatlabWorker.java:79)
at com.mathworks.jmi.NativeMatlab.dispatchMTRequests(NativeMatlab.java:475)
Attempt to reference field of non-structure array.
Error in parallel.internal.ui.AbstractValidationManager (line 20)
obj.Validator.addlistener('ValidationStarted', ...
Error in parallel.internal.ui.ValidationManager (line 21)
obj@parallel.internal.ui.AbstractValidationManager();
com.mathworks.jmi.MatlabException: Attempt to reference field of non-structure array.
at com.mathworks.jmi.NativeMatlab.SendMatlabMessage(Native Method)
at com.mathworks.jmi.NativeMatlab.sendMatlabMessage(NativeMatlab.java:266)
at com.mathworks.jmi.MatlabLooper.sendMatlabMessage(MatlabLooper.java:120)
at com.mathworks.jmi.Matlab.mtFevalConsoleOutput(Matlab.java:1778)
at com.mathworks.jmi.MatlabWorker.feval(MatlabWorker.java:195)
at com.mathworks.jmi.MatlabWorker.feval(MatlabWorker.java:172)
at com.mathworks.toolbox.distcomp.ui.profile.model.ValidationManager$1.runOnMatlabThread(ValidationManager.java:45)
at com.mathworks.jmi.MatlabWorker$2.run(MatlabWorker.java:79)
at com.mathworks.jmi.NativeMatlab.dispatchMTRequests(NativeMatlab.java:475)
收到此消息后,会弹出群集配置文件管理器,但除了"等待"之外不会显示任何内容。标志。我已经检查了我的分布式计算许可证,这看起来也很好。
license checkout Distrib_Computing_Toolbox
命令返回1.
顺便说一下,还有另一条错误消息,我怀疑它与我的某种问题有关。我在每个MATLAB的开始都得到了这个:
Error using feature
Feature isdmlworker not found
Error in matlabrc (line 187)
if ~(ismcc || isdeployed || feature('isdmlworker')) && usejava('jvm')
除了所有这些之外;每当我尝试打开"并行首选项"来自环境标签:
com.mathworks.jmi.MatlabException: Feature isdmlworker not found
at com.mathworks.jmi.NativeMatlab.SendMatlabMessage(Native Method)
at com.mathworks.jmi.NativeMatlab.sendMatlabMessage(NativeMatlab.java:265)
at com.mathworks.jmi.MatlabLooper.sendMatlabMessage(MatlabLooper.java:120)
at com.mathworks.jmi.Matlab.mtFeval(Matlab.java:1619)
at com.mathworks.jmi.MatlabWorker.feval(MatlabWorker.java:197)
at com.mathworks.toolbox.distcomp.ui.profile.model.MatlabProfileManager$1.runOnMatlabThread(MatlabProfileManager.java:72)
at com.mathworks.jmi.MatlabWorker$2.run(MatlabWorker.java:79)
at com.mathworks.jmi.NativeMatlab.dispatchMTRequests(NativeMatlab.java:440)
我试图找到函数 system_dependent.m 但它似乎并不存在。我得到的其他常见错误,功能" feature.m" ,选项" isdmlworker" 是其他谜团我无法找到任何关于的信息。
如果有人能帮我解决我在启动MATLAB的分布式计算系统时遇到的问题,我真的很感激。
编辑:我正在使用Ubuntu 14.04而我的MATLAB版本是R2014a。
答案 0 :(得分:2)
这似乎是您特定安装Ubuntu 14.04的问题。虽然它可能与matlabpool
在R2014a中产生工作线程的方式有关,因为com.mathworks.jmi.NativeMatlab.dispatchMTRequests()
发生了错误。
matlabpool
已经过测试,在Ubuntu 15.04和15.10上没有问题。它可能不是一个理想的解决方案,但将Ubuntu升级到15.04或15.10并重新安装MATLAB R2014a应该可以解决这个问题。