Квадратичное программирование (англ.quadratic programming, QP) — это процесс решения задачи оптимизации специального типа, а именно — задачи оптимизации (минимизации или максимизации) квадратичной функции нескольких переменных при линейных ограничениях на эти переменные. Квадратичное программирование является частным случаем нелинейного программирования.
Целью задачи квадратичного программирования является поиск n-мерного вектора x, который
минимизирует
при условиях
где xT обозначает транспонированный вектор. Обозначение Ax ≤ b означает, что любой элемент вектора Ax не превосходит соответствующего элемента вектора b.
Задача квадратичного программирования несколько проще, если Q является положительно определённой и все ограничения являются равенствами (нет неравенств), поскольку в этом случае можно свести задачу к решению системы линейных уравнений. Если использовать множители Лагранжа и искать экстремум лагранжиана, можно легко показать, что решение задачи
минимизировать
при условиях
определяется системой линейных уравнений
где — множество множителей Лагранжа, которые появляются вместе с решением .
Самый лёгкий способ решить эту систему — решить её прямыми методами (например, с помощью LU-разложения, очень удобного для небольших задач). Для больших задач возникают некоторые необычные трудности, наиболее заметные, когда задача не положительно определена (даже если положительно определена), что делает потенциально очень трудно найти хороший математический подход и существует много подходов, зависящих от задачи[источник не указан 2993 дня].
Если число ограничений не равно числу переменных, можно попробовать относительно простую атаку, заменив переменные таким образом, что ограничения будут выполняться безусловно. Например, допустим, что (переход к ненулевым значениям достаточно прост). Рассмотрим ограничения
Введём новый вектор , определённый равенством
где имеет размерность минус число ограничений. Тогда
и если матрица выбрана так, что , равенства в ограничениях будут выполняться всегда. Поиск матрицы подразумевает нахождение ядра матрицы , что более или менее просто, в зависимости от структуры матрицы . Подставляя новый вектор в исходные условия, получаем квадратичную задачу без ограничений:
и решение можно будет найти, решив уравнение
При некоторых ограничениях на сокращённая матрица будет положительно определена. Можно написать вариант метода сопряжённых градиентов, при котором нет необходимости явного вычисления матрицы [5].
Двойственная задача Лагранжа для квадратичного программирования является также задачей квадратичного программирования. Чтобы это понять, остановимся на случае с положительно определённой матрицей Q. Выпишем множители Лагранжа функции
Если определим (лагранжеву) двойственную функцию как , мы ищем нижнюю границу, используя и положительную определённость мaтрицы Q:
Следовательно, двойственна функция равна
и двойственной задачей Лагранжа для исходной задачи будет
минимизировать
при условиях
.
Кроме теории двойственности Лагранжа, существуют другие двойственные пары задач (например, двойственность Вулфа[англ.]).
Моделирование и оптимизация для задач LP (линейное программирование), QP (квадратичное программирование), NLP (нелинейное программирование), MILP (целочисленное программирование), MINLP (смешанное целочисленное нелинейное программирование) и DAE[англ.] (дифференциально-алгебраические уравнения) в MATLAB и Python.
Система решения нелинейных задач, приспособленная для электронных таблиц, в которой вычислений функций основывается на значении ячеек. Базовая версия доступна как стандартное дополнение для Excel.
Система решения задач с параллельными алгоритмами для задач линейного программирования большого размера, задач квадратичного программирования и смешанно–целочисленных задач. Бесплатна для академического использования.
Язык программирования общего назначения для математики. Для решения квадратичных задач в Maple используется команда QPSolveАрхивная копия от 12 мая 2021 на Wayback Machine.
Матрично-ориентированный язык программирования общего назначения для численных вычислений. Для решения задач квадратичного программирования в MATLAB требуется вдобавок к базовому продукту MATLAB дополнение «Optimization Toolbox»
Набор математических и статистических процедур, разработанных компанией Numerical Algorithms Group[англ.] для нескольких языков программирования (C, C++, Fortran, Visual Basic, Java и C#) и пакетов (MATLAB, Excel, R, LabVIEW). Раздел оптимизации библиотеки NAG включает процедуры для задач квадратичного программирования с редкими и плотными матрицами ограничений, а также процедуры для оптимизации линейных и нелинейных функций, сумм квадратов линейных и нелинейных функций. В библиотеке NAG имеются процедуры как для локальной, так и глобальной оптимизации, а также для задач целочисленного программирования.
Свободно распространяемый, основанный на Java язык моделирования для оптимизации и поддерживающий несколько целевых систем решений. Существует плагин для Eclipse [9][10]
Система для решения линейных, целочисленных , комбинаторных, нелинейных, недиференцируемых задач, задач на сетях и оптимизации в ограничениях. Язык алгебраического моделирования[англ.]OPTMODELАрхивная копия от 8 сентября 2016 на Wayback Machine и ряд вертикальных решений, нацеленных на специфичные задачи, полностью интегрированы с |SAS/.
Система математического моделирования и решения задач, основанная на декларативном языке, базирующемся на продукционных правилах. Система коммерциализирована компанией Universal Technical Systems, Inc.Архивная копия от 1 апреля 2022 на Wayback Machine.
Поддерживает глобальную оптимизацию, решение задач целочисленного программирования, все типы метода наименьших квадратов, решение задач линейного квадратичного программирования для MATLAB. TOMLAB поддерживает системы решения Gurobi, CPLEX, SNOPT[англ.] и KNITRO[англ.].
F. Delbos, J.Ch. Gilbert. Global linear convergence of an augmented Lagrangian algorithm for solving convex quadratic optimization problems // Journal of Convex Analysis. — 2005. — Т. 12. — С. 45—69.
Felix Zesch, Bernd Hellingrath. An optimization model for mixed-model assembly lines // Integrated Production-Distribution Planning. — 2010.
Andriy Burkov, Brahim Chaib-draa. Proceedings of the Twenty-Fourth AAAI Conference on Artificial Intelligence (AAAI-10). — Atlanta, USA: AAAI Press, 2010.
Nicholas I. M. Gould, Mary E. Hribar, Jorge Nocedal. On the Solution of Equality Constrained Quadratic Programming Problems Arising in Optimization. — SIAM Journal of Scientific Computing, 2001. — Т. 23, вып. 4. — С. 1376—1395.
М. К. Козлов, С. П. Тарасов, Л. Г. Хачиян. Полиномиальная разрешимость выпуклого квадратичного программирования, // Ж. вычисл. матем. и матем. физ.. — 1980. — Т. 20,, вып. 5.
S. Sahni. Computationally related problems // SIAM Journal on Computing. — 1974. — Т. 3. — С. 262—279. — doi:10.1137/0203021.
Panos M. Pardalos, Stephen A. Vavasis. Quadratic programming with one negative eigenvalue is NP-hard // Journal of Global Optimization. — 1991. — Т. 1, вып. 1. — С. 15—22. — doi:10.1007/bf00120662.
Richard W. Cottle, Jong-Shi Pang, Richard E. Stone. The linear complementarity problem. — Boston, MA: Academic Press, Inc., 1992. — С. xxiv+762 pp.. — (Computer Science and Scientific Computing). — ISBN 0-12-192350-9.
Nicholas I. M. Gould, Philippe L. Toint.A Quadratic Programming Bibliography (неопр.) (PDF). RAL Numerical Analysis Group Internal Report 2000-1 (2000).
Пожалуйста, после исправления проблемы исключите её из списка параметров. После устранения всех недостатков этот шаблон может быть удалён любым участником.