Научная статья на тему 'Алгоритм для календарного планирования'

Алгоритм для календарного планирования Текст научной статьи по специальности «Математика»

CC BY
758
91
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
ГЕНЕТИЧЕСКИЙ АЛГОРИТМ / ДИСКРЕТНАЯ ЗАДАЧА РАЗМЕЩЕНИЯ / ОПЕРАТИВНОЕ КАЛЕНДАРНОЕ ПЛАНИРОВАНИЕ / P-МЕДИАННАЯ ЗАДАЧА / GENETIC ALGORITHM / DISCRETE LOCATION PROBLEM / OPERATIONS SCHEDULING / P-MEDIAN PROBLEM

Аннотация научной статьи по математике, автор научной работы — Казаковцев Л. А., Антамошкин А. Н.

Задача расчета оптимальной загрузки производственных линий с непрерывным производственым циклом (например, литейно-прокатное производство), согласно заданному плану выпуска продукции, представлена в виде задачи размещения на сети. Для решения задачи применен генетический алгоритм с жадной эвристикой на основе аналогичного алгоритма для p-медианной задачи.

i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по математике , автор научной работы — Казаковцев Л. А., Антамошкин А. Н.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

ALGORITHM FOR CAPACITY SCHEDULING

A problem of optimal capacity planning of the production lines with a continuous manufacturing cycle (foundry for example) in accordance with a given product launch plan is considered as a discrete location problem on a network. For solving the problem, we use genetic algorithm with greedy heuristics based on an analogous algorithm for the p-median problem.

Текст научной работы на тему «Алгоритм для календарного планирования»

ВестникКрасГАУ. 2015. № 4

УДК 519.6 Л.А. Казаковцев, А.Н. Антамошкин

АЛГОРИТМ ДЛЯ КАЛЕНДАРНОГО ПЛАНИРОВАНИЯ

Задача расчета оптимальной загрузки производственных линий с непрерывным производственым циклом (например, литейно-прокатное производство), согласно заданному плану выпуска продукции, представлена в виде задачи размещения на сети. Для решения задачи применен генетический алгоритм с жадной эвристикой на основе аналогичного алгоритма для p-медианной задачи.

Ключевые слова: генетический алгоритм, дискретная задача размещения, оперативное календарное планирование, p-медианная задача.

L.A. Kazakovtsev, A.N. Antamoshkin ALGORITHM FOR CAPACITY SCHEDULING

A problem of optimal capacity planning of the production lines with a continuous manufacturing cycle (foundry for example) in accordance with a given product launch plan is considered as a discrete location problem on a network. For solving the problem, we use genetic algorithm with greedy heuristics based on an analogous algorithm for the p-median problem.

Key words: genetic algorithm, discrete location problem, operations scheduling, p-median problem.

Введение. Одной из основ эффективной работы предприятия является процедура календарного планирования производства, включая расчет производственного расписания [1]. Рассмотрим следующую задачу [2, 3]. Пусть имеется К производственных линий для выпуска I видов продукции. Производительность всех производственных линий одинакова, для 1-го вида продукции линия может произвести единиц продукции за смену при трех сменах в сутки. Требуется построить график с указанием вида продукции для производственной линии. Вводится матрица I булевых констант гк1,к = 1,К,1 = 1,1, равных 1, если к-я линия может производить 1-й вид продукции, и 0 - в противном случае. Для каждого вида продукции установлен производственный план в объеме Шг единиц (I = 1,1), который должен быть выполнен за Т суток. Кроме того, установлена минимальная суммарная загруженность производственного комплекса в сутки в объеме единиц продукции. При смене вида продукции могут требоваться некоторые технологические операции продолжительностью в одну смену, в ходе которых выпуск продукции линией невозможен. Возможность безостановочной смены продукции с вида I на вид г описывается симметричной матрицей булевых констант С1г размерности 1x1: значение С1г = 1 означает необходимость останова производственной линии при смене продукции с 1-го вида на г-й вид, С1/г = 0 - возможность безостановочного переключения производства. График на I суток требуется составить так, чтобы при условии выполнения плана выпуска по видам продукции и срокам, с учетом требования минимальной загруженности, требовалось минимальное число изменений видов продукции.

В р-медианной задаче на сети [4, 5] требуется найти p узлов сети, таких, чтобы сумма взвешенных расстояний от каждого из узлов сети до ближайшего из выбранных узлов была минимальной (каждому из ребер поставлено в соответствие число - его длина). В общем случае задача NP - трудная. Генетический алгоритм с жадной эвристикой [5, 6] - эффективное средство ее решения. В настоящей работе задача составления графика загрузки производственных мощностей формулируется как задача размещения на сети. Вычислительные эксперименты показывают высокую эффективность такого подхода по сравнению с существующими методами [2].

1. Математическая постановка задачи

Приведем постановку р-медианной задачи [4]. На некоторой сети (связном графе) д = (V, £), где V -множество узлов (вершин), а £ - множество попарно соединяющих их ребер Е^, Ь,] е V, каждому из которых поставлено в соответствие число - его длина , определена метрика расстояния й (Ь,]) между любой парой узлов Ь и ] как минимальная длина пути между этими узлами (длина пути - сумма длин входящих в него ребер). Цель состоит в выборе множества узлов сети (вершин графа) 5 заданной мощности р

arg min (S) = arg min minD (j,y) . (1)

Представим производственный график в виде трехмерной решетки в дискетной системе координат с осями i,/c,Z (время, производственные линиии, виды продукции). Каждый узел такой сети-решетки будем описывать тройкой его координат ( ¿, //1). Решению нашей задачи поставим в соответствие некоторое подмножество х узлов нашей сети-решетки, задающих моменты переключения видов продукции на нашем графике. Задача состоит в выборе минимального по мощности множества х узлов сети, удовлетворяющего заданным ограничениям.

Введем целочисленные переменные y'ifc. Значение y'jfc = i будет означать выпуск I-го вида продукции на //-й линии в ¿-е сутки (значение y'ik = 0 - отсутствие выпуска). Пусть у' ofc, / = 1 ,К -целочисленные константы, имеющие значения от до , показывающие, на какой вид продукции настроена каждая из К линий в начальный момент времени. Для удобства описания введем дополнительные зависимые переменные

, (У i,k' У У (i-l),k' Т~-7 1 У i,k У i-l,k'

Значения могут быть получены из

УиЧ^' TU « = =

I xi,k' xi,k ^ и

и вспомогательные булевы переменные (в работе [2] задача сформулирована именно в булевых переменных)

а, у\k = i, _ _ _

У,к, i = 1n V1' =t/ Vi = 1 ,/,к = = 1

lu' У i,k ^

Множества % выбранных определяют значения переменных

[I, (i, k, I) б х.

_а, (i,к, х и ' к {о , ( i ,к ,

Операция включения узла ( ¿, //, Z ) в множество j, таким образом, сводится с присвоению переменной х' j, к значения Z, исключения - к присвоению значения 0.

Ограничения задачи сформулируем следующим образом:

/г (j) = - Zf= i m ах{0 , Щ - у ^, ZL i У,, к, г ( 3 - C'y (i i) fc,y J } = 0 , (2)

/з (j) = -Z=i m ах{ 0 ,Щт,n - l£= i l[= i У 'y ;( 3 - C'y ( t_ г} fc ,y ,fc ) } = 0 . (3)

Здесь C' г,г - матрица Cir, дополненная нулевыми строкой и столбцом

(Cl r, I > 0, г > О, C ' г , r = j0 ,' г = 0 ,

11, i = 0, г > 0;

У' - вектор норм производства У, дополненный нулевым элементом Vo=0. Определим также целевую функцию / (j) = |j|.

Вестник^КрасТЯУ. 2015. № 4

Экономический смысл функции f2(j) - общее количество продукции, выпускаемой с отставанием от плана, функции f3(j) - суммарное недовыполнение суточного минимума выпускаемой продукции. Определим также единую штрафную функцию: f4 (j) = f2 (j) + f3 (j).

2. Описание алгоритма

Идея генетического алгоритма с жадной эвристикой для р-медианной задачи на сети [5] состоит в следующем. Имеется некоторый массив ("популяция") решений задачи, каждое из которых представляет собой множество из р выбранных узлов сети. Случайным образом выбираются два решения (родительские "особи"). В качестве промежуточного решения принимается множество узлов, являющееся объединением выбранных "родительских" множеств, из которого по одному исключаются те узлы, удаление которых дает наименьший прирост целевой функции (1), пока не останется р узлов.

Наша задача, в отличие от р-медианной, - задача условной оптимизации. Задачу поиска решений, удовлетворяющих условиям (2) и (3), можно рассматривать как задачу минимизации функции fA(j). Характер генетического алгоритма не требует наличия единственного критерия оценки решений. Мы применим скоринг по трем критериям: значение целевой функции и значения штрафных функций f2 (j), f з (j) . Кроме того, в р-медианной задаче число вершин р известно, в нашей задаче целью является его минимизация.

Общую схему алгоритма можно описать следующим образом.

Алгоритм 1. Генетический алгоритм с жадной эвристикой.

Шаг 1. Сгенерировать начальный массив множеств узлов сети, представленных тройками индексов (i,k,l): А = {jj} = {(i 1 ,ki,li) ,...,(ipj,kPj)}, j = 1 ,N. Здесь N - число "особей" популяции генетического алгоритма.

Шаг 2. Выбрать случайным образом два индекса родительских "особей" j1 ,j2 е { 1 ,N} , j1 Ф j2 и индекс . Здесь - множество индексов "особей" (элементов массива ), оцениваемых как "плохие" (см. ниже).

Шаг 3. Присвоить j j3 = j j1 и jb.

Шаг 4. Выполнить процедуру мутации множества j j (опционально).

Шаг 5. Для каждого узла V = (i 1 ,k1 ,l^ е j j выполнять: если 3 V2 = (i2,k2,l2)ejj -.l2Ф h>i2 = h,k2 = къ то выбрать случайным образом индекс l е { ^ ,l2}, присвоить jj3 = jj3\{(i-t,k1 ,l)} ; следующая итерация цикла 5.

Шаг 6. Вычислить соответствующие множеству jj3 матрицы переменных [ytiк,t], [х'к], [y'ik]. Присвоить .

Шаг 7. Разместив узлы множества j j в случайном порядке, для каждого узла V = (i', k, l') е j j выполнять:

Шаг 7.1. Присвоить % = jj3\{V}. Вычислить соответствующие множеству % матрицы булевых и целочисленных переменных [yfkl], [XIк] и [y' fk]. Если f4(%) < f4(jj ), то присвоить jj =%, перерассчитать соответствущие матрицы переменных , и . Перейти к 7.3. ,

Шаг 7.2. Выполнить процедуры локального поиска в окрестности узла .

Шаг 7.3. Следующая итерация цикла 7.

Шаг 8. Если FО UND = 1 , то присвоить FOUND=0 и начать цикл 7 заново.

Шаг 9. Проверить условия останова и перейти к шагу 2.

Мы использовали следующий алгоритм генерации начальной популяции, гарантирующий соответствие каждого решения ограничениям.

Алгоритм 2. Создание одной особи начальной популяции. Дано: число узлов сети р.

Шаг 1. Присвоить х' i,к = ОVi = 1J, k = 1 ,К.

Шаг 2. Для j = 1 ,р выполнять:

Шаг 2.1. Выбрать случайное k е { 1 ,К} . Рассчитать Z к = Y,i=1 zkiг - число видов продукции, которую можно производить на k-й линии. Выбрать случайное т е { 1 ,Zk}. Найти индекс m-го по счету ненулевого элемента -го столбца матрицы , сохранить этот индекс в переменную . Выбрать

случайное i е { 1, Tt}. Если х' ikк = О , то присвоить х' ikк = l. Иначе начать шаг 2.1 сначала.

Шаг 2.2. Следующая итерация цикла 2.

Практика показывает, что наилучшие результаты достигаются, если р в различных экземплярах исходной популяции варьируется в широких пределах - в диапазоне {L,K • I/ 2 }. Мы определяем его как р = [L + j(К •I/ 2 - L) /N] , здесь j - номер генерируемого экземпляра; N - число экземпляров в популяции; [ • ] - целая часть числа. Эмпирическим путем установлено, что значение N = I + К + L является достаточным, дальнейшее увеличение не приводит к улучшению результатов, лишь увеличивая время их достижения.

В качестве вспомогательных используются процедуры локального поиска в окрестности узла "У. Окрестностью в данном контексте будем называть множество узлов, отличающихся от "У значением координаты г (соответствует замене вида продукции) либо координаты i .

Процедура 1. Выполняется для вершины "У = ( i, /с, г) при условии 1 У*,fc, г( 3-

v' ) > Составить множество индексов видов продукции SL, удовлетворяющих

Efc=1 У* fc г( 3 - С.; ' ) < Выбрать случайным образом индекс г 2 из этого множества.

Вычислить f = (ху3\{"}) и { ( i , // , г2) } . Если /4 (f) < /4 (хь) , то присвоить х7з = f, FО//ND = 1 .

Процедура 2. Выполняется для вершины "У = ( i,/с, г) при условии i > 1 и ( i - 1 ,/с, г ) g хУз. Вычислить . Если , то присвоить , .

Процедура 3. Выполняется для вершины "У = ( i ,/с , г ) при условии i < Гг(i + 1 ,/с , г)€ху3. Вычислить f = (хь\ {"У}) и { ( i + 1 , /с, г ) } . Если /4 (О < /4(х7з), то присвоить х ]з = f, FО //ND = 1 .

Процедура 4. Мутация множества хУз. Выполняется с некоторой заданной вероятностью рт. Сгенерировать множество f c помощью алгоритма 2 с параметром р = |хУз|. Присвоить хУз = Xy3 и f. Экспериментально установлены оптимальные значения рт е [0, 0 0 5; 0, 0 3 ] при наличии процедур 2 и 3 и рт е [ 0 , 0 1 ; 0, 0 5 ] при наличии всех процедур локального поиска 1-3. Процедура 5. Определение множества w методом скоринга.

Шаг 1. Присвоить Sn = 0 , Fn = |хп| Vn = 1 ,N. Отсортировать массив F по возрастанию. Найти медианное значение .

Шаг 2. Присвоить Fn = /4(хп) Vn = 1 ,N. Для n е { 1 ,N}:|хп|</' присвоить Sn = Sn + 1 . Отсортировать массив в порядке возрастания. Найти медианное значение .

Шаг 3. Для n е {17N} :/4 (хп) < /'4 присвоить Sn = Sn + 2 . Шаг 4. Для n е { 1 ,N}: /2 (хп) = 0 присвоить Sn = Sn + 1 . Шаг 5. Для n е { 1 ,N}: /3 (хп) = 0 присвоить Sn = Sn + 1 .

Шаг 6. Найти наименьший индекс n е { 1 ,N}: /4 (хп) = 0 и |хп| = min |х0|. Если такой индекс

<?e{i,JV}

существует, то присвоить .

Шаг 7. Отсортировать массив S в порядке возрастания. Найти медианное значение s ' = S' [W/ 2] .

Возвратить результат - множество w = { n е { 1 , N}|Sn > s ' }.

Данная процедура требует достаточно больших вычислительных затрат, Поэтому процедура выполняется на шаге 2 после генерации начальной популяции, а также через каждые итераций. 3. Результаты

Алгоритм 2 реализован на языке Fortran 90 (компилятор ifort с опцией оптимизации кода и распаралеливания вычислений -O3). Для экспериментов использовалась вычислительная система Depo X8Sti (6-ядерное ЦПУ Xeon X5650 2.67 ГГц,12 Гб ОЗУ), технология hyperthreading отключена.

Получены результаты для задачи с параметрами, приведенными в работе [2] (L = 3 4, К = 2 8 , I = 3 1 ), но с более жесткими ограничениями (2) и (3): Гг е { 1 0, 3 1 }, VKm*n = 1 9 2 5 , Уг е [40, 5 0] , УКг е [2 0,2 5 0 0 0] . Всего использовано 10 наборов исходных данных, для каждого из них производилось по 10 запусков алгоритма в различных модификациях. На рисунке приведена зависимость наилучшего допустимого (т.е. ) решения от затраченного времени. Экспериментально выведено оптимальное

для большинства случаев значение размера популяции N=I+K+L. Также даны результаты алгоритма локального поиска, составленного только из процедур 1, 2, 3. Параметры алгоритма: вероятность мутации рт = 0,01.

Вестни^КрасТЯУ. 2015. № 4

Й н

Л

ч 63

(D

а

«

s В

f

£

300

Время 1 с

Результаты и влияние размера популяции на результат: 1 - алгоритм 2 без процедур 1 - 3, N = 8 9 ;

2 - с процедурами 1-3, N= 8 9; 3 - без процедур 1-3, N = 5 0 0; 4 - с процедурами 1 - 3, N = 5 О 0 ;

5 - алгоритм локального поиска процедурами 1-3 с мультистартом

С учетом того, что время работы алгоритма, предложенного в работе [2], составляет 8-1 0 5 секунд, результаты, достигнутые в настоящей работе, можно считать убедительными.

Заключение. Задача календарного планирования загрузки производственных мощностей непрерывного производства может рассматриваться как дискретная задача размещения. Предложенный алгоритм на базе генетического алгоритма с жадной эвристикой для р-медианных задач решает поставленные задачи, при этом затрачиваемое на решение время на несколько порядков меньше, чем в случае применения существущего алгоритма псевдобулевой оптимизации.

Литература

1. Фролов Е. Оперативное планирование производства // Директор информационной службы. - 2013. -Вып. 5. - URL: http://www.osp.ru/cio/2013/05/13035711/ (дата обращения: 01.10.2013).

2. Antamoshkin A., Masich I. Pseudo-Boolean Optimization in Case of an Unconnected Feasible Set, in: "Models and Algorithms for Global Optimization" // Optimization and Its Applications. - 2007. - V. 4. - P.111-122.

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

3. Kazakovtsev L.A., Gudyma M.N., Antamoshkin A.N. Genetic Algorithm with Greedy Heuristic for Capacity Planning // 6th International Congress on Ultra Modern Telecommunications and Control Systems and Workshops (ICUMT). - S.-Petersburg, 2014. - 6-8 October. - Р. 607-613.

4. Avella P., Sassano A., Vasil'ev I. Computational Study of Large-Scale p-Median Problems // Mathematical Programming. - 2007. - Issue 109(1). - P. 89-114.

5. Antamoshkin A.N., Kazakovtsev L.A. Random Search Algorithm for the p-Median Problem // Informatica. -2013. - V. 37(3). - P. 267-278.

6. Alp O., Erkut E, Drezner Z. An Efficient Genetic Algorithm for the p-Median Problem // Annals of Operations Research. - 2003. - V.122(1-4). - P. 21-42.

i Надоели баннеры? Вы всегда можете отключить рекламу.