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