Генерация кода в нелинейном решении уравнения: фон

Что такое генерация кода?

Генерация кода является преобразованием 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).

См. также

| | (MATLAB CODER)

Похожие темы

Для просмотра документации необходимо авторизоваться на сайте