Pintreepi1Lmax — различия между версиями
Zernov (обсуждение | вклад) |
Zernov (обсуждение | вклад) |
||
Строка 4: | Строка 4: | ||
|definition=Рассмотрим задачу на нахождение расписания: | |definition=Рассмотрим задачу на нахождение расписания: | ||
# У нас есть несколько станков, работающих параллельно. У станков могут быть разные скорости выполнения работ. | # У нас есть несколько станков, работающих параллельно. У станков могут быть разные скорости выполнения работ. | ||
− | # Есть несколько заданий, каждое из которых имеет определенный порядок, который указан в направленном из корней в лист intree-дерева. | + | # Есть несколько заданий, каждое из которых имеет определенный порядок, который указан в направленном из корней в лист [[Классификация задач#Характеристики работ|intree-дерева]]. |
# Любая работа на любом станке выполняется единицу времени. | # Любая работа на любом станке выполняется единицу времени. | ||
Требуется минимизировать максимальное опоздание <tex>L_{max} = \max\limits_i \{C_i - d_i\}</tex>. | Требуется минимизировать максимальное опоздание <tex>L_{max} = \max\limits_i \{C_i - d_i\}</tex>. | ||
Строка 13: | Строка 13: | ||
=== Идея === | === Идея === | ||
− | Все | + | Все работы хранятся в качестве вершин [[Классификация задач#Характеристики работ|intree-дерева]], состоящем из <tex>n</tex> вершин, нескольких корней и одного листа. В intree-дереве у одной вершины может быть два и более родителей. |
− | |||
− | |||
Решение задачи состоит из двух шагов: на первом шаге мы меняем сроки выполнения работ в соответствии с их очередностью. | Решение задачи состоит из двух шагов: на первом шаге мы меняем сроки выполнения работ в соответствии с их очередностью. | ||
− | + | * Для всех <tex>i, j</tex> таких, что существует ребро из <tex>i</tex> в <tex>j</tex> будем менять <tex>{d_i}</tex> на <tex>\min ({d_i}, {d_j} - 1) </tex>. | |
+ | * Работы расставляются в неубывающем порядке сроков. | ||
=== Первый шаг === | === Первый шаг === |
Версия 16:35, 22 мая 2016
Задача: |
Рассмотрим задачу на нахождение расписания:
|
Описание алгоритма
Идея
Все работы хранятся в качестве вершин intree-дерева, состоящем из вершин, нескольких корней и одного листа. В intree-дереве у одной вершины может быть два и более родителей. Решение задачи состоит из двух шагов: на первом шаге мы меняем сроки выполнения работ в соответствии с их очередностью.
- Для всех таких, что существует ребро из в будем менять на .
- Работы расставляются в неубывающем порядке сроков.
Первый шаг
Алгоритм изменения сроков:
deque = ii является листом while deque not empty i = stack.remove_first() for j j является предком i stack.add_last(j)
Лемма: |
Работа с новым сроком в расписании не имеет опозданий тогда и только тогда, когда она не имела опозданий с оригинальным сроком . |
Доказательство: |
: Т.к. , значит, если опозданий не было со значениями , их не будет и со значениями . : Пусть у нас были сроки и мы их заменили на в соответствии с приведенным алгоритмом.
|
Второй шаг
На втором этапе алгоритма работы сортируются в неубывающем порядке их дедлайнов. Предполагается, что работы занумерованы в соответствии с предыдущим пунктом, т.е.
, если .В переменной
хранится время, когда станок освободится.В массиве
хранится информация о максимальном времени завершении обработки родителя.Массив
хранит информацию о количестве работ, готовых к исполнению (находящихся в очереди) в момент времени .Массив
хранит информацию о начале выполнения работы .F = 0 for i = 1 .. n r[i] = 0 for t = 0 .. n q[t] = 0 for i = 1 .. n t = max(r[i], F) x[i] = t q[t] = q[t] + 1 if q[t] == m F = t + 1 j = i.child() r[j] = max (r[j], t + 1)
Расписание, сгенерированное этим алгоритмом имеет важное свойство: число заданий в очереди в любой момент времени
меньше, чем в момент . Действительно, пусть во время мы выполняем работ, и хотя бы работ готовы к выполению в момент времени . Но т.к. , значит каждой из работ предшествовала как минимум одна, поскольку у всех вершин, кроме корней, есть как минимум один предок. Значит, в момент времени исполнялось не менее работ, противоречие.Лемма: |
Если существует такое расписание, в котором ни одна из работ не будет выполнена с опозданием, то тогда это свойство сохранится в построенном данным алгоритмом расписании |
Доказательство: |
Предположим, что существует работа из расписания, построенного алгоритмом. В таком случае существует работа, которая опоздала по отношению к измененным срокам. Возьмем наименьшее такое, что . Пусть — наибольшее из удовлетворяющих условию Такое существует, потому что иначе работ с находятся в очереди до . Работа к ним не принадлежит, поскольку , а значит, что должны быть в очереди в момент времени и ни одна работа не должна опаздывать. Противоречие. Любая работа с и должна иметь предка, начавшего работать в момент времени . Теперь рассмотрим два случая:Первый случай: .
Второй случай: .
|
Теорема: |
Данный алгоритм корректно решает задачу |
Доказательство: |
Пусть | — оптимальное значение. В таком случае, существует расписание, удовлетворяющее , что эквивалетно выражению для . По первой лемме расписание , построенное для сдвинутых дат удовлетворяет данным выражениям. Таким образом, оно оптимально. Нетрудно заметить, что идентично расписанию, построенному алгоритмом, т.к. для
Источники информации
- Peter Brucker «Scheduling Algorithms», fifth edition, Springer — с. 151-156 ISBN 978-3-540-69515-8