Проблема с упаковкой контейнера
ведра Проблема с упаковкой мусорного [ 1 ] [ 2 ] [ 3 ] [ 4 ] Это задача оптимизации , в которой предметы разного размера должны быть упакованы в конечное число контейнеров или контейнеров, каждый из которых имеет фиксированную заданную вместимость, таким образом, чтобы минимизировать количество используемых контейнеров. Проблема имеет множество применений, таких как заполнение контейнеров, загрузка грузовиков с ограничениями по весу, создание резервных копий файлов на носителе, разделение сетевого префикса на несколько подсетей, [ 5 ] и картирование технологий при FPGA проектировании полупроводниковых чипов .
В вычислительном отношении задача является NP-сложной , а соответствующая задача решения , позволяющая решить, могут ли элементы поместиться в заданное количество ячеек, является NP-полной . Несмотря на сложность наихудшего случая, оптимальные решения для очень больших случаев задачи могут быть получены с помощью сложных алгоритмов. Кроме того, множество алгоритмов аппроксимации существует . Например, алгоритм первого соответствия обеспечивает быстрое, но зачастую неоптимальное решение, предполагающее помещение каждого элемента в первую корзину, в которую он поместится. Для этого требуется время Θ ( n log n ), где n — количество упаковываемых предметов. Алгоритм можно сделать намного более эффективным, если сначала отсортировать список элементов в порядке убывания (иногда известный как алгоритм убывания по первому совпадению), хотя это все равно не гарантирует оптимальное решение, а для более длинных списков может увеличиться время работы. алгоритм. Однако известно, что всегда существует хотя бы один порядок элементов, который позволяет методом первого подбора получить оптимальное решение. [ 6 ]
Существует множество вариантов этой задачи, например двумерная упаковка, линейная упаковка, упаковка по весу, упаковка по стоимости и т. д. Проблему упаковки корзин также можно рассматривать как частный случай проблемы раскроя запасов . Когда количество корзин ограничено 1 и каждый предмет характеризуется как объемом, так и стоимостью, проблема максимизации ценности предметов, которые могут поместиться в корзину, известна как задача о рюкзаке .
На практике встречается вариант упаковки в корзину, когда предметы могут разделять пространство при упаковке в корзину. В частности, набор предметов в упаковке может занимать меньше места, чем сумма их индивидуальных размеров. Этот вариант известен как упаковка VM. [ 7 ] поскольку когда виртуальные машины (ВМ) упакованы на сервер, их общая потребность в памяти может уменьшиться из-за страниц, совместно используемых ВМ, которые необходимо сохранить только один раз. Если предметы могут распределять пространство произвольным образом, проблему упаковки в мусорные корзины трудно даже приблизительно представить. Однако если совместное использование пространства вписывается в иерархию, как в случае совместного использования памяти в виртуальных машинах, проблема упаковки ячеек может быть эффективно решена.
Еще одним вариантом упаковки контейнеров, представляющим практический интерес, является так называемая онлайн- упаковка контейнеров. Здесь предметы различного объема должны поступать последовательно, и ЛПР должен решить, следует ли выбрать и упаковать наблюдаемый в данный момент предмет или пропустить его. Каждое решение не подлежит отзыву. Напротив, автономная упаковка в корзину позволяет переставлять предметы в надежде добиться лучшей упаковки после прибытия дополнительных товаров. Это, конечно, требует дополнительного места для хранения предметов, подлежащих перестановке.
Официальное заявление
[ редактировать ]В компьютерах и трудноразрешимости [ 8 ] : 226 Гэри и Джонсон перечисляют проблему упаковки контейнеров в ссылке [SR1]. Вариант его решения они определяют следующим образом.
Пример: конечное множество предметов, размер для каждого , положительное целое число емкость бункера и положительное целое число .
Вопрос: Есть ли раздел на непересекающиеся множества такая, что сумма размеров предметов в каждом является или меньше?
Отметим, что в литературе часто используются эквивалентные обозначения, где и для каждого . Кроме того, исследования больше всего интересуют варианты оптимизации, которые требуют минимально возможного значения . Решение является оптимальным, если оно имеет минимальную . -значение оптимального решения для набора предметов обозначается или просто если набор предметов ясен из контекста.
Возможная целочисленным линейным программированием формулировка задачи :
минимизировать | ||
при условии | ||
где если мусорное ведро используется и если предмет помещается в корзину . [ 9 ]
Твердость упаковки контейнера
[ редактировать ]Задача упаковки контейнеров является строго NP-полной . Это можно доказать, сведя сильно NP-полную задачу трех разделов к упаковке контейнеров. [ 8 ]
Более того, не может быть алгоритма аппроксимации с абсолютным коэффициентом аппроксимации меньшим, чем пока не . Это можно доказать, редукционируя к задаче о разделах : [ 10 ] учитывая экземпляр раздела, где сумма всех входных чисел равна , создайте экземпляр упаковки контейнеров, в котором размер контейнера равен T . Если существует равное разделение входных данных, то для оптимальной упаковки требуется 2 контейнера; следовательно, каждый алгоритм с коэффициентом аппроксимации меньшим, чем 3/2 . ячейки должно возвращать менее 3 ячеек, что должно составлять 2 Напротив, если нет равного разделения входов, то для оптимальной упаковки требуется как минимум 3 контейнера.
С другой стороны, упаковка контейнеров разрешима за псевдополиномиальное время для любого фиксированного числа контейнеров K и разрешима за полиномиальное время для любой фиксированной емкости контейнера B . [ 8 ]
Алгоритмы аппроксимации упаковки контейнеров
[ редактировать ]Для измерения производительности алгоритма аппроксимации в литературе рассматриваются два коэффициента аппроксимации. Для заданного списка элементов число обозначает количество ячеек, используемых при алгоритме применяется к списку , пока обозначает оптимальное число для этого списка. Абсолютный наихудший коэффициент производительности для алгоритма определяется как
С другой стороны, асимптотическое отношение наихудшего случая определяется как
Эквивалентно, — наименьшее число такое, что существует некоторая константа K, такая что для всех списков L: [ 4 ]
- .
Кроме того, можно ограничить списки теми, в которых все элементы имеют размер не более . Для таких списков коэффициенты производительности ограниченного размера обозначаются как и .
Алгоритмы аппроксимации упаковки контейнеров можно разделить на две категории:
- Онлайн-эвристика, которая рассматривает элементы в заданном порядке и помещает их один за другим в корзины. Эти эвристики также применимы к автономной версии этой задачи.
- Автономная эвристика, которая изменяет заданный список элементов, например, сортируя элементы по размеру. Эти алгоритмы больше не применимы к онлайн-варианту этой задачи. Однако они имеют улучшенную гарантию аппроксимации, сохраняя при этом преимущество своей небольшой временной сложности. Подкатегория автономных эвристик — это схемы асимптотической аппроксимации. Эти алгоритмы имеют гарантию аппроксимации вида для некоторой константы, которая может зависеть от . Для сколь угодно большого эти алгоритмы подбираются сколь угодно близко к . Однако за это приходится платить (резко) увеличением временной сложности по сравнению с эвристическими подходами.
Онлайн-эвристика
[ редактировать ]В онлайн- версии задачи об упаковке корзин предметы прибывают один за другим, и (необратимое) решение, куда поместить предмет, должно быть принято до того, как будет известен следующий предмет или даже будет ли он еще. Разнообразный набор офлайн- и онлайн-эвристик для упаковки в контейнеры был изучен Дэвидом С. Джонсоном в своей докторской диссертации. диссертация. [ 11 ]
Одноклассовые алгоритмы
[ редактировать ]Существует множество простых алгоритмов, использующих следующую общую схему:
- Для каждого элемента входного списка:
- Если предмет помещается в одну из открытых в данный момент ячеек, поместите его в одну из этих ячеек;
- В противном случае откройте новую корзину и поместите в нее новый предмет.
Алгоритмы различаются критерием, по которому они выбирают открытую корзину для нового товара на шаге 1 (дополнительную информацию см. на связанных страницах):
- Функция Next Fit (NF) всегда оставляет одну открытую корзину. Когда новый товар в него не помещается, он закрывает текущую корзину и открывает новую корзину. Его преимущество состоит в том, что это алгоритм с ограниченным пространством, поскольку ему нужно хранить в памяти только один открытый интервал. Его недостатком является то, что коэффициент асимптотической аппроксимации равен 2. В частности, , и для каждого существует список L такой, что и . [ 11 ] Его коэффициент асимптотической аппроксимации можно несколько улучшить в зависимости от размеров элемента: для всех и для всех . Для каждого алгоритма A , который является алгоритмом AnyFit, справедливо следующее соотношение: .
- Next-k-Fit (NkF) — это вариант Next-Fit, но вместо того, чтобы оставлять открытой только одну ячейку, алгоритм оставляет открытыми последние k ячеек и выбирает первую ячейку, в которую помещается элемент. Поэтому его называют алгоритмом с k-ограниченным пространством . [ 12 ] Для NkF дает результаты, которые улучшаются по сравнению с результатами NF, однако увеличение k до постоянных значений, превышающих 2, не приводит к дальнейшему улучшению алгоритма в его худшем случае. Если алгоритм A является алгоритмом ПочтиAnyFit и затем . [ 11 ]
- Функция First-Fit (FF) сохраняет все контейнеры открытыми в том порядке, в котором они были открыты. Он пытается поместить каждый новый элемент в первую корзину, в которую он помещается. Его коэффициент аппроксимации равен , и существует семейство входных списков L, для которого соответствует этой границе. [ 13 ]
- Best-Fit (BF) также оставляет все контейнеры открытыми, но пытается поместить каждый новый предмет в контейнер с максимальной загрузкой, в которую он помещается. Его коэффициент аппроксимации идентичен коэффициенту FF, то есть: , и существует семейство входных списков L, для которого соответствует этой границе. [ 14 ]
- Worst-Fit (WF) пытается поместить каждый новый предмет в корзину с минимальной загрузкой. Он может вести себя так же плохо, как Next-Fit, и попадет в список наихудших для этого случаев. . Кроме того, он утверждает, что . Поскольку WF является алгоритмом AnyFit, существует алгоритм AnyFit такой, что . [ 11 ]
- Функция «Почти наихудшее соответствие» (AWF) пытается поместить каждый новый товар во вторую по величине пустую открытую корзину (или самую пустую корзину, если таких корзин две). Если не подходит, пробует самый пустой. Он имеет асимптотическое отношение наихудшего случая . [ 11 ]
Чтобы обобщить эти результаты, Джонсон ввел два класса онлайн-эвристик, называемых алгоритмом любого соответствия и алгоритмом почти любого соответствия : [ 4 ] : 470
- В алгоритме AnyFit (AF) , если текущие непустые ячейки — это B 1 ,..., B j , то текущий элемент не будет упакован в B j +1, если только он не помещается ни в один из B 1 ,.. ., Б ж . Алгоритмы FF, WF, BF и AWF удовлетворяют этому условию. Джонсон доказал, что для любого алгоритма AnyFit A и любого :
- .
- В алгоритме ПочтиAnyFit (AAF) , если текущие непустые контейнеры — это B 1 ,..., B j , и из этих контейнеров B k — уникальный контейнер с наименьшей загрузкой, то текущий элемент не будет упакован в B. k , если только он не помещается ни в одну из ячеек слева от него. Алгоритмы FF, BF и AWF удовлетворяют этому условию, а WF — нет. Джонсон доказал, что для любого алгоритма AAF A и любого α :
- В частности: .
Усовершенствованные алгоритмы
[ редактировать ]Лучшие коэффициенты аппроксимации возможны при использовании эвристики, отличной от AnyFit. Эти эвристики обычно содержат несколько классов открытых ячеек, посвященных предметам разных размеров (дополнительную информацию см. на связанных страницах):
- Усовершенствованная упаковка контейнеров по принципу «первая установка» (RFF) делит размеры предметов на четыре диапазона: , , , и . Аналогичным образом контейнеры делятся на четыре класса. Следующий пункт сначала присваивается соответствующему классу. Внутри этого класса он назначается ячейке с помощью first-fit . Обратите внимание, что этот алгоритм не является алгоритмом Any-Fit, поскольку он может открыть новую корзину, несмотря на то, что текущий элемент помещается в открытую корзину. Этот алгоритм был впервые представлен Эндрю Чи-Чи Яо, [ 15 ] который доказал, что он имеет гарантию аппроксимации и представил семейство списков с для .
- Гармоника-k разбивает интервал размеров основанный на Гармонической прогрессии в куски для и такой, что . Этот алгоритм был впервые описан Ли и Ли. [ 16 ] Имеет временную сложность и на каждом шаге имеется не более k открытых ячеек, которые потенциально можно использовать для размещения предметов, т. е. это алгоритм с k -ограниченным пространством. Для , его коэффициент аппроксимации удовлетворяет , и оно асимптотически тесно.
- Refined-harmonic сочетает в себе идеи из Harmonic-k с идеями из Refined-First-Fit . Он помещает элементы размером больше, чем аналогично методу Refined-First-Fit, тогда как более мелкие элементы размещаются с использованием Harmonic-k. Идея этой стратегии заключается в том, чтобы уменьшить количество огромных отходов в контейнерах, содержащих куски размером чуть больше . Этот алгоритм был впервые описан Ли и Ли. [ 16 ] Они доказали, что для он утверждает, что .
Общие нижние оценки для онлайн-алгоритмов
[ редактировать ]Их [ 15 ] доказал в 1980 году, что не может быть онлайн-алгоритма с асимптотическим коэффициентом конкуренции меньшим, чем . Коричневый [ 17 ] и Лян [ 18 ] улучшил эту границу до 1,536 35 . Впоследствии эта граница была улучшена до 1,540 14 . Влитом [ 19 ] В 2012 году эту нижнюю границу снова улучшили Бекеши и Галамбос. [ 20 ] к .
Сравнительная таблица
[ редактировать ]Алгоритм | Гарантия аппроксимации | Список худшего случая | Временная сложность |
---|---|---|---|
Следующий вариант (NF) | [ 11 ] | [ 11 ] | |
Первая установка (FF) | [ 13 ] | [ 13 ] | [ 11 ] |
Наиболее подходящий (BF) | [ 14 ] | [ 14 ] | [ 11 ] |
Наихудший вариант (WF) | [ 11 ] | [ 11 ] | [ 11 ] |
Почти наихудшее соответствие (AWF) | [ 11 ] | [ 11 ] | [ 11 ] |
«Уточненная первая установка» (RFF) | [ 15 ] | (для ) [ 15 ] | [ 15 ] |
Гармоника-к (Hk) | для [ 16 ] | [ 16 ] | [ 16 ] |
Утонченная гармоника (RH) | [ 16 ] | [ 16 ] | |
Модифицированная гармоника (MH) | [ 21 ] | ||
Модифицированная гармоника 2 (MH2) | [ 21 ] | ||
Гармоника + 1 (H+1) | [ 22 ] | ||
Гармоника++ (H++) | [ 22 ] | [ 22 ] |
Автономные алгоритмы
[ редактировать ]В автономной версии упаковки в корзины алгоритм может видеть все предметы, прежде чем начинать размещать их в корзинах. Это позволяет добиться улучшенных коэффициентов аппроксимации.
Мультипликативное приближение
[ редактировать ]Самый простой метод, используемый в схемах автономной аппроксимации, следующий:
- Упорядочение входного списка по убыванию размера;
- Запустите онлайн-алгоритм в упорядоченном списке.
Джонсон [ 11 ] доказал, что любая схема AnyFit A, которая работает со списком, упорядоченным по убыванию размера, имеет асимптотический коэффициент аппроксимации
.
Некоторые методы этого семейства (дополнительную информацию см. на связанных страницах):
- Функция First-Fit-Dereasing (FFD) упорядочивает элементы по убыванию размера, а затем вызывает First-Fit. Его коэффициент аппроксимации равен , а это туго. [ 23 ]
- Функция Next-Fit-Dereasing (NFD) упорядочивает элементы по убыванию размера, а затем вызывает Next-Fit . Его приблизительное соотношение в худшем случае чуть меньше 1,7. [ 24 ] Это также было проанализировано вероятностно. [ 25 ] Next-Fit упаковывает список и его инверсию в одинаковое количество ячеек. Таким образом, функция Next-Fit-Increasing имеет ту же производительность, что и Next-Fit-Decreasing. [ 26 ]
- Модифицированный метод уменьшения первого соответствия (MFFD) [ 27 ] , улучшает FFD для предметов размером более половины корзины за счет разделения предметов по размеру на четыре размера: большой, средний, маленький и крошечный, что соответствует предметам размером > 1/2 корзины, > 1/3 корзины, > 1/6 корзины. мусорное ведро и более мелкие предметы соответственно. Его гарантия аппроксимации равна . [ 28 ]
Фернандес де ла Вега и Люкер [ 29 ] представила PTAS для упаковки в мусорные контейнеры. Для каждого , их алгоритм находит решение размером не более и бежит во времени , где обозначает функцию, зависящую только от . Для этого алгоритма придумали метод адаптивного округления входных данных : входные числа группируются и округляются до значения максимума в каждой группе. В результате получается экземпляр с небольшим количеством разных размеров, который можно точно решить с помощью линейной программы конфигурации . [ 30 ]
Аддитивное приближение
[ редактировать ]находит Алгоритм упаковки контейнеров Кармаркара-Карпа решение с размером не более и работает за полиномиальное от n время (многочлен имеет высокую степень, не менее 8).
Ротвосс [ 31 ] представил алгоритм, который генерирует решение с не более чем контейнеры.
Хоберг и Ротвосс [ 32 ] улучшил этот алгоритм, чтобы генерировать решение с максимальным контейнеры. Алгоритм рандомизирован, а время его работы полиномиально от n .
Сравнительная таблица
[ редактировать ]Алгоритм | Гарантия аппроксимации | Худший случай |
---|---|---|
Уменьшение при первом приближении (FFD) | [ 23 ] | [ 23 ] |
Модифицированное уменьшение первого соответствия (MFFD) | [ 28 ] | [ 27 ] |
Кармаркар и Карп | [ 33 ] | |
Ротвосс | [ 31 ] | |
Хоберг и Ротвосс | [ 32 ] |
Точные алгоритмы
[ редактировать ]Мартелло и Тот [ 34 ] разработал точный алгоритм для одномерной задачи упаковки контейнеров, названный MTP. Более быстрая альтернатива - алгоритм Bin Completion, предложенный Корфом в 2002 году. [ 35 ] и позже улучшилось. [ 36 ]
Дальнейшее улучшение было представлено Шрайбером и Корфом в 2013 году. [ 37 ] Показано, что новый алгоритм Improved Bin Completion на пять порядков быстрее, чем Bin Completion, при решении нетривиальных задач со 100 элементами и превосходит алгоритм BCP (ветвь, разрезание и цена), разработанный Беловым и Шейтауэром на задачи, для которых оптимальным решением является менее 20 контейнеров. Какой алгоритм работает лучше всего, зависит от свойств задачи, таких как количество элементов, оптимальное количество ячеек, неиспользуемое пространство в оптимальном решении и точность значений.
Небольшое количество разных размеров
[ редактировать ]Особым случаем упаковки в контейнеры является ситуация, когда имеется небольшое количество d предметов разных размеров. Может быть много разных предметов каждого размера. Этот случай также называется упаковкой контейнеров с высокой кратностью , и он допускает более эффективные алгоритмы, чем общая задача.
Бин-упаковка с фрагментацией
[ редактировать ]Упаковка в корзину с фрагментацией или упаковка в корзину для фрагментируемых предметов — это вариант задачи об упаковке в корзину, в которой допускается разбивать предметы на части и помещать каждую часть отдельно в отдельный контейнер. Разбиение элементов на части может позволить улучшить общую производительность, например, свести к минимуму общее количество корзин. Более того, вычислительная задача поиска оптимального расписания может стать проще, поскольку некоторые переменные оптимизации становятся непрерывными. С другой стороны, разбирать предметы на части может оказаться дорогостоящим. Эту проблему впервые предложили Мандал, Чакрабари и Гхош. [ 38 ]
Варианты
[ редактировать ]Проблема имеет два основных варианта.
- В первом варианте, называемом бин-упаковкой с фрагментацией по увеличению размера ( BP-SIF ), каждый предмет может быть фрагментирован; служебные единицы добавляются к размеру каждого фрагмента.
- Во втором варианте, называемом бин-упаковкой с фрагментацией с сохранением размера ( BP-SPF ), каждый предмет имеет размер и стоимость; фрагментация предмета увеличивает его стоимость, но не меняет его размер.
Вычислительная сложность
[ редактировать ]Мандал, Чакрабари и Гхош [ 38 ] доказал, что BP-SPF является NP-жестким .
Менакерман и Ром [ 39 ] показали, что BP-SIF и BP-SPF являются сильно NP-жесткими . Несмотря на сложность, они представляют несколько алгоритмов и исследуют их работу. используются классические алгоритмы упаковки контейнеров, такие как уменьшение следующего и первого соответствия В их алгоритмах в качестве основы для своих алгоритмов .
Бертацци, Голден и Ван [ 40 ] представил вариант BP-SIF с Правило разделения: элемент можно разделить только одним способом в зависимости от его размера. Это полезно для решения задачи маршрутизации транспортных средств , например, . В своей статье они приводят оценку производительности варианта для наихудшего случая.
Шахнай, Тамир и Ехезкели [ 41 ] разработаны аппроксимационные схемы БП-СИФ и БП-СПФ; двойственный PTAS (PTAS для двойственной версии задачи), асимптотический PTAS, называемый APTAS, и двойственный асимптотический FPTAS, называемый AFPTAS, для обеих версий.
Плантатор [ 42 ] введён вариант БП-СПФ, в котором некоторые предметы конфликтуют, и запрещено упаковывать фрагменты конфликтных предметов в одну корзину. Они доказали, что и этот вариант NP-труден.
Кассацца и Чезелли [ 43 ] введен вариант без затрат и накладных расходов, а количество бункеров фиксировано. Однако количество фрагментаций должно быть сведено к минимуму. Они представляют алгоритмы математического программирования как для точных, так и для приближенных решений.
Связанные проблемы
[ редактировать ]Задачу о дробном ранце со штрафами предложили Малагути, Моначи, Паронуцци и Пферши. [ 44 ] Они разработали FPTAS и динамическую программу для решения этой проблемы, а также продемонстрировали обширное вычислительное исследование, сравнивающее производительность своих моделей. См. также: Дробное планирование заданий .
Производительность с делимыми размерами предметов
[ редактировать ]Важным частным случаем упаковки корзин является то, что размеры предметов образуют делимую последовательность (также называемую факторизованной ). Особый случай делимых размеров предметов возникает при распределении памяти в компьютерных системах, где все размеры предметов представляют собой степени 2. Если размеры предметов делятся, то некоторые эвристические алгоритмы упаковки корзин находят оптимальное решение. [ 45 ]
Ограничения мощности ячеек
[ редактировать ]Существует вариант упаковки контейнеров, в котором существуют ограничения на мощность контейнеров: каждый контейнер может содержать не более k элементов для некоторого фиксированного целого числа k .
- Краузе, Шен и Шветман [ 46 ] Представим эту задачу как вариант оптимального планирования заданий : компьютер имеет несколько k процессоров. Существует несколько n заданий, которые занимают единицу времени (1), но имеют разные требования к памяти. Каждая единица времени считается отдельным интервалом. Цель состоит в том, чтобы использовать как можно меньше контейнеров (=единиц времени), гарантируя при этом, что в каждом контейнере выполняется не более k заданий. Они представляют несколько эвристических алгоритмов, которые находят решение не более чем за контейнеры.
- Келлерер и Пферши [ 47 ] представить алгоритм во время выполнения , который находит решение с не более чем контейнеры. Их алгоритм выполняет двоичный поиск OPT. Для каждого искомого значения m он пытается упаковать предметы в 3 м /2. контейнеры размером
Неаддитивные функции
[ редактировать ]Существуют различные способы расширения модели упаковки контейнеров для более общих функций затрат и нагрузки:
- Анилий, Брамель и Симчи-Леви [ 48 ] изучите ситуацию, в которой стоимость корзины является вогнутой функцией количества предметов в корзине. Целью является минимизация общей стоимости, а не количества контейнеров. Они показывают, что упаковка контейнеров с увеличением следующего соответствия достигает абсолютного коэффициента аппроксимации наихудшего случая не более 7/4 и асимптотического коэффициента наихудшего случая 1,691 для любой вогнутой и монотонной функции стоимости.
- Коэн, Келлер, Миррокни и Задимогаддам [ 49 ] изучите обстановку, в которой размер предметов заранее не известен, но является случайной величиной . Это особенно распространено в средах облачных вычислений . Несмотря на то, что существует верхний предел объема ресурсов, необходимых определенному пользователю, большинство пользователей используют гораздо меньше емкости. Таким образом, облачный менеджер может много выиграть от небольшого превышения обязательств . Это приводит к варианту упаковки контейнеров со случайными ограничениями : вероятность того, что сумма размеров в каждом контейнере не превышает B, должна быть не меньше p , где p — фиксированная константа (стандартная упаковка контейнеров соответствует p = 1). Они показывают, что при мягких предположениях эта проблема эквивалентна задаче об упаковке субмодульной корзины , в которой «нагрузка» в каждой корзине равна не сумме предметов, а некоторой субмодульной функции . ее
Связанные проблемы
[ редактировать ]В задаче об упаковке контейнеров размер контейнеров фиксирован, а их количество можно увеличить (но оно должно быть как можно меньшим).
Напротив, в многостороннего разделения чисел задаче количество ячеек фиксировано, а их размер может быть увеличен. Цель состоит в том, чтобы найти раздел, в котором размеры ячеек будут как можно более равными (в варианте, называемом многопроцессорного планирования проблемой или проблемой минимального времени обработки , цель состоит в том, чтобы минимизировать размер наибольшего контейнера).
В задаче об обратной упаковке контейнеров : [ 50 ] и количество корзин, и их размеры фиксированы, но размеры предметов можно изменить. Цель состоит в том, чтобы добиться минимального отклонения вектора размера предмета, чтобы все предметы можно было упаковать в заданное количество контейнеров.
В задаче об упаковке контейнера с максимальным количеством ресурсов : [ 51 ] цель состоит в том, чтобы максимизировать количество используемых ячеек так, чтобы при некотором упорядочении ячеек ни один предмет из более поздней ячейки не помещался в более раннюю корзину. В двойной задаче количество корзин фиксировано, и цель состоит в том, чтобы минимизировать общее количество или общий размер предметов, помещенных в корзины, так, чтобы ни один оставшийся предмет не помещался в незаполненную корзину.
В задаче покрытия ячеек размер ячейки ограничен снизу : цель состоит в том, чтобы максимизировать количество используемых ячеек так, чтобы общий размер в каждой ячейке был не ниже заданного порога.
В задаче справедливого неделимого распределения обязанностей (вариант справедливого распределения элементов ) элементы представляют собой работу по дому, и есть разные люди, каждый из которых приписывает каждой работе разное значение сложности. Цель состоит в том, чтобы распределить для каждого человека набор обязанностей с верхней границей общего значения сложности (таким образом, каждый человек соответствует корзине). В этой задаче также используются многие методы упаковки в контейнеры. [ 52 ]
В задаче гильотинной резки и предметы, и «корзины» представляют собой двумерные прямоугольники, а не одномерные числа, и предметы необходимо вырезать из корзины, используя сквозные разрезы.
В задаче об эгоистичной упаковке мусора каждый предмет — это игрок, который хочет минимизировать его стоимость. [ 53 ]
Существует также вариант упаковки в контейнеры, при котором стоимость, которую следует минимизировать, представляет собой не количество контейнеров, а некоторую вогнутую функцию количества предметов в каждом контейнере. [ 48 ]
Другие варианты — двухмерная упаковка в контейнер, [ 54 ] трехмерная упаковка контейнера , [ 55 ] контейнерная упаковка с доставкой , [ 56 ]
Ресурсы
[ редактировать ]- BPPLIB — библиотека опросов, кодов, тестов, генераторов, решателей и библиографии.
Ссылки
[ редактировать ]- ^ Мартелло, Сильвано; Тот, Паоло (1990), «Проблема упаковки контейнеров» (PDF) , Проблемы с рюкзаком: алгоритмы и компьютерные реализации , Чичестер, Великобритания: John Wiley and Sons, ISBN 0471924202
- ^ Корте, Бернхард; Виген, Йенс (2006). «Бин-упаковка» . Комбинаторная оптимизация: теория и алгоритмы . Алгоритмы и комбинаторика 21. Спрингер. стр. 426–441. дои : 10.1007/3-540-29297-7_18 . ISBN 978-3-540-25684-7 .
- ^ Баррингтон, Дэвид Микс (2006). «Бин-упаковка» . Архивировано из оригинала 16 февраля 2019 г. Проверено 27 февраля 2016 г.
- ^ Jump up to: а б с Коффман-младший, Эдвард Г.; Чирик, Янош; Галамбос, Габор; Мартелло, Сильвано; Виго, Даниэле (2013), Пардалос, Панос М.; Черный, Дин-Чжу; Грэм, Рональд Л. (ред.), «Алгоритмы аппроксимации упаковки контейнеров: обзор и классификация» , Справочник по комбинаторной оптимизации , Нью-Йорк, Нью-Йорк: Springer, стр. 455–531, номер домена : 10.1007/978-1-4419-7997-1_35 , ISBN. 978-1-4419-7997-1 , получено 8 августа 2021 г.
- ^ «DHCPv6-PD — Первые шаги» . Проверено 12 июня 2024 г.
- ^ Льюис, Р. (2009), «Универсальный метод восхождения на холм для решения задач минимальной группировки, не зависящих от порядка: пример раскраски графов и упаковки ячеек» (PDF) , Computers and Operations Research , 36 (7): 2295– 2310, номер документа : 10.1016/j.cor.2008.09.004 , S2CID 1577334
- ^ Синделар, Майкл; Ситараман, Рамеш ; Шеной, Прашант (2011), «Алгоритмы совместного использования для колокации виртуальных машин» (PDF) , Материалы 23-го симпозиума ACM по параллелизму в алгоритмах и архитектурах (SPAA), Сан-Хосе, Калифорния, июнь 2011 г .: 367–378
- ^ Jump up to: а б с Гэри, MR ; Джонсон, Д.С. (1979). Виктор Клее (ред.). Компьютеры и трудноразрешимые проблемы: Руководство по теории NP-полноты . Серия книг по математическим наукам. Сан-Франциско, Калифорния: WH Freeman and Co., стр. x+338 . ISBN 0-7167-1045-5 . МР 0519066 .
- ^ Мартелло и Тот 1990 , с. 221
- ^ Vazirani, Vijay V. (14 March 2013). Approximation Algorithms . Springer Berlin Heidelberg. p. 74. ISBN 978-3662045657 .
- ^ Jump up to: а б с д и ж г час я дж к л м н тот п Джонсон, Дэвид С. (1973). «Почти оптимальные алгоритмы упаковки контейнеров» (PDF) . Массачусетский технологический институт .
- ^ Гонсалес, Теофило Ф. (23 мая 2018 г.). Справочник по аппроксимационным алгоритмам и метаэвристике. Том 2 Современные и новые приложения . Тейлор и Фрэнсис Инкорпорейтед. ISBN 9781498770156 .
- ^ Jump up to: а б с Доса, Дьёрдь; Сгалл, Иржи (2013). «Упаковка контейнера с первой подгонкой: тщательный анализ» . 30-й Международный симпозиум по теоретическим аспектам информатики (STACS 2013) . 20 . Замок Дагштуль – Центр информатики Лейбница: 538–549. дои : 10.4230/LIPIcs.STACS.2013.538 .
- ^ Jump up to: а б с Дьёрдь, Доса; Сгалл, Иржи (2014). «Оптимальный анализ наиболее подходящей упаковки в контейнеры». Автоматы, языки и программирование . Конспекты лекций по информатике. Том. 8572. стр. 429–441. дои : 10.1007/978-3-662-43948-7_36 . ISBN 978-3-662-43947-0 .
{{cite book}}
:|journal=
игнорируется ( помогите ) - ^ Jump up to: а б с д и Яо, Эндрю Чи-Чи (апрель 1980 г.). «Новые алгоритмы упаковки контейнеров» . Журнал АКМ . 27 (2): 207–227. дои : 10.1145/322186.322187 . S2CID 7903339 .
- ^ Jump up to: а б с д и ж г Ли, CC; Ли, DT (июль 1985 г.). «Простой онлайн-алгоритм упаковки в корзину» . Журнал АКМ . 32 (3): 562–572. дои : 10.1145/3828.3833 . S2CID 15441740 .
- ^ Донна Дж, Браун (1979). «Нижняя граница для онлайн-алгоритмов упаковки одномерных контейнеров» (PDF) . Технический представитель . Архивировано (PDF) из оригинала 17 марта 2022 г.
- ^ Лян, Фрэнк М. (1980). «Нижняя граница для упаковки контейнеров в режиме онлайн». Письма об обработке информации . 10 (2): 76–79. дои : 10.1016/S0020-0190(80)90077-0 .
- ^ ван Влит, Андре (1992). «Улучшенная нижняя граница для алгоритмов упаковки контейнеров в режиме онлайн». Письма об обработке информации . 43 (5): 277–284. дои : 10.1016/0020-0190(92)90223-I .
- ^ Балог, Янош; Бекеши, Йожеф; Галамбос, Габор (июль 2012 г.). «Новые нижние оценки для некоторых классов алгоритмов упаковки контейнеров» . Теоретическая информатика . 440–441: 1–13. дои : 10.1016/j.tcs.2012.04.017 .
- ^ Jump up to: а б Раманан, Пракаш; Браун, Донна Дж; Ли, CC; Ли, DT (сентябрь 1989 г.). «Онлайн-упаковка контейнеров в линейное время». Журнал алгоритмов . 10 (3): 305–326. дои : 10.1016/0196-6774(89)90031-X . hdl : 2142/74206 .
- ^ Jump up to: а б с Сейден, Стивен С. (2002). «О проблеме онлайн-упаковки корзин». Журнал АКМ . 49 (5): 640–671. дои : 10.1145/585265.585269 . S2CID 14164016 .
- ^ Jump up to: а б с Доса, Дьёрдь (2007). «Точная граница алгоритма упаковки контейнеров с уменьшением первого соответствия равна FFD(I) ≤ 11/9\mathrm{OPT}(I) + 6/9». Комбинаторика, алгоритмы, вероятностные и экспериментальные методологии. ПОБЕГ . дои : 10.1007/978-3-540-74450-4_1 .
- ^ Бейкер, бакалавр наук; Коффман-младший, Э.Г. (1 июня 1981 г.). «Точная асимптотическая граница для следующей подходящей убывающей упаковки в контейнерах» . SIAM Journal по алгебраическим и дискретным методам . 2 (2): 147–152. дои : 10.1137/0602019 . ISSN 0196-5212 .
{{cite journal}}
: CS1 maint: несколько имен: список авторов ( ссылка ) - ^ Цирик, Дж.; Галамбос, Г.; Фрэнк, JBG; Фриз, AM; Риннуй Кан, AHG (1 ноября 1986 г.). «Вероятностный анализ следующей эвристики упаковки контейнеров, уменьшающей соответствие» . Письма об исследованиях операций . 5 (5): 233–236. дои : 10.1016/0167-6377(86)90013-1 . hdl : 1765/11645 . ISSN 0167-6377 . S2CID 50663185 .
- ^ Фишер, Дэвид К. (1 декабря 1988 г.). «Next-fit упаковывает список и его обратную сторону в одинаковое количество ячеек» . Письма об исследованиях операций . 7 (6): 291–293. дои : 10.1016/0167-6377(88)90060-0 . ISSN 0167-6377 .
- ^ Jump up to: а б Джонсон, Дэвид С; Гэри, Майкл Р. (октябрь 1985 г.). «Теорема 7160 для упаковки контейнеров» . Журнал сложности . 1 (1): 65–106. дои : 10.1016/0885-064X(85)90022-6 .
- ^ Jump up to: а б Юэ, Миньи; Чжан, Лей (июль 1995 г.). «Простое доказательство неравенства MFFD(L) ≤ 71/60 OPT(L) + 1,L для алгоритма упаковки контейнеров MFFD». Acta Mathematicae Applicatae Sinica . 11 (3): 318–330. дои : 10.1007/BF02011198 . S2CID 118263129 .
- ^ Фернандес де ла Вега, В.; Люкер, Г.С. (1981). «Упаковку контейнеров можно решить за 1 + ε за линейное время». Комбинаторика . 1 (4): 349–355. дои : 10.1007/BF02579456 . ISSN 1439-6912 . S2CID 10519631 .
- ^ Клэр Матье. «Алгоритмы аппроксимации. Часть I, неделя 3: упаковка контейнеров» . Курсера . Архивировано из оригинала 15 июля 2021 г.
- ^ Jump up to: а б Ротвосс, Т. (1 октября 2013 г.). «Аппроксимация упаковки ячеек в ячейки O(log OPT · Log Log OPT)» . 54-й ежегодный симпозиум IEEE по основам информатики , 2013 г. стр. 20–29. arXiv : 1301.4010 . дои : 10.1109/FOCS.2013.11 . ISBN 978-0-7695-5135-7 . S2CID 15905063 .
- ^ Jump up to: а б Хоберг, Ребекка; Ротвосс, Томас (01 января 2017 г.), «Логарифмический аддитивный разрыв целостности для упаковки контейнеров», Труды ежегодного симпозиума ACM-SIAM 2017 г. по дискретным алгоритмам , Труды Общества промышленной и прикладной математики, стр. 2616–2625, arXiv : 1503.08796 , doi : 10.1137/1.9781611974782.172 , ISBN 978-1-61197-478-2 , S2CID 1647463
- ^ Кармаркар, Нарендра; Карп, Ричард М. (ноябрь 1982 г.). «Эффективная аппроксимационная схема одномерной задачи упаковки контейнеров» . 23-й ежегодный симпозиум по основам информатики (SFCS 1982) : 312–320. дои : 10.1109/SFCS.1982.61 . S2CID 18583908 .
- ^ Мартелло и Тот 1990 , стр. 237–240.
- ^ Корф, Ричард Э. (2002). Новый алгоритм оптимальной упаковки контейнеров (PDF) . АААИ-02.
- ^ RE Korf (2003), Улучшенный алгоритм оптимальной упаковки контейнеров . Материалы Международной совместной конференции по искусственному интеллекту (стр. 1252–1258).
- ^ Шрайбер, Итан Л.; Корф, Ричард Э. (2013), «Улучшенное заполнение бинов для оптимальной упаковки бинов и разделения номеров» (PDF) , Материалы двадцать третьей международной совместной конференции по искусственному интеллекту , IJCAI '13, Пекин, Китай: AAAI Press, стр. 651–658, ISBN . 978-1-57735-633-2
- ^ Jump up to: а б Мандал, Калифорния; Чакрабарти, ПП; Гоуз, С. (1 июня 1998 г.). «Сложность упаковки фрагментируемых объектов и применение» . Компьютеры и математика с приложениями . 35 (11): 91–97. дои : 10.1016/S0898-1221(98)00087-X . ISSN 0898-1221 .
- ^ Нир Менакерман и Рафаэль Ром «Упаковка мусорного ведра с фрагментацией предметов». Алгоритмы и структуры данных, 7-й международный семинар, WADS 2001, Провиденс, Род-Айленд, США, 8-10 августа 2001 г., Материалы.
- ^ Бертацци, Лука; Голден, Брюс; Ван, Синъинь (31 мая 2019 г.). «Проблема упаковки контейнеров с фрагментацией предметов: анализ наихудшего случая» . Дискретная прикладная математика . Встреча GO X, Риги Кальтбад (Швейцария), 10–14 июля 2016 г. 261 : 63–77. дои : 10.1016/j.dam.2018.08.023 . ISSN 0166-218X . S2CID 125361557 .
- ^ Шахнай, Хадас; Тамир, Тами; Йехезкели, Омер (2006). «Аппроксимационные схемы упаковки с фрагментацией изделий» . В Эрлебахе, Томас; Персинао, Джузеппе (ред.). Приближение и онлайн-алгоритмы . Конспекты лекций по информатике. Том. 3879. Берлин, Гейдельберг: Springer. стр. 334–347. дои : 10.1007/11671411_26 . ISBN 978-3-540-32208-5 .
- ^ Экичи, Али (01 февраля 2021 г.). «Проблема упаковки корзин с конфликтами и фрагментацией предметов» . Компьютеры и исследования операций . 126 : 105113. doi : 10.1016/j.cor.2020.105113 . ISSN 0305-0548 . S2CID 225002556 .
- ^ Касацца, Марко; Чезелли, Альберто (01 июня 2014 г.). «Алгоритмы математического программирования для задач упаковки корзин с фрагментацией предметов» . Компьютеры и исследования операций . 46 : 1–11. дои : 10.1016/j.cor.2013.12.008 . ISSN 0305-0548 .
- ^ Малагути, Энрико; Моначи, Мишель; Паронуцци, Паоло; Пферши, Ульрих (16 марта 2019 г.). «Целочисленная оптимизация с дробными значениями со штрафом: случай с рюкзаком» . Европейский журнал операционных исследований . 273 (3): 874–888. дои : 10.1016/j.ejor.2018.09.020 . hdl : 11585/657029 . ISSN 0377-2217 . S2CID 31722681 .
- ^ Коффман, Э.Г.; Гэри, MR; Джонсон, Д.С. (1 декабря 1987 г.). «Корзинная упаковка с предметами, делящимися по размеру» . Журнал сложности . 3 (4): 406–428. дои : 10.1016/0885-064X(87)90009-4 . ISSN 0885-064X .
- ^ Краузе, КЛ; Шен, В.Я.; Шветман, HD (1 октября 1975 г.). «Анализ нескольких алгоритмов планирования задач для модели мультипрограммных компьютерных систем» . Журнал АКМ . 22 (4): 522–550. дои : 10.1145/321906.321917 . ISSN 0004-5411 . S2CID 10214857 .
- ^ Келлерер, Х.; Пферши, У. (1 января 1999 г.). «Проблемы упаковки контейнеров с ограничением по мощности» . Анналы исследования операций . 92 : 335–348. дои : 10.1023/А:1018947117526 . ISSN 1572-9338 . S2CID 28963291 .
- ^ Jump up to: а б Анили, Шошана; Брамель, Жюльен; Симчи-Леви, Дэвид (1 апреля 1994 г.). «Эвристический анализ наихудшего случая для задачи упаковки контейнеров с общей структурой затрат» . Исследование операций . 42 (2): 287–298. дои : 10.1287/опре.42.2.287 . ISSN 0030-364X .
- ^ Коэн, Максим К.; Келлер, Филипп В.; Миррокни, Вахаб; Задимогадам, Мортеза (01 июля 2019 г.). «Чрезмерные обязательства в сфере облачных сервисов: упаковка контейнеров с учетом случайных ограничений» . Наука управления . 65 (7): 3255–3271. arXiv : 1705.09335 . дои : 10.1287/mnsc.2018.3091 . ISSN 0025-1909 . S2CID 159270392 .
- ^ Чунг, Ерим; Пак, Мён Джу (01 января 2015 г.). «Заметки о задачах обратной упаковки в контейнеры» . Письма об обработке информации . 115 (1): 60–68. дои : 10.1016/j.ipl.2014.09.005 . ISSN 0020-0190 .
- ^ Бояр, Жанна ; Эпштейн, Лия; Фаврхольдт, Лене М.; Корт, Йенс С.; Ларсен, Ким С.; Педерсен, Мортен М.; Вёлк, Санне (11 октября 2006 г.). «Проблема упаковки бункера с максимальным ресурсом» . Теоретическая информатика . 362 (1): 127–139. дои : 10.1016/j.tcs.2006.06.001 . ISSN 0304-3975 .
- ^ Хуан, Синь; Лу, Пиньян (10 ноября 2020 г.). «Алгоритмическая основа для приближенного распределения долей по дому». arXiv : 1907.04505 [ cs.GT ].
- ^ Ма, Жуйсинь; Доса, Дьёрдь; Хан, Синь; Тинг, Хин-Фунг; Да, Деши; Чжан, Юн (01 августа 2013 г.). «Заметка об эгоистичной проблеме упаковки мусора» . Журнал глобальной оптимизации . 56 (4): 1457–1462. дои : 10.1007/s10898-012-9856-9 . ISSN 0925-5001 . S2CID 3082040 .
- ^ Лоди А., Мартелло С., Моначи, М., Виго, Д. (2010) «Проблемы упаковки двумерных контейнеров». В В.Т. Пашос (ред.), «Парадигмы комбинаторной оптимизации» , Wiley/ISTE, стр. 107–129.
- ^ Оптимизация трехмерной упаковки в контейнеры посредством моделирования
- ^ Бенко А., Доса Г., Туза З. (2010) « Упаковка/покрытие контейнеров с доставкой, решение с помощью эволюции алгоритмов », Труды 2010 5-й Международной конференции IEEE по биовычислениям: теории и приложения, BIC-TA 2010 г. , ст. нет. 5645312, стр. 298–302.