1ripi1sumf — различия между версиями
Dominica (обсуждение | вклад) |
м (rollbackEdits.php mass rollback) |
||
(не показано 16 промежуточных версий 3 участников) | |||
Строка 1: | Строка 1: | ||
<tex dpi = "200" >1 \mid r_i, p_i = 1 \mid \sum f_i</tex> | <tex dpi = "200" >1 \mid r_i, p_i = 1 \mid \sum f_i</tex> | ||
− | Для каждой работы задана монотонно неубывающая функция <tex>f_i</tex>. Необходимо минимизировать <tex> \sum f_i, </tex> где каждая <tex>f_i</tex> считается на значении времени завершения выполнения задания с номером <tex>i</tex>. | + | Для каждой работы задана монотонно неубывающая функция <tex>f_i</tex>. Необходимо минимизировать <tex> \sum f_i,</tex> где каждая <tex>f_i</tex> считается на значении времени завершения выполнения задания с номером <tex>i</tex>. |
==Решение== | ==Решение== | ||
Строка 8: | Строка 8: | ||
А именно, покажем, что решение задачи состоит в сопоставлении <tex>n</tex> различным заданиям различных времен начала выполнения работы. Если сопоставляем работе <tex>i</tex> время <tex>t</tex>, то вклад в целевую функцию будет <tex> f_i(t + 1) </tex>. | А именно, покажем, что решение задачи состоит в сопоставлении <tex>n</tex> различным заданиям различных времен начала выполнения работы. Если сопоставляем работе <tex>i</tex> время <tex>t</tex>, то вклад в целевую функцию будет <tex> f_i(t + 1) </tex>. | ||
− | Далее будет показано, что при построении оптимального расписания нам нужно будет рассмотреть всего <tex>n</tex> различных времен начала работ. Следовательно, подобная задача может быть решена за <tex>O(n^3)</tex>. | + | Далее будет показано, что при построении оптимального расписания нам нужно будет рассмотреть всего <tex>n</tex> различных времен начала работ. Следовательно, подобная задача может быть решена за <tex>\mathcal{O}(n^3)</tex>. |
Поскольку <tex>f_i</tex> {{---}} монотонно неубывающие функции, то это значит, что в оптимальном расписании работы должны начинать исполняться как можно раньше. Первые <tex>n</tex> самых ранних для начала исполнения времен <tex>t_i</tex> могут быть вычислены следующим алгоритмом : | Поскольку <tex>f_i</tex> {{---}} монотонно неубывающие функции, то это значит, что в оптимальном расписании работы должны начинать исполняться как можно раньше. Первые <tex>n</tex> самых ранних для начала исполнения времен <tex>t_i</tex> могут быть вычислены следующим алгоритмом : | ||
Строка 34: | Строка 34: | ||
{{Лемма | {{Лемма | ||
|id=lemma1 | |id=lemma1 | ||
− | |statement= | + | |statement= Пусть значения <tex>t_i</tex> вычислены приведенным выше алгоритмом. Тогда существует оптимальное расписание <tex>S,</tex> в котором все <tex>n</tex> задач распределены по всем временам <tex>t_i (i = 1\ldots n).</tex> |
− | |proof= Предположим, что в некоторое оптимальное расписание <tex>S</tex> входят времена <tex> t_1 \ldots t_j, </tex> где <tex> j < n</tex> | + | |proof= Предположим, что в некоторое оптимальное расписание <tex>S</tex> входят времена <tex> t_1 \ldots t_j, </tex> где <tex> j < n,</tex> а вместо <tex>t_{j+1}</tex> времени используется какое-то другое. Из всех возможных таких оптимальных расписаний мы возьмем то, у которого <tex>j</tex> будет максимально. |
Из того, как в алгоритме выбирались значения для <tex>t_i</tex> следует, что <tex>t_{j + 1}</tex> {{---}} минимальное возможное время, большее <tex>t_j,</tex> в которое можно начать выполнять какое-нибудь из оставшихся заданий. Если во время <tex>t_{j+1}</tex> в расписании <tex>S</tex> не выполняется никакого задания, то какое-то задание, которое могло бы выполнится в момент времени <tex>t_{j+1}</tex> выполняется в <tex>S</tex> позднее. Значит оно может быть перемещено в нашем расписании <tex>S</tex> на время <tex>t_{j+1}</tex> без увеличения целевой функции. Таким образом, наше новое расписание тоже будет оптимальным. Получили противоречие с максимальностью <tex>j</tex>. Значит из всех оптимальных расписаний нам подходят только те, в которых <tex>j = n</tex>. | Из того, как в алгоритме выбирались значения для <tex>t_i</tex> следует, что <tex>t_{j + 1}</tex> {{---}} минимальное возможное время, большее <tex>t_j,</tex> в которое можно начать выполнять какое-нибудь из оставшихся заданий. Если во время <tex>t_{j+1}</tex> в расписании <tex>S</tex> не выполняется никакого задания, то какое-то задание, которое могло бы выполнится в момент времени <tex>t_{j+1}</tex> выполняется в <tex>S</tex> позднее. Значит оно может быть перемещено в нашем расписании <tex>S</tex> на время <tex>t_{j+1}</tex> без увеличения целевой функции. Таким образом, наше новое расписание тоже будет оптимальным. Получили противоречие с максимальностью <tex>j</tex>. Значит из всех оптимальных расписаний нам подходят только те, в которых <tex>j = n</tex>. | ||
}} | }} | ||
+ | ==Частный случай== | ||
+ | В случае, когда все времена появлений заданий различны, оптимальное решение может быть посчитано за <tex>\mathcal{O}(n\log n) </tex>. | ||
− | ==См. также == | + | Поскольку любое задание выполняется за единицу времени, а все функции <tex>f_i</tex> являются неубывающими, то будет достаточно отсортировать работы по возрастанию времен появления и выполнять каждую работу как только она появится. Поскольку все <tex>r_i</tex> различны, то промежутки выполнения работ не будут пересекаться {{---}} расписание будет корректным. |
+ | |||
+ | == Примеры == | ||
+ | ===Пример 1=== | ||
+ | Даны четыре задания. | ||
+ | |||
+ | <tex>r_1 = 3, f_1 = 5t </tex> | ||
+ | |||
+ | <tex>r_2 = 2, f_2 = t^2 </tex> | ||
+ | |||
+ | <tex>r_3 = 4, f_3 = t + 4 </tex> | ||
+ | |||
+ | <tex>r_4 = 1, f_4 = 2^t </tex> | ||
+ | |||
+ | Отсортируем задания по неубыванию <tex>r_i</tex>, а дальше будем выполнять их по мере появления. В полученном расписании работы будут идти в порядке <tex>4, 2, 1, 3</tex> и давать в ответе <tex>2^{1 + 1} + (2 + 1)^2 + 5(3 + 1) + (4 + 1) + 4 = 42 </tex>, что является оптимальным результатом. | ||
+ | |||
+ | ===Пример 2=== | ||
+ | Пусть у нас есть три задания, и каждое из них имеет время появления <tex>r_i = 0.</tex> | ||
+ | |||
+ | Заданы функции <tex>f_i</tex>: | ||
+ | |||
+ | <tex>f_1(t) = t^2 </tex> | ||
+ | |||
+ | <tex>f_2(t) = t^3 </tex> | ||
+ | |||
+ | <tex>f_3(t) = 3 ^ t </tex> | ||
+ | |||
+ | Поступить как в предыдущем примере и просто отсортировать работы мы теперь не можем {{---}} не понятно, в каком порядке сортировать задания с одинаковым временем появления. | ||
+ | |||
+ | Тогда нужно по приведенному в начале алгоритму посчитать времена, когда мы можем начать выполнять задания. В результате получим: <tex>t_1 = 0, t_2 = 1, t_3 = 2</tex>. | ||
+ | Тогда, согласно алгоритму, задача сведется к следующей задаче о назначениях: | ||
+ | |||
+ | <tex> | ||
+ | \begin{tabular}{c||ccc} | ||
+ | $t_i$ $\backslash$ i & 1 & 2 & 3 \\ | ||
+ | \hline | ||
+ | \hline | ||
+ | 0 & 1 & $\mathbf{1}$ & 3 \\ | ||
+ | 1 & 4 & 8 & $\mathbf{9}$ \\ | ||
+ | 2 & $\mathbf{9}$ & 27 & 27\\ | ||
+ | \hline | ||
+ | \end{tabular} | ||
+ | |||
+ | </tex> | ||
+ | |||
+ | В результате работы [[Венгерский алгоритм решения задачи о назначениях | Венгерского алгоритма]] будет выбран порядок работ <tex>2, 3, 1</tex>, что даст лучший результат {{---}} <tex>19</tex>. | ||
+ | |||
+ | На этом примере хорошо видно, что решение, выбирающие в каждый момент времени <tex>t_i</tex> несделанную работу с минимальным значением <tex>f_i(t_i + 1)</tex> будет давать плохой результат. | ||
+ | |||
+ | ===Пример 3=== | ||
+ | Пусть у нас есть четыре задания, определенные следующим образом: | ||
+ | |||
+ | <tex>r_1 = 0, f_1(t) = t^2 </tex> | ||
+ | |||
+ | <tex>r_2 = 0, f_2(t) = 2t </tex> | ||
+ | |||
+ | <tex>r_3 = 1, f_3(t) = 2 ^ t </tex> | ||
+ | |||
+ | <tex>r_4 = 5, f_3(t) = t + 2 </tex> | ||
+ | |||
+ | Работы уже отсортированы, поэтому посчитаем времена <tex>t_i</tex> для выполнения заданий. Получим: <tex>t_1 = 0, t_2 = 1, t_3 = 2, t_4 = 4</tex>. | ||
+ | |||
+ | Таблица, необходимая для решения задачи, будет построена так, что если работа с номером <tex>i</tex> ещё не доступна в момент времени <tex>t_j</tex>, то в соответствующей ячейке будет стоять <tex>\infty</tex>. | ||
+ | |||
+ | <tex> | ||
+ | \begin{tabular}{c||cccc} | ||
+ | $t_i$ $\backslash$ i & 1 & 2 & 3 & 4 \\ | ||
+ | \hline | ||
+ | \hline | ||
+ | 0 & $\mathbf{1}$ & 2 & $\infty$ & $\infty$ \\ | ||
+ | 1 & 4 & 4 & $\mathbf{4}$ & $\infty$ \\ | ||
+ | 2 & 9 & $\mathbf{6}$ & 8& $\infty$ \\ | ||
+ | 4 & 25 & 10 & 32 & $\mathbf{7}$ \\ | ||
+ | \hline | ||
+ | \end{tabular} | ||
+ | |||
+ | </tex> | ||
+ | |||
+ | |||
+ | В результате будет выбран порядок работ <tex>1, 3, 2, 4</tex>, и все работы выполнятся за <tex>18</tex> единиц времени. | ||
+ | |||
+ | == См. также == | ||
* [[Классификация задач]] | * [[Классификация задач]] | ||
* [[1precpmtnrifmax|<tex>1 \mid prec, pmtn, r_i \mid f_{\max}</tex>]] | * [[1precpmtnrifmax|<tex>1 \mid prec, pmtn, r_i \mid f_{\max}</tex>]] | ||
Строка 45: | Строка 128: | ||
* P. Brucker. Scheduling Algorithms (2006), 5th edition, стр. 19 - 20 | * P. Brucker. Scheduling Algorithms (2006), 5th edition, стр. 19 - 20 | ||
− | [[Категория: | + | [[Категория: Алгоритмы и структуры данных]] |
[[Категория: Теория расписаний]] | [[Категория: Теория расписаний]] |
Текущая версия на 19:42, 4 сентября 2022
Для каждой работы задана монотонно неубывающая функция
. Необходимо минимизировать где каждая считается на значении времени завершения выполнения задания с номером .Решение
Эта задача может быть решена сведением к решению задачи о назначениях. А именно, покажем, что решение задачи состоит в сопоставлении различным заданиям различных времен начала выполнения работы. Если сопоставляем работе время , то вклад в целевую функцию будет .
Далее будет показано, что при построении оптимального расписания нам нужно будет рассмотреть всего
различных времен начала работ. Следовательно, подобная задача может быть решена за .Поскольку
— монотонно неубывающие функции, то это значит, что в оптимальном расписании работы должны начинать исполняться как можно раньше. Первые самых ранних для начала исполнения времен могут быть вычислены следующим алгоритмом :отсортиртировать по неубыванию времена появления= for =
Для того, чтобы найти оптимальное расписание, построим полный двудольный граф, в котором будут доли и ребра между ними:
Решив задачу о назначениях для данного графа, получим оптимальное расписание.
Доказательство корректности и оптимальности
Лемма: |
Пусть значения вычислены приведенным выше алгоритмом. Тогда существует оптимальное расписание в котором все задач распределены по всем временам |
Доказательство: |
Предположим, что в некоторое оптимальное расписание Из того, как в алгоритме выбирались значения для входят времена где а вместо времени используется какое-то другое. Из всех возможных таких оптимальных расписаний мы возьмем то, у которого будет максимально. следует, что — минимальное возможное время, большее в которое можно начать выполнять какое-нибудь из оставшихся заданий. Если во время в расписании не выполняется никакого задания, то какое-то задание, которое могло бы выполнится в момент времени выполняется в позднее. Значит оно может быть перемещено в нашем расписании на время без увеличения целевой функции. Таким образом, наше новое расписание тоже будет оптимальным. Получили противоречие с максимальностью . Значит из всех оптимальных расписаний нам подходят только те, в которых . |
Частный случай
В случае, когда все времена появлений заданий различны, оптимальное решение может быть посчитано за
.Поскольку любое задание выполняется за единицу времени, а все функции
являются неубывающими, то будет достаточно отсортировать работы по возрастанию времен появления и выполнять каждую работу как только она появится. Поскольку все различны, то промежутки выполнения работ не будут пересекаться — расписание будет корректным.Примеры
Пример 1
Даны четыре задания.
Отсортируем задания по неубыванию
, а дальше будем выполнять их по мере появления. В полученном расписании работы будут идти в порядке и давать в ответе , что является оптимальным результатом.Пример 2
Пусть у нас есть три задания, и каждое из них имеет время появления
Заданы функции
:
Поступить как в предыдущем примере и просто отсортировать работы мы теперь не можем — не понятно, в каком порядке сортировать задания с одинаковым временем появления.
Тогда нужно по приведенному в начале алгоритму посчитать времена, когда мы можем начать выполнять задания. В результате получим:
. Тогда, согласно алгоритму, задача сведется к следующей задаче о назначениях:
В результате работы Венгерского алгоритма будет выбран порядок работ , что даст лучший результат — .
На этом примере хорошо видно, что решение, выбирающие в каждый момент времени
несделанную работу с минимальным значением будет давать плохой результат.Пример 3
Пусть у нас есть четыре задания, определенные следующим образом:
Работы уже отсортированы, поэтому посчитаем времена
для выполнения заданий. Получим: .Таблица, необходимая для решения задачи, будет построена так, что если работа с номером
ещё не доступна в момент времени , то в соответствующей ячейке будет стоять .
В результате будет выбран порядок работ , и все работы выполнятся за единиц времени.
См. также
Источники информации
- P. Brucker. Scheduling Algorithms (2006), 5th edition, стр. 19 - 20