QpmtnCmax — различия между версиями
(→Алгоритм построения расписания) |
(→Алгоритм построения расписания) |
||
| Строка 29: | Строка 29: | ||
Будем назвать Level-ом работы <tex> p_i(t) </tex> - невыполненную часть работы <tex> p_i </tex> в момент времени <tex> t </tex> | Будем назвать Level-ом работы <tex> p_i(t) </tex> - невыполненную часть работы <tex> p_i </tex> в момент времени <tex> t </tex> | ||
| − | Далее построим расписание, которое достигает нашей оценки <tex>w</tex>, с помощью Level-алгоритма. | + | Далее построим расписание, которое достигает нашей оценки <tex>w</tex>, с помощью <tex>Level</tex>-алгоритма. |
| − | Level - алгоритм: | + | <tex>Level</tex> - алгоритм: |
<tex>t \leftarrow 0 </tex> | <tex>t \leftarrow 0 </tex> | ||
| Строка 43: | Строка 43: | ||
Функция <tex>Assign(t)</tex>: | Функция <tex>Assign(t)</tex>: | ||
| − | <tex>J </tex> - множество работ с положительным level | + | <tex>J </tex> - множество работ с положительным <tex>level</tex> |
<tex>M = \{M_1,...,M_m\}</tex> - множество всех станков | <tex>M = \{M_1,...,M_m\}</tex> - множество всех станков | ||
'''WHILE''' (множества <tex>J</tex> и <tex>M</tex> не пустые) | '''WHILE''' (множества <tex>J</tex> и <tex>M</tex> не пустые) | ||
Версия 17:30, 22 июня 2012
Содержание
Постановка задачи
Есть несколько станков с разной скоростью выполнения работ. Работу на каждом из станков можно прервать и продолжить позже.
Цель - выполнить все как можно быстрее.
1. Найдем нижнюю границу времени выполнения.
2. Составим оптимальное расписание.
Алгоритм построения расписания
Где ; ; - вес -ой работы ; - скорость работы -oй машины ;
Необходимое условие для выполнения всех работ в интервале :
или
Нижняя граница :
Будем назвать Level-ом работы - невыполненную часть работы в момент времени
Далее построим расписание, которое достигает нашей оценки , с помощью -алгоритма.
- алгоритм:
WHILE существуют работы с положительным level Assign(t) находим следующую выполненную работу,где - время ее окончания найти минимальное . Для которого выполняется для некоторых работ , : и //поиск следующего момента времени ,в который нужно будет перераспределить машины/работы Построение расписания
Функция :
- множество работ с положительным - множество всех станков WHILE (множества и не пустые) Найти множество работ подмножество ,level которых максимальный (||,||) Назначаем работы из множества на самых быстрых машин из множества \ удаляем из мн-ва самых быстрых машин
Доказательство корректности алгоритма
Так как нижняя граница :
то достаточно показать, что составленное расписание достигает этой оценки.
Будем считать, что в начале алгоритма мы имеем . Это утверждение не меняется на протяжении всего выполнения алгоритма, для любого момента времени. Получаем: . Докажем что алгоритм составляет расписание в соответствии с этим свойством. Чтобы доказать этот факт, будем считать что в любой момент времени T нет простоев машин, когда есть хотя бы одна невыполненная работа. Получаем:
или
Таким образом необходимая оценка достигается нашим алгоритмом.
Допустим хотя бы одна машина простаивает, в момент когда есть невыполненные работы, мы имеем следующее неравенство для времен окончания работ на станках :
В этом случае, если для некоторого , Level последней работы выполнявшейся на станке равен . Где достаточно мал, и меньше чем Level последней работы на станке . Пришли к противоречию.
Пример
Пусть у нас есть 6 работ и 3 станка. Покажем работу алгоритма для данного случая.
В начальный момент времени начинаем обрабатывать работы с наибольшим временем выполнения на станках соответственно. В момент времени 1-ой работы и 2-ой работы совпадает. С этого момента начинаем обрабатывать работы синхронно на станках: . В момент времени работа опускается до уровня работы .Работы выполняем одновременно на одном станке . В момент времени начинаем выполнять первые четыре работы на всех станках одновременно, далее просто добавятся работы и все работы закончатся одновременно.
Время работы
Level-алгоритм вызывает функцию Assign(t) в самом худшем случае раз. Функция Assign(t) выполняется за . Итоговое время работы .
Литература
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 379 стр. — ISBN 978-3-540-69515-8