Квадратичная программа с ограничениями - Quadratically constrained quadratic program - Wikipedia
В математическая оптимизация, а квадратичная квадратичная программа (QCQP) является проблема оптимизации в котором как целевая функция и ограничения находятся квадратичные функции. Он имеет вид
куда п0, …, пм находятся п-к-п матрицы и Икс ∈ рп - переменная оптимизации.
Если п0, …, пм все положительно полуопределенный, тогда проблема в выпуклый. Если эти матрицы не являются ни положительными, ни отрицательными полуопределенными, проблема невыпуклая. Если п1, … ,пм равны нулю, то на самом деле ограничения линейный и проблема в квадратичная программа.
Твердость
Решение общего случая - это NP-жесткий проблема. Чтобы увидеть это, обратите внимание, что два ограничения Икс1(Икс1 - 1) ≤ 0 и Икс1(Икс1 - 1) ≥ 0 эквивалентны ограничению Икс1(Икс1 - 1) = 0, что, в свою очередь, эквивалентно ограничению Икс1 ∈ {0, 1}. Следовательно, любой 0–1 целочисленная программа (в котором все переменные должны быть либо 0, либо 1) может быть сформулирована как квадратичная квадратичная программа. Поскольку целочисленное программирование 0–1 в целом является NP-сложным, QCQP также является NP-сложным.
Расслабление
Есть два основных способа ослабления QCQP: использование полуопределенное программирование (SDP) и используя метод переформулировки-линеаризации (RLT). Для некоторых классов задач QCQP (а именно, QCQP с нулевыми диагональными элементами в матрицах данных), программирование конуса второго порядка (SOCP) и линейное программирование Доступны (LP) релаксации, обеспечивающие такое же объективное значение, как и релаксация SDP.[1]
Невыпуклые QCQP с неположительными недиагональными элементами могут быть точно решены с помощью релаксации SDP или SOCP,[2] и есть полиномиально проверяемые по времени достаточные условия, чтобы SDP-релаксации общих QCQP были точными.[3] Более того, было показано, что класс случайных общих QCQP имеет точные полуопределенные релаксации с высокой вероятностью до тех пор, пока количество ограничений растет не быстрее, чем фиксированный многочлен от числа переменных.[3]
Полуопределенное программирование
Когда п0, …, пм все положительно определенные матрицы, проблема в выпуклый и может быть легко решена с помощью методы внутренней точки, как и с полуопределенное программирование.
Пример
Максимальный разрез является проблемой теории графов, которая является NP-трудной. Для данного графа задача состоит в том, чтобы разделить вершины на два набора, чтобы как можно больше ребер переходили из одного набора в другой. Max Cut можно сформулировать как QCQP, а SDP-релаксация двойника обеспечивает хорошие нижние границы.
Решатели и языки сценариев (программирования)
Имя | Краткая информация |
---|---|
Artelys Knitro | Knitro - это решатель, специализирующийся на нелинейной оптимизации, но также решающий задачи линейного программирования, задачи квадратичного программирования, конусное программирование второго порядка, системы нелинейных уравнений и задачи с равновесными ограничениями. |
FICO Xpress | Коммерческий решатель оптимизации для линейного программирования, нелинейного программирования, смешанного целочисленного линейного программирования, выпуклого квадратичного программирования, выпуклого квадратично ограниченного квадратичного программирования, конусного программирования второго порядка и их смешанных целочисленных аналогов. |
AMPL | |
CPLEX | Популярный решатель с API для нескольких языков программирования. Бесплатно для ученых. |
Гуроби | Решатель с параллельными алгоритмами для крупномасштабных линейных программ, квадратичных программ и смешано-целочисленных программ. Бесплатно для академического использования. |
МОСЕК | Решатель для крупномасштабной оптимизации с API для нескольких языков (C ++, java, .net, Matlab и python) |
ТОМЛАБ | Поддерживает глобальную оптимизацию, целочисленное программирование, все типы наименьших квадратов, линейное, квадратичное и неограниченное программирование для MATLAB. TOMLAB поддерживает такие решатели, как Гуроби, CPLEX, СНОПТ и KNITRO. |
Рекомендации
- ^ Кимидзука, Масаки; Ким, Сонён; Ямасита, Макото (2019). «Решение задач объединения с дискретизацией по времени с помощью релаксации LP и SOCP и методов перепланирования». Журнал глобальной оптимизации. 75 (3): 631–654. Дои:10.1007 / s10898-019-00795-w. ISSN 0925-5001.
- ^ Ким, Сонён; Кодзима, Масакадзу (2003). «Точные решения некоторых невыпуклых квадратичных задач оптимизации с помощью SDP и SOCP релаксации». Вычислительная оптимизация и приложения. 26 (2): 143–154. Дои:10.1023 / А: 1025794313696.
- ^ а б Бюрер, Самуэль; Е Инью (04.02.2019). «Точные полуопределенные формулировки для класса (случайных и неслучайных) невыпуклых квадратичных программ». Математическое программирование. 181: 1–17. arXiv:1802.02688. Дои:10.1007 / s10107-019-01367-2. ISSN 0025-5610.
- Бойд, Стивен; Ливен Ванденберге (2004). Выпуклая оптимизация. Кембридж: Издательство Кембриджского университета. ISBN 978-0-521-83378-3.
дальнейшее чтение
В статистике
- Альберс К. Дж., Кричли Ф., Гауэр Дж. К. (2011). «Задачи квадратичной минимизации в статистике» (PDF). Журнал многомерного анализа. 102 (3): 698–713. Дои:10.1016 / j.jmva.2009.12.018.CS1 maint: несколько имен: список авторов (связь)