Генерация кода является преобразованием MATLAB® код для Кода С с использованием MATLAB Coder™. Для генерации кода требуется лицензия MATLAB Coder.
Как правило, генерация кода используется для развертывания кода на оборудовании, которое не работает под управлением MATLAB. Например, можно развернуть код на роботе, используя lsqnonlin
для оптимизации движения или планирования.
Для получения примера смотрите Сгенерировать Код для lsqcurvefit или lsqnonlin. Для генерации кода в других решателях оптимизации смотрите Сгенерируйте код для fmincon, Сгенерируйте код для quadprog, Сгенерируйте код для lsqlin или Сгенерируйте код для fsolve.
lsqcurvefit
и lsqnonlin
поддерживает генерацию кода, используя либо codegen
(MATLAB Coder) или приложение MATLAB Coder. Для генерации кода необходимо иметь лицензию MATLAB Coder.
Целевой компьютер должно поддерживать стандартные расчеты с плавающей точностью. Вы не можете сгенерировать код для расчетов с одной точностью или с фиксированной точкой.
Цели генерации кода не используют те же библиотеки математических ядер, что и решатели MATLAB. Поэтому решения генерации кода могут варьироваться от решений решателя, особенно для плохо обусловленных задач.
Весь код для генерации должен быть кодом MATLAB. В частности, вы не можете использовать пользовательскую функцию black-box в качестве целевой функции для lsqcurvefit
или lsqnonlin
. Можно использовать coder.ceval
для вычисления пользовательской функции, закодированной на C или C++. Однако пользовательская функция должна вызываться в функции MATLAB.
lsqcurvefit
и lsqnonlin
не поддерживать problem
аргумент для генерации кода.
[x,fval] = lsqnonlin(problem) % Not supported
Вы должны задать целевую функцию, используя указатели на функцию, а не строки или имена символов.
x = lsqnonlin(@fun,x0,lb,ub,options) % Supported % Not supported: lsqnonlin('fun',...) or lsqnonlin("fun",...)
Все входные матрицы lb
и ub
должно быть полным, а не разреженным. Вы можете преобразовать разреженные матрицы в полные с помощью full
функция.
The lb
и ub
аргументы должны иметь то же количество записей, что и x0
аргумент или должен быть пустым []
.
Для расширенной оптимизации кода с использованием встраиваемых процессоров вам также нужен Embedded Coder® лицензия.
Вы должны включить опции для lsqcurvefit
или lsqnonlin
и указать их используя optimoptions
. Опции должны включать Algorithm
опция, установить на 'levenberg-marquardt'
.
options = optimoptions('lsqnonlin','Algorithm','levenberg-marquardt'); [x,fval,exitflag] = lsqnonlin(fun,x0,lb,ub,options);
Генерация кода поддерживает следующие опции:
Algorithm
- Должен быть 'levenberg-marquardt'
FiniteDifferenceStepSize
FiniteDifferenceType
FunctionTolerance
MaxFunctionEvaluations
MaxIterations
SpecifyObjectiveGradient
StepTolerance
TypicalX
Сгенерированный код имеет ограниченную проверку ошибок на опции. Рекомендуемый способ обновления опции - использовать optimoptions
, а не запись через точку.
opts = optimoptions('lsqnonlin','Algorithm','levenberg-marquardt'); opts = optimoptions(opts,'MaxIterations',1e4); % Recommended opts.MaxIterations = 1e4; % Not recommended
Не загружайте опции из файла. Это может привести к сбою генерации кода. Вместо этого создайте опции в коде.
Обычно, если вы задаете опцию, которая не поддерживается, опция молчаливо игнорируется во время генерации кода. Однако, если вы задаете функцию построения графика или выходную функцию при помощи записи через точку, генерация кода может вызвать ошибку. Для надежности задайте только поддерживаемые опции.
Поскольку выходные функции и функции построения графика не поддерживаются, решатели не возвращают выходной флаг -1.
По умолчанию сгенерированный код для использования вне окружения MATLAB использует линейные библиотеки алгебры, которые не являются многопоточными. Поэтому этот код может запускаться значительно медленнее, чем код в среде MATLAB.
Если ваш целевой компьютер имеет несколько ядер, можно достичь лучшей эффективности с помощью пользовательских многопоточных библиотек LAPACK и BLAS. Чтобы включить эти библиотеки в ваш сгенерированный код, смотрите Ускорение Линейной Алгебры в Сгенерированном Автономном Коде при Помощи Вызовов LAPACK (MATLAB Coder).
lsqcurvefit
| lsqnonlin
| optimoptions
| codegen
(MATLAB CODER)