QpmtnCmax — различия между версиями
(→Описание алгоритма) |
|||
Строка 15: | Строка 15: | ||
<tex>i = 1 \ldots n</tex>, <tex>j = 1 \ldots m</tex>, <tex> p_i </tex> {{---}} время выполнения <tex>i</tex>-ой работы, <tex> s_j</tex> {{---}} скорость работы <tex> j </tex>-oй машины. | <tex>i = 1 \ldots n</tex>, <tex>j = 1 \ldots m</tex>, <tex> p_i </tex> {{---}} время выполнения <tex>i</tex>-ой работы, <tex> s_j</tex> {{---}} скорость работы <tex> j </tex>-oй машины. | ||
− | Необходимое условие для выполнения всех работ в интервале <tex>[0 | + | Необходимое условие для выполнения всех работ в интервале <tex>[0 \ldots T]</tex>: |
<tex> P_n = p_1 + \ldots + p_n \leqslant s_1T + \ldots + s_mT = S_mT</tex> или <tex>P_n/S_m \leqslant T</tex> | <tex> P_n = p_1 + \ldots + p_n \leqslant s_1T + \ldots + s_mT = S_mT</tex> или <tex>P_n/S_m \leqslant T</tex> | ||
Строка 26: | Строка 26: | ||
</tex> | </tex> | ||
− | Перейдем к описанию алгоритма. Будем назвать <tex>\mathrm{level}</tex>-ом работы <tex> p_i(t) </tex> | + | Перейдем к описанию алгоритма. Будем назвать <tex>\mathrm{level}</tex>-ом работы <tex> p_i(t) </tex> невыполненную часть работы <tex> p_i </tex> в момент времени <tex> t </tex> |
Далее построим расписание, которое достигает нашей оценки <tex>C_{max}</tex>, с помощью <tex>\mathrm{level}</tex>-алгоритма. | Далее построим расписание, которое достигает нашей оценки <tex>C_{max}</tex>, с помощью <tex>\mathrm{level}</tex>-алгоритма. |
Версия 22:16, 7 июня 2016
Задача: |
Дано несколько станков с разной скоростью выполнения работ, работающих параллельно. Работа может быть прервана в любой момент и продолжена позже на любой машине. Необходимо минимизировать время выполнения всех работ. |
Содержание
Алгоритм построения расписания
Описание алгоритма
Пусть нам даны
работ и станков. Перед выполнением алгоритма, упорядочим все работы по убыванию их времени выполнения: , а все машины в порядке убывания скоростей: . Введем следующие обозначения:
, , — время выполнения -ой работы, — скорость работы -oй машины.
Необходимое условие для выполнения всех работ в интервале
:или
Кроме того, должно выполняться условие
для всех , так как это нижняя оценка времени выполнения работ . Исходя из этого получаем нижнюю границу :
Перейдем к описанию алгоритма. Будем назвать
-ом работы невыполненную часть работы в момент времениДалее построим расписание, которое достигает нашей оценки
, с помощью -алгоритма.Псевдокод
Функция
:function level(): intwhile assign(t) int and int and , and , // поиск следующего момента времени, в который нужно будет перераспределить машины/работы Построение расписания
Функция
:function assign (: int): // множество работ с положительным level // множество всех станков while or int // максимальное значение level из J int // количество работ с level = maxLevel int , работ из самых быстрых машин из Распределяем работы
Асимптотика
-алгоритм вызывает функцию в самом худшем случае раз. Функция выполняется за . Итоговое время работы .
Доказательство корректности алгоритма
Теорема: |
Расписание, построенное данным алгоритмом, является корректным и оптимальным. |
Доказательство: |
Так как нижняя граница :
то достаточно показать, что составленное расписание достигает этой оценки. Будем считать, что в начале алгоритма все работы упорядочены, как было сказано ранее: . Это утверждение не меняется на протяжении всего выполнения алгоритма, для любого момента времени. Получаем: . Докажем что алгоритм составляет расписание в соответствии с этим свойством. Чтобы доказать этот факт, будем считать что в любой момент времени нет простоев машин, когда есть хотя бы одна невыполненная работа. Получаем:или Таким образом необходимая оценка достигается нашим алгоритмом. Допустим хотя бы одна машина простаивает, в момент когда есть невыполненные работы, получим следующее неравенство для времен окончания работ (обозначим далее как ) на станках , пронумерованных по убыванию скоростей:
Докажем написанное выше неравенство: Предположим, что Пусть для некоторого . Тогда последней работы, выполнявшейся на станке в момент времени (где достаточно мал) меньше, чем последней работы на станке . Пришли к противоречию, так как при распределении, работы с наибольшим выставлялись на самые быстрые станки. = ,где . Чтобы работы завершились в момент времени , необходимо начать их в момент времени 0, поскольку если это не выполняется, то у нас найдется работа , которая начинается позже и заканчивается в . Это означает, что в момент времени начинаются как минимум работ. Пусть первые работ стартовали вместе на всех машинах. Мы получаем , из чего следует, что для любого , удовлетворяющего условию . Таким образом, до момента времени нет простаивающих машин. Пришли к противоречию. Получаем . |
Пример
Пусть у нас есть
работ и станка. Покажем работу алгоритма для данного случая.В начальный момент времени начинаем обрабатывать работы с наибольшим временем выполнения
, и на станках , и соответственно. В момент времени -ой работы и -ой работы совпадает. С этого момента начинаем обрабатывать работы и синхронно на станках: и . В момент времени работа опускается до уровня работы .Работы и выполняем одновременно на одном станке . В момент времени начинаем выполнять первые четыре работы на всех станках одновременно, далее просто добавятся работы и , и все работы закончатся одновременно.См. также
Источники информации
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 124 — 129 стр. — ISBN 978-3-540-69515-8