Нелинейное программирование - Nonlinear programming

В математика, нелинейное программирование (НЛП) - это процесс решения проблема оптимизации где некоторые ограничения или целевая функция нелинейный. An проблема оптимизации является одним из вычислений экстремумов (максимумов, минимумов или стационарных точек) целевая функция над набором неизвестных реальные переменные и при условии удовлетворения система из равенства и неравенство, вместе именуемые ограничения. Это подполе математическая оптимизация который имеет дело с проблемами, которые не являются линейными.

Применимость

Типичный не-выпуклый Проблема заключается в оптимизации транспортных расходов путем выбора из набора методов транспортировки, один или несколько из которых демонстрируют эффект масштаба, с различными возможностями подключения и ограничениями емкости. Примером может быть транспортировка нефтепродуктов с учетом выбора или комбинации трубопровода, железнодорожного танкера, автоцистерны, речной баржи или прибрежного танкера. Из-за экономичного размера партии функции затрат могут иметь разрывы в дополнение к плавным изменениям.

В экспериментальной науке некоторый простой анализ данных (например, подгонка спектра к сумме пиков известного местоположения и формы, но неизвестной величины) может выполняться линейными методами, но в целом эти проблемы также являются нелинейными. Обычно имеется теоретическая модель изучаемой системы с переменными параметрами в ней и модель эксперимента или экспериментов, которые также могут иметь неизвестные параметры. Кто-то пытается найти наилучшее численное соответствие. В этом случае часто требуется мера точности результата, а также само наилучшее соответствие.

Определение

Позволять п, м, и п быть натуральными числами. Позволять Икс быть подмножеством рп, позволять ж, гя, и часj быть действительные функции на Икс для каждого я в {1, …, м} и каждый j в {1, …, п}, хотя бы с одним из ж, гя, и часj быть нелинейным.

Задача нелинейной минимизации - это проблема оптимизации формы

Аналогично определяется задача нелинейной максимизации.

Возможные типы набора ограничений

Существует несколько вариантов характера набора ограничений, также известного как допустимый набор или возможный регион.

An невыполнимый проблема - это проблема, для которой ни один набор значений переменных выбора не удовлетворяет всем ограничениям. То есть ограничения противоречат друг другу, и решения не существует; возможный набор - это пустой набор.

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

An неограниченный проблема - это выполнимая задача, для которой целевая функция может быть лучше любого заданного конечного значения. Таким образом, не существует оптимального решения, потому что всегда существует допустимое решение, которое дает лучшее значение целевой функции, чем любое данное предлагаемое решение.

Способы решения проблемы

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

Если целевая функция квадратичный и ограничения линейны, квадратичное программирование используются техники.

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

Доступно несколько методов решения невыпуклых задач. Один из подходов - использовать специальные постановки задач линейного программирования. Другой метод предполагает использование ветвь и переплет методы, в которых программа делится на подклассы, которые должны быть решены с помощью выпуклых (задача минимизации) или линейных аппроксимаций, которые образуют нижнюю границу общей стоимости в рамках подразделения. При последующих делениях в какой-то момент будет получено реальное решение, стоимость которого будет равна наилучшей нижней оценке, полученной для любого из приближенных решений. Это решение оптимальное, хотя, возможно, и не уникальное. Алгоритм также может быть остановлен раньше, с гарантией, что наилучшее возможное решение находится в пределах допуска от найденной наилучшей точки; такие точки называются ε-оптимальными. Преобразование в ε-оптимальные точки обычно необходимо для обеспечения конечного завершения. Это особенно полезно для больших, сложных проблем и проблем с неопределенными затратами или значениями, где неопределенность можно оценить с помощью соответствующей оценки надежности.

Под дифференцируемость и ограничения квалификации, то Условия Каруша – Куна – Таккера (ККТ) обеспечить необходимые условия для оптимального решения. В случае выпуклости этих условий также достаточно. Если некоторые функции недифференцируемы, субдифференциальный версииУсловия Каруша – Куна – Таккера (ККТ) доступны.[1]

Примеры

2-мерный пример

Синяя область - это возможный регион. В касание линии с допустимой областью представляет решение. Линия лучшая достижимая контурная линия (локус с заданным значением целевой функции).

Простую задачу (показанную на диаграмме) можно определить с помощью ограничений

Икс1 ≥ 0
Икс2 ≥ 0
Икс12 + Икс22 ≥ 1
Икс12 + Икс22 ≤ 2

с максимальной целевой функцией

ж(Икс) = Икс1 + Икс2

где Икс = (Икс1, Икс2).

3-х мерный пример

Касание верхней поверхности с ограниченным пространством в центре представляет собой решение.

Еще одна простая задача (см. Диаграмму) может быть определена ограничениями

Икс12Икс22 + Икс32 ≤ 2
Икс12 + Икс22 + Икс32 ≤ 10

с максимальной целевой функцией

ж(Икс) = Икс1Икс2 + Икс2Икс3

где Икс = (Икс1, Икс2, Икс3).

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

использованная литература

  1. ^ Рущинский, Анджей (2006). Нелинейная оптимизация. Принстон, штат Нью-Джерси: Princeton University Press. С. xii + 454. ISBN  978-0691119151. Г-Н  2199043.

дальнейшее чтение

внешние ссылки