QpmtnCmax — различия между версиями
Creep (обсуждение | вклад) (Новая страница: «<div style="background-color: #ABCDEF; font-size: 16px; font-weight: bold; color: #000000; text-align: center; padding: 4px; border-style: solid; border-width: 1p...») |
(→Пример) |
||
Строка 55: | Строка 55: | ||
Пусть у нас есть 5 работ и 4 станка. Покажем работу алгоритма для данного случая. | Пусть у нас есть 5 работ и 4 станка. Покажем работу алгоритма для данного случая. | ||
− | В начальный момент времени начинаем обрабатывать работы с наибольшим временем выполнения <tex>J_1-J_4</tex> на станках <tex>M_1- | + | В начальный момент времени начинаем обрабатывать работы с наибольшим временем выполнения <tex>J_1-J_4</tex> на станках <tex>M_1-M_4</tex> соответственно. В момент времени <tex>t_1</tex> lvl 4-ой работы опускается до времени выполнения 5-ой работы. С этого момента начинаем обрабатывать работы <tex> J_4,J_5</tex> на одном станке: <tex>M_4</tex>. В момент времени <tex>t_2</tex> происходит похожая ситуация. С этого момента времени работы <tex> J_1,J_2</tex> выполняются синхронно на двух станках <tex> M_1,M_2</tex>. Далее работы не пересекаются друг с другом и каждая заканчивается на ранее выделенных им станках. |
==Время работы== | ==Время работы== |
Версия 17:07, 21 мая 2012
Эта статья находится в разработке!
Содержание
Постановка задачи
Есть несколько станков с разной скоростью выполнения работ. Работу на каждом из станков можно прервать и продолжить позже.
Цель - выполнить все как можно быстрее.
1. Найдем нижнюю границу времени выполнения.
2. Составим оптимальное расписание.
Алгоритм построения расписания
Где
; ; ;Необходимое условие для выполнения всех работ в интервале
:или
Нижняя граница
:{ }
Далее построим расписание, которое достигает нашей оценки w, с помощью Level-алгоритма.
Level - алгоритм:
WHILE существуют работы с положительным lvl Assign(t) работа выполненная в момент времени && Построение расписания
Функция
:{ } { } WHILE ( != 0 && != 0) Найти множество работ подмножество ,lvl которых максимальный (| |,| |) Назначаем работы из мн-ва на самых быстрых машин из мн-ва \ удаляем из мн-ва самых быстрых машин
Пример
Пусть у нас есть 5 работ и 4 станка. Покажем работу алгоритма для данного случая.
В начальный момент времени начинаем обрабатывать работы с наибольшим временем выполнения
на станках соответственно. В момент времени lvl 4-ой работы опускается до времени выполнения 5-ой работы. С этого момента начинаем обрабатывать работы на одном станке: . В момент времени происходит похожая ситуация. С этого момента времени работы выполняются синхронно на двух станках . Далее работы не пересекаются друг с другом и каждая заканчивается на ранее выделенных им станках.Время работы
Level-алгоритм вызывает функцию Assign(t) в самом худшем случае
раз. Функция Assign(t) выполняется за . Итоговое время работы .Литература
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 379 стр. — ISBN 978-3-540-69515-8