Лекции All in One (1121240), страница 9
Текст из файла (страница 9)
Значение данной функции вычисляется алгоритмом, строящим расписание по маршруту.
Второй способ сведения задачи построения статико-динамического расписания к задаче нахождения на графе маршрута
Построим граф G’=<N’,A’>,
N’={ni+,ni–|i[1..n]}{O} – множество вершин; вершина ni+ соответствует размещению работы без закрытия текущего окна, ni– – размещению работы с закрытием окна. Вершина О является началом всех маршрутов.
A’={(ni+,nj–),(ni+,nj+),(ni–,nj–)|i,j[1..n],ij}{(O,ni+), (O,ni–)|i[1..n]} – множество ребер. Вершины, соответствующие одной работе, ребрами не связаны.
Алгоритм построения расписания по заданной последовательности работ полностью аналогичен предыдущему, за исключением того, что в п.4 при размещении работы, соответствующей вершине nj– текущее окно закрывается принудительно.
Если SP0 корректное оптимальное расписание для множества работ SW, то существует такая последовательность вершин SL, что модифицированный алгоритм построит по ней корректное оптимальное расписание.
Построенное расписание будет совпадать с расписанием SP0
-
по количеству размещенных в нем работ,
-
по количеству окон,
-
по множеству работ выполняемых внутри каждого окна,
но может отличаться по времени открытия и закрытия окон.
Алгоритм построения расписания обменов по каналу с централизованным управлением (схема с подциклами)
Канал в данной системе может рассматриваться как одноприборное устройство, обслуживающее исходно заданный набор работ без прерываний.
Дано:
-
Множество работ, которые должны выполняться на системе
. Для каждой работы заданы
- время выполнения,
- директивный интервал выполнения и выполняется условие
; -
Дополнительные ограничения
на корректность расписания
; -
Вектор значений технологических требований
.
Расписание выполнения работ, которое представляет собой упорядоченное множество
Здесь k - порядковый номер j-ой работы в расписании,
- время начала выполнения j-ой работы в расписании
,
- время завершения выполнения j-ой работы.
Множество корректных расписаний
определим набором ограничений:
-
Построение муравьями путей в графе.
-
Применение алгоритма размещения работ в расписание, на вход которому подаются последовательности вершин, построенные муравьиным алгоритмом.
-
Вычисление целевой функции.
-
Обновление количества феромона на ребрах графа.
-
Если условие останова не выполнено, переход к п.1.
Сопоставим каждой работе из J вершину ri.
Введем специальную вершину О, с которой будет начинаться маршрут каждого муравья.
Получим полносвязный ориентированный граф
-
– множество вершин, -
– множество ребер (между любыми двумя вершинами есть два ориентированных ребра).
Утверждение. Каждому пути в графе G соответствует ровно одно расписание и для одного и того же расписания может существовать более одного пути, по которому его можно построить.
Локальные эвристические функции на ребрах графа:
-
– чем ýже директивный интервал работы, тем раньше её предпочтительно разместить; -
, - чем ýже директивный интервал работы и чем больше времени нужно на её выполнение, тем раньше её предпочтительно разместить; -
, где NS – количество подциклов, в которые может быть размещена j-я работа – чем меньше это число, тем раньше работу предпочтительно разместить;
Сравнение алгоритмов на классе исходных данных А.
Сравнение алгоритмов на классе исходных данных Б.
. Для каждой работы заданы
- время выполнения,
- директивный интервал выполнения и выполняется условие
;
на корректность расписания
.
– множество вершин,
– множество ребер (между любыми двумя вершинами есть два ориентированных ребра).
– чем ýже директивный интервал работы, тем раньше её предпочтительно разместить;
, - чем ýже директивный интервал работы и чем больше времени нужно на её выполнение, тем раньше её предпочтительно разместить;
, где NS – количество подциклов, в которые может быть размещена j-я работа – чем меньше это число, тем раньше работу предпочтительно разместить;














