QpmtnCmax — различия между версиями
(→Алгоритм построения расписания) |
(→Алгоритм построения расписания) |
||
Строка 32: | Строка 32: | ||
<tex>t \leftarrow 0 </tex> | <tex>t \leftarrow 0 </tex> | ||
− | '''WHILE''' существуют работы с положительным | + | '''WHILE''' существуют работы с положительным level |
Assign(t) | Assign(t) | ||
<tex>t1 \leftarrow min(s>t |</tex>работа выполненная в момент времени <tex> s)</tex> | <tex>t1 \leftarrow min(s>t |</tex>работа выполненная в момент времени <tex> s)</tex> | ||
Строка 44: | Строка 44: | ||
<tex>M = </tex>{<tex>M_1,...,M_m</tex>} | <tex>M = </tex>{<tex>M_1,...,M_m</tex>} | ||
'''WHILE''' (<tex>J</tex> != 0 && <tex>M</tex> != 0) | '''WHILE''' (<tex>J</tex> != 0 && <tex>M</tex> != 0) | ||
− | Найти множество работ <tex>I</tex> подмножество <tex>J</tex> , | + | Найти множество работ <tex>I</tex> подмножество <tex>J</tex> ,level которых максимальный |
<tex>r \leftarrow min</tex>(|<tex>M</tex>|,|<tex>I</tex>|) | <tex>r \leftarrow min</tex>(|<tex>M</tex>|,|<tex>I</tex>|) | ||
Назначаем работы из мн-ва <tex>I</tex> на <tex>r</tex> самых быстрых машин из мн-ва <tex>M</tex> | Назначаем работы из мн-ва <tex>I</tex> на <tex>r</tex> самых быстрых машин из мн-ва <tex>M</tex> |
Версия 11:45, 9 июня 2012
Эта статья находится в разработке!
Содержание
Постановка задачи
Есть несколько станков с разной скоростью выполнения работ. Работу на каждом из станков можно прервать и продолжить позже.
Цель - выполнить все как можно быстрее.
1. Найдем нижнюю границу времени выполнения.
2. Составим оптимальное расписание.
Алгоритм построения расписания
Где
; ; ;Необходимое условие для выполнения всех работ в интервале
:или
Нижняя граница
:{ }
Далее построим расписание, которое достигает нашей оценки
, с помощью Level-алгоритма.Level - алгоритм:
WHILE существуют работы с положительным level Assign(t) работа выполненная в момент времени && Построение расписания
Функция
:{ } { } WHILE ( != 0 && != 0) Найти множество работ подмножество ,level которых максимальный (| |,| |) Назначаем работы из мн-ва на самых быстрых машин из мн-ва \ удаляем из мн-ва самых быстрых машин
Пример
Пусть у нас есть 5 работ и 4 станка. Покажем работу алгоритма для данного случая.
В начальный момент времени начинаем обрабатывать работы с наибольшим временем выполнения
на станках соответственно. В момент времени 4-ой работы опускается до времени выполнения 5-ой работы. С этого момента начинаем обрабатывать работы на одном станке: . В момент времени происходит похожая ситуация. С этого момента времени работы выполняются синхронно на двух станках . Далее работы не пересекаются друг с другом и каждая заканчивается на ранее выделенных им станках.Время работы
Level-алгоритм вызывает функцию Assign(t) в самом худшем случае
раз. Функция Assign(t) выполняется за . Итоговое время работы .Литература
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 379 стр. — ISBN 978-3-540-69515-8