QpmtnCmax — различия между версиями
(→Алгоритм построения расписания) |
(→Алгоритм построения расписания) |
||
| Строка 25: | Строка 25: | ||
Нижняя граница <tex>C_{max}</tex> : | Нижняя граница <tex>C_{max}</tex> : | ||
| − | <tex>w = max</tex>{<tex>max\limits_{j=1}^{m-1} P_i/S_j, P_n/S_m</tex>} | + | <tex>w = \max</tex>{<tex>\max\limits_{j=1}^{m-1} P_i/S_j, P_n/S_m</tex>} |
Далее построим расписание, которое достигает нашей оценки w, с помощью Level-алгоритма. | Далее построим расписание, которое достигает нашей оценки w, с помощью Level-алгоритма. | ||
Версия 15:23, 25 мая 2012
Содержание
Постановка задачи
Есть несколько станков с разной скоростью выполнения работ. Работу на каждом из станков можно прервать и продолжить позже.
Цель - выполнить все как можно быстрее.
1. Найдем нижнюю границу времени выполнения.
2. Составим оптимальное расписание.
Алгоритм построения расписания
Где ; ; ;
Необходимое условие для выполнения всех работ в интервале :
или
Нижняя граница :
{}
Далее построим расписание, которое достигает нашей оценки w, с помощью Level-алгоритма.
Level - алгоритм:
WHILE существуют работы с положительным lvl Assign(t) работа выполненная в момент времени && Построение расписания
Функция :
{} {} WHILE ( != 0 && != 0) Найти множество работ подмножество ,lvl которых максимальный (||,||) Назначаем работы из мн-ва на самых быстрых машин из мн-ва \ удаляем из мн-ва самых быстрых машин
Пример
Пусть у нас есть 5 работ и 4 станка. Покажем работу алгоритма для данного случая.
В начальный момент времени начинаем обрабатывать работы с наибольшим временем выполнения на станках соответственно. В момент времени 4-ой работы опускается до времени выполнения 5-ой работы. С этого момента начинаем обрабатывать работы на одном станке: . В момент времени происходит похожая ситуация. С этого момента времени работы выполняются синхронно на двух станках . Далее работы не пересекаются друг с другом и каждая заканчивается на ранее выделенных им станках.
Время работы
Level-алгоритм вызывает функцию Assign(t) в самом худшем случае раз. Функция Assign(t) выполняется за . Итоговое время работы .
Литература
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 379 стр. — ISBN 978-3-540-69515-8