Основа Гравера - Википедия - Graver basis
В Прикладная математика, Основания гравера позволяют итерационные решения линейных и различных нелинейных целочисленное программирование проблемы в полиномиальное время. Их представил Джек Э. Грейвер.[1] Их связь с теорией Базы Грёбнера обсуждался Бернд Штурмфельс.[2] Алгоритмическая теория основ Гравера и ее приложение к целочисленному программированию описываются Шмуэль Онн.[3][4]
Формальное определение
В Основание Graver из м × п целочисленная матрица конечное множество минимальных элементов в множестве
в частичном порядке на определяется когда и для всех я. Например, основание Гравера состоит из векторов (2, −1,0), (0, −1,2), (1,0, −1), (1, −1,1) и их отрицаний.
Решение целочисленного программирования с использованием баз Гравера
Целочисленное программирование - задача оптимизации линейной или нелинейной целевой функции по множеству целочисленных точек, удовлетворяющих системе линейных неравенств. Формально в стандартном виде это можно записать так:
Это одна из наиболее фундаментальных задач дискретной оптимизации, которая обладает очень широкими возможностями моделирования и многочисленными приложениями в различных областях, но, как указано ниже, обычно требует больших вычислительных затрат. Однако с учетом основы Гравера из , проблема с линейными и различными нелинейными целевыми функциями может быть решена за полиномиальное время, как описано ниже.
Линейное целочисленное программирование
Наиболее изученный случай, тщательно рассмотренный в,[5] это из линейное целочисленное программирование,
Можно предположить, что все переменные ограничены снизу и сверху: такие границы либо появляются естественным образом в приложении, либо могут быть применены без потери оптимальных решений. Но даже с линейными целевыми функциями проблема NP-сложна и, следовательно, предположительно не может быть решена за полиномиальное время.
Однако основа Гравера из обладает следующим свойством. Для каждой возможной точки Икс:
- Либо Икс является оптимальным (т.е. минимизирует учитывая ограничения);
- Или существует вектор грамм в , так что Икс+грамм возможно и (т.е. Икс можно улучшить, добавив к нему элемент основы Гравера).
Поэтому с учетом основы Гравера , ILP может решаться за полиномиальное время с помощью следующего простого итерационного алгоритма.[3][6] Предположим сначала, что некоторая начальная допустимая точка Икс дано. По возможности повторите следующую итерацию: найдите положительное целое число q и элемент грамм в такой, что Икс + qg не выходит за рамки и дает наилучшее возможное улучшение; Обновить Икс := Икс + qg и переходим к следующей итерации. Последний пункт Икс оптимально, а количество итераций полиномиально.
Чтобы найти начальную выполнимую точку, можно создать подходящую вспомогательную программу и решить ее аналогичным образом.
Нелинейное целочисленное программирование
Переходя к случаю общих целевых функций ж, если переменные неограничены, то задача может оказаться невычислимой: это следует из решения 10-я проблема Гильберта (видеть [7]), что не существует алгоритма, который при целочисленном полиноме ж степени 8 от 58 переменных, решает, равно ли минимальное значение f по всем 58-мерным целочисленным векторам 0. Однако, когда переменные ограничены, проблема
решается на основе Гравера за полиномиальное время для нескольких нелинейных целевых функций, включая[нужна цитата ]:
- Сепарабельно-выпуклый функции формы ;
- В частности p-норма для каждого положительного целого числа п;
- Композитно-вогнутый функции ж(Икс) = грамм(Wx), куда W это d × п целочисленная матрица с d фиксировано, а где грамм это d-переменная функция вогнутости;
- Определенный (in) -определенный квадратичный и многочлен высшей степени функции.
Некоторые приложения
Многомерные таблицы
Рассмотрим следующую задачу оптимизации трехмерных таблиц с заданными суммами строк:
с , , неотрицательные целые числа (максимальное значение которых неявно ограничивает все переменные сверху). Обозначим через (lm + пер + мин) × (lmn), определяющую матрицу этой системы. Обратите внимание, что эта матрица обычно нет полностью унимодулярный. Тем не менее, это было показано в [8] что для каждого фиксированного л и м, его Граверная основа можно вычислить за время, которое является полиномиальным отп. Приведенные выше результаты позволяют решить эту задачу за полиномиальное время при фиксированном л и м и переменная п. Обратите внимание, что если только одна сторона л стола фиксируется (даже с л = 3) в то время как оба м и п являются переменными, то проблема NP трудна, как показано в.[9] В более общем плане аналогичные положительные результаты верны для табличных задач более высокой размерности [10]): для каждого фиксированного d и , (не) линейная оптимизация по таблицы с переменным n и заданными полями могут быть созданы за полиномиальное время. Это имеет дополнительные приложения к проблемам безопасности входа и конфиденциальности в статистических базах данных.
Многопродуктовые потоки
Рассмотрим целое число проблема многопродуктового потока маршрутизации k виды целочисленных товаров из м поставщики п потребители подвергаются ограничениям по поставке, потреблению и мощности, чтобы минимизировать сумму линейных или зависящих от перегрузки выпуклых затрат на дугах. Тогда для каждого фиксированного k и м, можно вычислить базис Гравера определяющей системы и минимизировать получаемую в результате выпуклую и отделимую целевую функцию по времени, которое является полиномиальным от числа переменных п потребителей и в остальных данных.
Другие приложения
Многие приложения алгоритмической теории баз Гравера также включают:
- стохастическое целочисленное программирование,[6]
- N-кратное целочисленное программирование,
- N4-кратное разложимое целочисленное программирование,[11]
- кластеризация
- контроль раскрытия информации в статистических базах данных,
- и справедливое размещение неделимых объектов.[12]
В некоторых из этих приложений соответствующая основа Гравера не можешь вычисляться за полиномиальное время, но к нему можно обращаться косвенно, что позволяет использовать его за полиномиальное время.
Универсальность и параметризация
Это было показано в [13] что каждая (ограниченная) задача целочисленного программирования в точности эквивалентна 3 ×м × п проблема таблицы обсуждалась выше для некоторых м и п и некоторые строчные суммы. Таким образом, такие 3 ×м × п столовые проблемы универсальный для целочисленного программирования. Причем для каждого фиксированного м, результирующий класс целочисленных программ может быть решен за полиномиальное время с помощью итерационного базисного метода Гравера, описанного выше. Итак, ширина стола м обеспечивает параметризация всех задач целочисленного программирования.
Иерархия приближений для целочисленного программирования
Обозначим через Граверовский базис матрицы определяя универсальный 3 ×м × п таблица проблема обсуждалась выше. Элементы 3 ×м × п таблицы, в которых суммы всех строк равны 0. тип такой таблицы - количество ее ненулевых 3 ×м слои. Оказывается, существует конечная Функция сложности Гравера грамм(м) такой, что для любого п, тип любого элемента основы Гравера самое большее грамм(м). Отсюда следует, что базис Гравера это союз надлежащим образом встроенные копии основы Гравера . Чтобы приблизительно решить на практике задачу произвольного целочисленного программирования, действуйте следующим образом. Сначала вставьте его в подходящие 3 ×м × п проблема таблицы, что стало возможным благодаря универсальности, отмеченной выше. Теперь применим следующую иерархию приближений . На уровне k этой иерархии, пусть быть подмножеством состоящий только из элементов типа не более k; используйте это приближение в итерационном алгоритме как можно дольше, чтобы получить как можно более точную выполнимую точку для задачи целочисленного программирования, встроенной в 3 ×м × п таблица проблема; если значение целевой функции этой точки удовлетворительное (скажем, по сравнению со значением релаксация линейного программирования ), затем используйте эту точку; в противном случае увеличить k и переходите на следующий уровень иерархии. Это можно показать [3] что для любого фиксированного уровня k, приближение базиса Гравера имеет полиномиальную мощность и может быть вычислен за это время.
Управляемость с фиксированными параметрами: от полиномиальной до кубической временной сложности
Временная сложность решения некоторых из рассмотренных выше приложений, таких как многомерные табличные задачи, проблемы с потоками нескольких товаров и N-кратных задач целочисленного программирования, доминирует мощность соответствующего базиса Гравера, который является полиномом с обычно большой степенью грамм что является подходящей Граверовской сложностью системы. В [14] представлен гораздо более быстрый алгоритм, который на каждой итерации находит лучшее улучшение Икс + qg с q положительное целое число и грамм элемент в без явного построения базиса Гравера, в кубическом времени независимо от системы. параметризованная сложность, это означает, что все эти задачи параметризованы соответствующим образом, и в частности л × м × п Табличные задачи, параметризованные л и м, находятся фиксированный параметр управляемый.
Смотрите также
- Лемма Гордана - еще один инструмент, связанный с нулевыми наборами целочисленных матриц.
Рекомендации
- ^ Джек Э. Грейвер: Об основах линейного и линейного целочисленного программирования, Математическое программирование 9: 207–226, 1975
- ^ Бернд Штурмфельс, Базисы Грёбнера и выпуклые многогранники, Американское математическое общество, xii + 162 с., 1996
- ^ а б c Шмуэль онн: Нелинейная дискретная оптимизация, Европейское математическое общество, x + 137 с., 2010
- ^ Шмуэль Онн: Линейная и нелинейная целочисленная оптимизация, Серия онлайн-видеолекций, Институт математических наук, Беркли, 2010 г.
- ^ Александр Шрайвер: Теория линейного и целочисленного программирования, Wiley, xii + 471 с., 1986
- ^ а б Раймонд Хеммеке, Шмуэль Онн, Роберт Вейсмантел: полиномиальный алгоритм времени-оракула для выпуклой целочисленной минимизации, Математическое программирование, 126: 97–117, 2011
- ^ Юрий Васильевич Матиясевич: Десятая проблема Гильберта, MIT Press, xxiv + 264 стр., 1993
- ^ Хесус А. Де Лоэра, Раймонд Хеммеке, Шмуэль Онн, Роберт Вайсмантель: N-кратное целочисленное программирование, DiscreteOptimization, 5: 231–241, 2008.
- ^ Хесус А. Де Лоэра, Шмуэль Онн: Сложность трехкомпонентных статистических таблиц, SIAM Journal on Computing, 33: 819–836, 2004
- ^ Теодор С. Моцкин: многоиндексная транспортная проблема, Бюллетень Американского математического общества 58: 494, 1952
- ^ Раймонд Хеммеке, Маттиас Кеппе, Роберт Вайсмантел: алгоритм с полиномиальным временем для оптимизации N4-блочные разложимые целочисленные программы, IPCO 14, 2010
- ^ Бредерек, Роберт; Качмарчик, Анджей; Кноп, Душан; Нидермайер, Рольф (17.06.2019). "Справедливое распределение высокой кратности: Lenstra расширяет возможности N-кратного целочисленного программирования". Материалы конференции ACM по экономике и вычислениям 2019 г.. EC '19. Феникс, Аризона, США: Ассоциация вычислительной техники: 505–523. Дои:10.1145/3328526.3329649. ISBN 978-1-4503-6792-9.
- ^ Хесус А. Де Лоэра, Шмуэль Онн: Полностью линейные и целочисленные программы - это тонкие программы трехстороннего транспорта, SIAM Journal on Optimization, 17: 806–821, 2006
- ^ Раймонд Хеммеке, Шмуэль Онн, Любовь Романчук: N-кратное целочисленное программирование в кубическом времени, Математическое программирование, 137: 325–341, 2013