Opij1sumwu — различия между версиями
(→Источники информации) |
(→Описание алгоритма) |
||
Строка 5: | Строка 5: | ||
}} | }} | ||
==Описание алгоритма== | ==Описание алгоритма== | ||
− | Для решения этой задачи, мы должны найти множество <tex>S</tex>, что <tex>\sum\limits_{i \notin S} {w_{i} U_{i}}</tex> минимальна. Будем решать эту задачу с помощью динамического программирования с использованием утверждений из | + | Для решения этой задачи, мы должны найти множество <tex>S</tex>, что <tex>\sum\limits_{i \notin S} {w_{i} U_{i}}</tex> минимальна. Будем решать эту задачу с помощью динамического программирования с использованием утверждений из решения задачи [[Opij1di|<tex> O \mid p_{i,j} = 1, d_i \mid - </tex>]]. |
− | Рассмотрим работы в порядке | + | Рассмотрим работы в порядке неубывания дедлайнов: <tex>d_{1} \leqslant d_{2} \leqslant \ldots \leqslant d_{n}</tex>. Пусть мы нашли решение для работ <tex>1, 2, \ldots, i-1</tex>. Очевидно, что <tex>S \subseteq \{1, \ldots i-1\}</tex>. |
Пусть <tex>h^S</tex> {{---}} вектор соответствующий множеству <tex>S</tex> из задачи [[Opij1di|<tex> O \mid p_{i,j} = 1, d_i \mid - </tex>]]. Тогда, для добавления работы <tex>i</tex> в множество <tex>S</tex> должно выполняться неравенство: <tex>m\cdot (d_i-m)-(km-\sum\limits_{j=1}^m {h^S(d_i-m+j)})+x(d_i) \geqslant m</tex>, где <tex>k=|S|</tex> и <tex>x(d_i)</tex> {{---}} количество периодов времени <tex>t</tex> со свойствами: <tex>d_i-m+1 \leqslant t \leqslant d_i</tex> и <tex>h^S(t) < m</tex>. Чтобы проверить это неравенство, нам нужно посчитать <tex>m</tex> чисел <tex>h^S(t)</tex>, <tex>t=d_i-m+1, \ldots, d_i</tex>. Для этого определим переменные: | Пусть <tex>h^S</tex> {{---}} вектор соответствующий множеству <tex>S</tex> из задачи [[Opij1di|<tex> O \mid p_{i,j} = 1, d_i \mid - </tex>]]. Тогда, для добавления работы <tex>i</tex> в множество <tex>S</tex> должно выполняться неравенство: <tex>m\cdot (d_i-m)-(km-\sum\limits_{j=1}^m {h^S(d_i-m+j)})+x(d_i) \geqslant m</tex>, где <tex>k=|S|</tex> и <tex>x(d_i)</tex> {{---}} количество периодов времени <tex>t</tex> со свойствами: <tex>d_i-m+1 \leqslant t \leqslant d_i</tex> и <tex>h^S(t) < m</tex>. Чтобы проверить это неравенство, нам нужно посчитать <tex>m</tex> чисел <tex>h^S(t)</tex>, <tex>t=d_i-m+1, \ldots, d_i</tex>. Для этого определим переменные: | ||
Строка 21: | Строка 21: | ||
\end{matrix} \right.</tex>. | \end{matrix} \right.</tex>. | ||
− | Тогда можно заметить, что <tex>x(d_i)=\sum\limits_{j=1}^m {l_j}</tex>. Следовательно можно | + | Тогда можно заметить, что <tex>x(d_i)=\sum\limits_{j=1}^m {l_j}</tex>. Следовательно можно упростить исходное неравенство: <tex>m\cdot (d_i-m)-(km-\sum\limits_{j=1}^m {k_j})+\sum\limits_{j=1}^m {l_j} \geqslant m</tex> или <tex>m\cdot (d_i-m-k)+ \sum\limits_{j=1}^m {(k_j+l_j)} \geqslant m</tex>. |
Для динамического программирования определим <tex>f_i(k,k_1 \ldots , k_m) = \min(\sum\limits_{j=i}^n {w_jU_j})</tex>, где <tex>k=|S|, S \subseteq \{1, \ldots , i-1\}</tex> и <tex>k_j=h^S(d_i-m+j)</tex> где <tex>j=1, \ldots , m</tex>. | Для динамического программирования определим <tex>f_i(k,k_1 \ldots , k_m) = \min(\sum\limits_{j=i}^n {w_jU_j})</tex>, где <tex>k=|S|, S \subseteq \{1, \ldots , i-1\}</tex> и <tex>k_j=h^S(d_i-m+j)</tex> где <tex>j=1, \ldots , m</tex>. |
Версия 13:52, 22 мая 2016
Задача: |
Дано | одинаковых станков, которые работают параллельно, и работ, которые необходимо выполнить в произвольном порядке на всех станках. Любая работа на любом станке выполняется за единицу времени. Для каждой работы есть время окончания — время, до которого она должна быть выполнена. Требуется минимизировать , то есть суммарный вес всех просроченных работ.
Описание алгоритма
Для решения этой задачи, мы должны найти множество .
, что минимальна. Будем решать эту задачу с помощью динамического программирования с использованием утверждений из решения задачиРассмотрим работы в порядке неубывания дедлайнов:
. Пусть мы нашли решение для работ . Очевидно, что .Пусть . Тогда, для добавления работы в множество должно выполняться неравенство: , где и — количество периодов времени со свойствами: и . Чтобы проверить это неравенство, нам нужно посчитать чисел , . Для этого определим переменные:
— вектор соответствующий множеству из задачи
.
Тогда можно заметить, что
. Следовательно можно упростить исходное неравенство: или .Для динамического программирования определим
, где и где .Пусть
, тогда определим рекуррентное выражение для :
и начальное условие:
для .Если выполняется неравенство
, то мы не можем добавить работу в множество и поэтому .Если выполняется неравенство
, тогда мы может добавить работу в множество или не добавлять. Если мы добавим работу , то . Если мы не добавим работу , то по аналогии с первым случаем . Так как , то нам надо взять минимум из значений и .Ответ на задачу будет находиться в
.Время работы
Для определения времени работы алгоритма надо заметить, что
, где . Из рекуррентной формулы очевидно, что подсчет одного значение нужно времени. Значит алгоритм работает за или для фиксированного .См. также
Источники информации
- Peter Brucker. «Scheduling Algorithms» — «Springer», 2006 г. — c. 168 - 170. ISBN 978-3-540-69515-8