Оптимальное планирование работы

Оптимальное планирование заданий — это класс задач оптимизации, связанных с планированием . Входными данными для таких задач являются список заданий (также называемых процессами или задачами ) и список машин (также называемых процессорами или рабочими ). ​​Требуемым выходом является расписание — назначение заданий машинам. Расписание должно оптимизировать определенную целевую функцию . В литературе задачи оптимального планирования заданий часто называют машинным планированием , процессорным планированием , многопроцессорным планированием или просто планированием .

Существует множество различных задач оптимального планирования заданий, различающихся по характеру заданий, характеру машин, ограничениям на расписание и целевой функции. Удобная нотация для задач оптимального планирования была введена Рональдом Грэмом , Юджином Лоулером , Яном Карелом Ленстра и Александром Ринной Каном . [1] [2] Она состоит из трех полей: α , β и γ . Каждое поле может быть списком слов, разделенных запятыми. Поле α описывает машинную среду, β — характеристики и ограничения задания, а γ — целевую функцию. [3] С момента своего введения в конце 1970-х годов нотация постоянно расширялась, иногда непоследовательно. В результате сегодня существуют некоторые задачи, которые появляются с различными нотациями в нескольких работах.

Одноэтапные задания против многоэтапных заданий

В более простых задачах оптимального планирования заданий каждое задание j состоит из одной фазы выполнения с заданным временем обработки p j . В более сложных вариантах каждое задание состоит из нескольких фаз выполнения, которые могут выполняться последовательно или параллельно.

Машинные среды

В задачах одноэтапного планирования заданий существуют четыре основные категории машинных сред:

За этими буквами может следовать число машин, которое затем фиксируется. Например, P2 указывает на то, что есть две параллельные идентичные машины. Pm указывает на то, что есть m параллельных идентичных машин, где m — фиксированный параметр. Напротив, P указывает на то, что есть m параллельных идентичных машин, но m не фиксировано (оно является частью ввода).

В задачах многоэтапного планирования заданий существуют и другие варианты машинных сред:

  • O : Проблема открытого цеха . Каждая работа состоит из операций для . Операции могут быть запланированы в любом порядке. Операция должна быть обработана для единиц на машине . дж {\displaystyle j} м {\displaystyle м} О я дж {\displaystyle O_{ij}} i = 1 , , m {\displaystyle i=1,\ldots ,m} O i j {\displaystyle O_{ij}} p i j {\displaystyle p_{ij}} i {\displaystyle i}
  • F : Проблема поточного цеха . Каждая работа состоит из операций для , которые должны быть запланированы в заданном порядке. Операция должна быть обработана для единиц на машине . j {\displaystyle j} m {\displaystyle m} O i j {\displaystyle O_{ij}} i = 1 , , m {\displaystyle i=1,\ldots ,m} O i j {\displaystyle O_{ij}} p i j {\displaystyle p_{ij}} i {\displaystyle i}
  • J : Проблема Job-shop . Каждая работа состоит из операций для , которые должны быть запланированы в этом порядке. Операция должна быть обработана для единиц на выделенной машине с для . j {\displaystyle j} n j {\displaystyle n_{j}} O k j {\displaystyle O_{kj}} k = 1 , , n j {\displaystyle k=1,\ldots ,n_{j}} O k j {\displaystyle O_{kj}} p k j {\displaystyle p_{kj}} μ k j {\displaystyle \mu _{kj}} μ k j μ k j {\displaystyle \mu _{kj}\neq \mu _{k'j}} k k {\displaystyle k\neq k'}

Характеристики работы

Все времена обработки предполагаются целыми числами. Однако в некоторых старых исследовательских работах они предполагаются рациональными числами.

  • p i = p {\displaystyle p_{i}=p} , или : время обработки одинаково для всех заданий. p i j = p {\displaystyle p_{ij}=p}
  • p i = 1 {\displaystyle p_{i}=1} , или : время обработки равно 1 единице времени для всех заданий. p i j = 1 {\displaystyle p_{ij}=1}
  • r j {\displaystyle r_{j}} : для каждого задания указывается время выпуска, до которого его нельзя запланировать, по умолчанию 0.
  • online- r j {\displaystyle {\text{online-}}r_{j}} : онлайн-задача. Задания раскрываются в момент их выпуска. В этом контексте производительность алгоритма измеряется его конкурентоспособным коэффициентом .
  • d j {\displaystyle d_{j}} : для каждой работы указана дата выполнения. Идея заключается в том, что каждая работа должна быть завершена до даты выполнения, и есть некоторый штраф за работу, которая завершается с опозданием. Этот штраф указан в объективном значении. Наличие характеристики работы подразумевается и не указывается в названии задачи, если только нет некоторых ограничений, например , если все даты выполнения равны некоторой заданной дате. d j {\displaystyle d_{j}} d j = d {\displaystyle d_{j}=d}
  • d ¯ j {\displaystyle {\bar {d}}_{j}} : для каждой работы дается строгий срок. Каждая работа должна быть завершена до наступления своего срока.
  • pmtn : Задания могут быть прерваны и возобновлены, возможно, на другой машине. Иногда также обозначается как ' prmp '.
  • size j {\displaystyle {\text{size}}_{j}} : Каждое задание поставляется с несколькими машинами, на которых оно должно быть запланировано в одно и то же время. Значение по умолчанию — 1. Это важный параметр в варианте, называемом параллельным планированием задач .

Отношения старшинства

Каждая пара из двух заданий может иметь или не иметь отношение приоритета. Отношение приоритета между двумя заданиями означает, что одно задание должно быть завершено раньше другого. Например, если задание i является предшественником задания j в этом порядке, задание j может начаться только после завершения задания i.

  • prec : На отношения приоритета не накладывается никаких ограничений.
  • цепочки : каждое задание является предшественником не более чем одного другого задания и ему предшествует не более чем одно другое задание.
  • дерево: отношения приоритета должны удовлетворять одному из двух ограничений.
    • intree: Каждый узел является предшественником максимум одного другого задания.
    • outtree: Каждому узлу предшествует не более одной другой работы.
  • противопоставленный лес: если граф отношений предшествования разделен на связные компоненты , то каждый связный компонент является либо входящим, либо исходящим деревом.
  • sp-граф: Граф отношений предшествования представляет собой последовательно-параллельный граф .
  • ограниченная высота : длина самого длинного направленного пути ограничена фиксированным значением. (Направленный путь — это последовательность заданий, где каждое задание, кроме последнего, является предшественником следующего задания в последовательности.)
  • порядок уровня : Каждое задание имеет уровень, который является длиной самого длинного направленного пути, начинающегося с этого задания. Каждое задание с уровнем является предшественником каждого задания с уровнем . k {\displaystyle k} k 1 {\displaystyle k-1}
  • порядок интервала : каждая работа имеет интервал [ s x , e x ) и работа является предшественником тогда и только тогда, когда конец интервала строго меньше начала интервала для .= x {\displaystyle x} x {\displaystyle x} y {\displaystyle y} x {\displaystyle x} y {\displaystyle y}

При наличии отношения предшествования можно дополнительно предположить временные задержки . Временная задержка между двумя заданиями — это количество времени, которое необходимо подождать после завершения первого задания, прежде чем начнется второе задание. Формально, если задание i предшествует заданию j, то должно быть true. Если временная задержка не указана, то она предполагается равной нулю. Временные задержки также могут быть отрицательными. Отрицательная временная задержка означает, что второе задание может начаться за фиксированное время до завершения первого задания. C i + i j S j {\displaystyle C_{i}+\ell _{ij}\leq S_{j}} i j {\displaystyle \ell _{ij}}

  • : Временной лаг одинаков для каждой пары заданий.
  • i j {\displaystyle \ell _{ij}} : Разные пары работ могут иметь разные временные задержки.

Задержки в транспортировке

  • t j k {\displaystyle t_{jk}} : Между завершением работы машины и началом работы машины существует задержка транспортировки не менее чем на единицу. O k j {\displaystyle O_{kj}} j {\displaystyle j} k {\displaystyle k} O k + 1 , j {\displaystyle O_{k+1,j}} j {\displaystyle j} k + 1 {\displaystyle k+1} t j k {\displaystyle t_{jk}}
  • t j k l {\displaystyle t_{jkl}} : Между завершением работы машины и началом работы машины существует задержка транспортировки не менее чем на единицу. O k j {\displaystyle O_{kj}} j {\displaystyle j} k {\displaystyle k} O l , j {\displaystyle O_{l,j}} j {\displaystyle j} l {\displaystyle l} t j k l {\displaystyle t_{jkl}}
  • t k {\displaystyle t_{k}} : Задержка транспортировки, зависящая от машины. Между завершением работы машины и началом работы машины существует задержка транспортировки не менее чем на единицы. O k j {\displaystyle O_{kj}} j {\displaystyle j} k {\displaystyle k} O k + 1 , j {\displaystyle O_{k+1,j}} j {\displaystyle j} k + 1 {\displaystyle k+1} t k {\displaystyle t_{k}}
  • t k l {\displaystyle t_{kl}} : Задержка транспортировки, зависящая от пары машин. Между завершением работы машины и началом работы машины существует задержка транспортировки не менее единиц. O k j {\displaystyle O_{kj}} j {\displaystyle j} k {\displaystyle k} O l , j {\displaystyle O_{l,j}} j {\displaystyle j} l {\displaystyle l} t k l {\displaystyle t_{kl}}
  • t j {\displaystyle t_{j}} : Задержка транспортировки, зависящая от работы. Между завершением работы на машине и началом работы на машине существует задержка транспортировки не менее чем на единицы. O k j {\displaystyle O_{kj}} j {\displaystyle j} k {\displaystyle k} O l , j {\displaystyle O_{l,j}} j {\displaystyle j} l {\displaystyle l} t j {\displaystyle t_{j}}

Различные ограничения

  • rcrc : Также известно как рециркуляция или гибкий цех по работе. Обещание снято, и для некоторых пар мы можем иметь . Другими словами, возможно, что различные операции одной и той же работы будут назначены одной и той же машине. μ {\displaystyle \mu } k k {\displaystyle k\neq k'} μ k j = μ k j {\displaystyle \mu _{kj}=\mu _{k'j}}
  • no-wait : Операция должна начинаться точно тогда, когда операция завершается. Другими словами, как только одна операция задания завершается, следующая операция должна начинаться немедленно. Иногда также обозначается как ' nwt' . O k + 1 , i {\displaystyle O_{k+1,i}} O k , i {\displaystyle O_{k,i}}
  • no-idle : Ни одна машина не должна простаивать с начала своего первого выполнения до конца своего последнего выполнения.
  • size j {\displaystyle {\text{size}}_{j}} : Многопроцессорные задачи на идентичных параллельных машинах. Выполнение задания происходит одновременно на параллельных машинах. j {\displaystyle j} size j {\displaystyle {\text{size}}_{j}}
  • fix j {\displaystyle {\text{fix}}_{j}} : Многопроцессорные задачи. Каждое задание выполняется с набором машин и требует одновременного выполнения всех этих машин. Иногда также обозначается как «MPT». j {\displaystyle j} fix j { 1 , , m } {\displaystyle {\text{fix}}_{j}\subseteq \{1,\ldots ,m\}}
  • M j {\displaystyle M_{j}} : Многоцелевые машины. Каждая работа должна быть запланирована на одной машине из заданного набора . Иногда также обозначается как M j . j {\displaystyle j} M j { 1 , , m } {\displaystyle M_{j}\subseteq \{1,\ldots ,m\}}

Целевые функции

Обычно целью является минимизация некоторого объективного значения. Одно из отличий — это нотация , в которой целью является максимизация количества заданий, которые завершаются до крайнего срока. Это также называется пропускной способностью . Объективное значение может быть суммой, возможно, взвешенной некоторыми заданными весами приоритета для каждого задания. U j {\displaystyle \sum U_{j}} w j {\displaystyle w_{j}}

  • - : Отсутствие объективного значения обозначается одним тире. Это означает, что проблема заключается просто в создании допустимого расписания, удовлетворяющего всем заданным ограничениям.
  • C j {\displaystyle C_{j}} : время завершения работы . максимальное время завершения; также известное как makespan . Иногда нас интересует среднее время завершения (среднее по всем j ), которое иногда обозначается как mft (среднее время завершения). [4] j {\displaystyle j} C max {\displaystyle C_{\max }} C j {\displaystyle C_{j}}
  • F j {\displaystyle F_{j}} : Время выполнения задания — это разница между временем его завершения и временем его выпуска, т. е . . F j = C j r j {\displaystyle F_{j}=C_{j}-r_{j}}
  • L j {\displaystyle L_{j}} : Опоздание . Каждой работе присваивается дата выполнения . Опоздание работы определяется как . Иногда используется для обозначения осуществимости задачи с крайними сроками. Действительно, при использовании бинарного поиска сложность версии осуществимости эквивалентна минимизации . j {\displaystyle j} d j {\displaystyle d_{j}} j {\displaystyle j} C j d j {\displaystyle C_{j}-d_{j}} L max {\displaystyle L_{\max }} L max {\displaystyle L_{\max }}
  • U j {\displaystyle U_{j}} : Пропускная способность . Каждой работе присваивается срок выполнения . Для работ, которые завершаются вовремя, существует удельная прибыль, т. е. если и в противном случае. Иногда в литературе значение инвертируется, что эквивалентно при рассмотрении версии решения задачи, но имеет огромное значение для приближений. d j {\displaystyle d_{j}} U j = 1 {\displaystyle U_{j}=1} C j d j {\displaystyle C_{j}\leq d_{j}} U j = 0 {\displaystyle U_{j}=0} U j {\displaystyle U_{j}}
  • T j {\displaystyle T_{j}} : Опоздание . Каждой работе дается срок выполнения . Опоздание работы определяется как . j {\displaystyle j} d j {\displaystyle d_{j}} j {\displaystyle j} T j = max { 0 , C j d j } {\displaystyle T_{j}=\max\{0,C_{j}-d_{j}\}}
  • E j {\displaystyle E_{j}} : Раннее выполнение . Каждой работе назначается дата выполнения . Раннее выполнение работы определяется как . Эта цель важна для планирования «точно в срок». j {\displaystyle j} d j {\displaystyle d_{j}} j {\displaystyle j} E j = max { 0 , d j C j } {\displaystyle E_{j}=\max\{0,d_{j}-C_{j}\}}

Существуют также варианты с несколькими целями , но они гораздо менее изучены. [2]

Примеры

Вот несколько примеров задач, определенных с использованием приведенных выше обозначений. [1]

  • P 2 C max {\displaystyle P_{2}\parallel C_{\max }} – назначение каждой из заданных задач на одну из двух идентичных машин, чтобы минимизировать максимальное общее время обработки на машинах. Это оптимизационная версия проблемы разбиения n {\displaystyle n}
  • 1|prec| – назначение одной машине, процессы с общим ограничением приоритета, минимизация максимальной задержки. L max {\displaystyle L_{\max }}
  • R|pmtn| – назначение задач разному количеству несвязанных параллельных машин, что позволяет осуществлять прерывание и минимизировать общее время выполнения. C i {\displaystyle \sum C_{i}}
  • J3| | – задача цеха с тремя станками и единичным временем обработки, где целью является минимизация максимального времени завершения. p i j = 1 {\displaystyle p_{ij}=1} C max {\displaystyle C_{\max }}
  • P size j C max {\displaystyle P\mid {\text{size}}_{j}\mid C_{\max }} – назначение заданий на параллельные идентичные машины, где каждое задание поставляется с несколькими машинами, на которых оно должно быть запланировано на одно и то же время, минимизируя максимальное время завершения. См. параллельное планирование задач . m {\displaystyle m}

Другие варианты

  • Все рассмотренные выше варианты являются детерминированными в том смысле, что все данные известны планировщику. Существуют также стохастические варианты, в которых данные заранее неизвестны или могут изменяться случайным образом. [2]
  • В игре балансировки нагрузки каждая работа принадлежит стратегическому агенту, который может решать, где запланировать свою работу. Равновесие Нэша в этой игре может быть не оптимальным. Ауманн и Домбб [5] оценивают неэффективность равновесия в нескольких играх балансировки нагрузки.

Смотрите также

Ссылки

  1. ^ ab Graham, RL; Lawler, EL; Lenstra, JK; Rinnooy Kan, AHG (1979). «Оптимизация и аппроксимация в детерминированном секвенировании и планировании: обзор» (PDF) . Труды Института передовых исследований по дискретной оптимизации и системным приложениям Группы системных наук НАТО и Симпозиума по дискретной оптимизации . Elsevier. стр. (5) 287–326.
  2. ^ abc Eugene L. Lawler, Jan Karel Lenstra, Alexander HG Rinnooy Kan, David B. Shmoys (1993-01-01). "Глава 9 Последовательность и планирование: Алгоритмы и сложность". Справочники по исследованию операций и науке управления . 4 : 445–522. doi :10.1016/S0927-0507(05)80189-6. ISBN 9780444874726. ISSN  0927-0507.{{cite journal}}: CS1 maint: multiple names: authors list (link)
  3. ^ B. Chen, CN Potts и GJ Woeginger . "Обзор машинного планирования: сложность, алгоритмы и аппроксимируемость". Handbook of Combinatory Optimization (том 3) (редакторы: D.-Z. Du и P. Pardalos), 1998, Kluwer Academic Publishers. 21-169. ISBN 0-7923-5285-8 (HB) 0-7923-5019-7 (набор) 
  4. ^ Хоровиц, Эллис; Сахни, Сартай (1976-04-01). «Точные и приближенные алгоритмы планирования неидентичных процессоров». Журнал ACM . 23 (2): 317–327. doi : 10.1145/321941.321951 . ISSN  0004-5411. S2CID  18693114.
  5. ^ Ауманн, Йонатан; Домб, Яир (2010). Контогианнис, Спирос; Кутсупьяс, Элиас; Спиракис, Пол Г. (ред.). "Эффективность по Парето и приближенная эффективность по Парето в играх маршрутизации и балансировки нагрузки". Алгоритмическая теория игр . Конспект лекций по информатике. Берлин, Гейдельберг: Springer: 66–77. doi :10.1007/978-3-642-16170-4_7. ISBN 978-3-642-16170-4.
  • Scheduling zoo (Кристоф Дюрр, Сигрид Кнуст, Дэмиен Прот, Оскар С. Васкес): онлайн-инструмент для поиска оптимальной задачи планирования с использованием обозначений.
  • Результаты оценки сложности задач планирования (Питер Брукер, Сигрид Кнуст): классификация задач оптимального планирования по тому, что известно об их сложности во время выполнения.
Retrieved from "https://en.wikipedia.org/w/index.php?title=Optimal_job_scheduling&oldid=1249356890"