Последовательное линейно-квадратичное программирование - Sequential linear-quadratic programming

Последовательное линейно-квадратичное программирование (SLQP) является итерационный метод за задачи нелинейной оптимизации куда целевая функция и ограничения дважды непрерывно дифференцируемый. Аналогично последовательное квадратичное программирование (SQP) SLQP выполняется путем решения последовательности подзадач оптимизации. Разница между двумя подходами заключается в том, что:

  • в SQP каждая подзадача является квадратичная программа, с квадратичной моделью объекта с линеаризацией ограничений
  • в SLQP на каждом шаге решаются две подзадачи: линейная программа (LP) используется для определения активный набор, за которой следует квадратичная программа с ограничениями на равенство (EQP), используемая для вычисления общего шага

Эта декомпозиция делает SLQP подходящим для крупномасштабных задач оптимизации, для которых доступны эффективные решатели LP и EQP, причем эти задачи легче масштабировать, чем полноценные квадратичные программы.

Основы алгоритма

Рассмотрим нелинейное программирование проблема формы:

Лагранжиан для этой задачи равен[1]

куда и находятся Множители Лагранжа.

Фаза LP

В LP-фазе SLQP решается следующая линейная программа:

Позволять обозначить активный набор на оптимальном этой задачи, т. е. набор ограничений, равных нулю при . Обозначим через и подвекторы и соответствующие элементам .

Фаза EQP

На этапе EQP SLQP направление поиска шага получается путем решения следующей квадратичной программы:

Обратите внимание, что термин в приведенных выше целевых функциях может быть опущено для задач минимизации, поскольку она постоянна.

Смотрите также

Примечания

  1. ^ Хорхе Нокедаль и Стивен Дж. Райт (2006). Численная оптимизация. Springer. ISBN  0-387-30303-0.

Рекомендации