Не могу начать игру

Я работаю с 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 на панели Parallel:

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)

После получения этого сообщения появляется Cluster Profile Manager, но на самом деле ничего не показывает, кроме знака "ждать". Я проверил свою лицензию на распределенные вычисления, и это тоже выглядит нормально.

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.

1 ответ

Решение

Похоже, это проблема вашей конкретной установки Ubuntu 14.04. Возможно, это связано с тем, как matlabpool порождает рабочие потоки в R2014a, учитывая, что ошибка возникает в com.mathworks.jmi.NativeMatlab.dispatchMTRequests(),

matlabpool был протестирован для работы без проблем на Ubuntu 15.04 и 15.10. Возможно, это не идеальное решение, но обновление Ubuntu до 15.04 или 15.10 и переустановка MATLAB R2014a должны решить эту проблему.

Другие вопросы по тегам