J2pij1Lmax — различия между версиями
(→Алгоритм) |
(→Доказательство) |
||
Строка 136: | Строка 136: | ||
|statement=Расписание, построенное данным алгоритмом, оптимально. | |statement=Расписание, построенное данным алгоритмом, оптимально. | ||
|proof=Пусть <tex> l</tex> — максимальное опоздание оптимального расписания. Тогда | |proof=Пусть <tex> l</tex> — максимальное опоздание оптимального расписания. Тогда | ||
− | <tex> | + | <tex>\overset{n}{\underset{i=1}{\max}}L(i) = \overset{n}{\underset{i=1}{\max}}(C_i - d_i) \leqslant l</tex> эквивалентно |
− | <tex> | + | <tex>\overset{n}{\underset{i=1}{\max}}(C_i - (d_i+l)) \leqslant 0</tex>. |
По первой лемме, данный алгоритм применительно к задаче с дедлайнами <tex> d_i + l</tex> дает оптимальное расписание для исходной задаче. Кроме того, это расписание совпадает с расписанием, которое мы получим, применив данный алгоритм к исходной задаче. | По первой лемме, данный алгоритм применительно к задаче с дедлайнами <tex> d_i + l</tex> дает оптимальное расписание для исходной задаче. Кроме того, это расписание совпадает с расписанием, которое мы получим, применив данный алгоритм к исходной задаче. |
Версия 19:06, 15 мая 2016
Задача: |
Дано , то операция должна быть совершена на машине . Задача заключается в том, что для данного каждой -той работе дедлайна необходимо найти достижимое расписание с наименьшими максимальным временем опоздания: | работ и две машины, обозначенные как и . -тая работа состоит из операций , которые должны быть выполнены последовательно и, при этом, если операция была совершена на машине
Описание решения
Судя по условию,
-тая работа может характеризоваться двумя значениями: количество операций и машиной, на которой была совершена первая операция. Пусть — общее количество операций.Допустим, самым ранним моментом, когда операция может начать выполняться, будет момент времени 0, а верхнюю границу момента начала выполнения последней операции обозначим за
. К примеру, мы можем выбрать . Тогда расписание можно представить как два списка и , где , если операция должна выполниться на машине в момент времени и , если машина простаивает в этот момент. И для каждой операции , выполняющейся на машине существует , для которого . Аналогично для . Расписание достижимо тогда и только тогда, когда из следует для некоторого , и первая операция для каждой работы запланирована на нужной машине. Перестановку всех операций будем называть списком. Для данного списка осуществимое расписание может быть создано следующим способом: планируем выполнять операции в порядке, соответствующим , причем каждую операцию стараемся выполнить как можно раньше. Подобное расписание будем называть соответствующим расписанием. — время окончания работы в достижимом расписании можно рассчитать как:или — операция -той работы.
Задача заключается в том, что для данного каждой работе
дедлайна мы хотим найти достижимое расписание с наименьшим максимальным временем опоздания:
Следующий алгоритм решает эту задачу:
- введём для каждой операции величину ,
- создадим список всех операций , упорядоченный в порядке неубывания значений ,
- найдем соответствующее списку расписание.
Этот алгоритм может быть реализован с асимптотикой
.Мы предполагаем, что
для и хотя бы для одной работы . Иначе, вычтем из всех минимальное значение по .Так как
для всех и справедливо как минимум для одной работы . К тому же, можно предположить, что . Таким образом, работы с , то есть c , можно смело игнорировать. Они не влияют на значение улучшаемой функции , так как для некого можно выполнять эти работы в любом порядке после всех остальных. Для оставшихся операций мы имеем:
Каждую операцию мы кладём в соответствующий список (на самом деле это должна быть куча (англ. heap) для хорошей асимптотики) , где . На втором шаге мы планируем операции соответственно возрастающему по номеру списка порядку, где операции из одного списка могут выполнятся в произвольном порядке.
Алгоритм
Рассмотрим алгоритм. Пусть:
- и — первый период времени , когда соответствующие машины и бездействуют;
- — время окончания последней запланированной операции -той работы;
- — множество работ, где .
function main(): for k = -r + 1 to r - 1= Z = for i = 1 to n if < r for j = 1 to добавить в else добавить работу i в Z for i = 1 to n LAST(i) = 0 T1 = 0 T2 = 0 for k = -r + 1 to r - 1 while Выбрать задание из = schedule( ) while Выбрать работу i из Z Z = ; for j = 1 to schedule( )
function schedule(): if == A if T1 < LAST(i) t = LAST(i) A(t) = (*) else t = T1 A(t) = while T1 = T1 + 1 else if T2 < LAST(i) t = LAST(i) B(t) = (**) else t = T2 A(t) = while T2 = T2 + 1 LAST(i) = t + 1
Очевидно, что количество шагов алгоритма ограничено
.Доказательство
Для доказательства того, что алгоритм решения задачи корректен, необходимо показать то, что он строит достижимое расписание. Это справедливо тогда и только тогда, когда до исполнения строчек (*) и (**) пусты A(t) и B(t) соответственно. Иначе две разные операции будут выполняться в один момент времени на одной машине. Для того, чтобы показать достижимость докажем лемму.
Лемма: |
Пусть — расписание, где . Тогда для каждого , где выполняется |
Доказательство: |
Докажем по индукции по Предположим теперь что лемма верна для всех , что если и , то . Это, очевидно, верно при так как если и не соответствует работе , то означает что операция должна быть запланирована в расписании ранее. при и . Выберем максимальное , такое что и . По предположению индукции, и соответствуют одной и той же работе для . Пусть ) не соответствует работе . Тогда для каждого операция не соответствует работе . Таким образом, может быть обработан в момент , что противоречит тому, что является расписанием. |
Теорема: |
Пусть — операция, которую планируют строчкой (*) или (**) и . Тогда |
Доказательство: |
Предположим что | . Поскольку , из предыдущей леммы следует, что и и являются операциями одной и той же задачи . Так как , то должно быть значение . Это невозможно, т.к. при и , .
Лемма: |
Если существует расписание без опозданий, то данный алгоритм построит расписание без опозданий. |
Доказательство: |
Покажем, что если в расписании, построенном данным алгоритмом есть опоздание, то опоздание есть в каждом расписании. Если есть опоздание в , то существует операция или с или . Например, это неравенство верно для последней операции в конце работы. Выберем минимальное с этим свойством и предположим, что . Тогда мы докажем, что и . (***) Таким образом, в каждом расписании должно существовать, по крайней мере, одно опоздание, т.к. если то при и мы должны запланировать операций во временном интервале , что невозможно. Если же , то все задачи начинаются на машине и операций должны обрабатываться в интервале времени , что тоже не возможно. Для доказательства (***) заметим, что (***) верно, если является первой операцией для работы, так как если при некоторых , то алгоритм должен запланировать перед . Теперь положим для какого-нибудь и . Получим при , так как из следует , а это противоречит минимальности . Из этого следует, что при так как в противном случае должно быть запланировано ранее. Также поскольку в противном случае должно быть запланировано на время , так как и являются операциями различных задач. Для мы доказали (***). Иначе пусть . Если — первая операция задачи, мы закончили. В противном случае, если при , мы снова имеемЕсли . , тогда возьмем минимальное такое, что и являются последовательными операциями одной и той же задачи при . не соответствует задаче , и мы снова имеем .Если , мы закончили. Если , продолжаем таким же образом. |
Теорема: |
Расписание, построенное данным алгоритмом, оптимально. |
Доказательство: |
Пусть По первой лемме, данный алгоритм применительно к задаче с дедлайнами — максимальное опоздание оптимального расписания. Тогда эквивалентно . дает оптимальное расписание для исходной задаче. Кроме того, это расписание совпадает с расписанием, которое мы получим, применив данный алгоритм к исходной задаче. |
См. также.
Источники информации
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — 180 — 186 стр. — ISBN 978-3-540-69515-8