Исследование комбинированного решения трехиндексной задачи о назначениях::Журнал СА 05.2019
www.samag.ru
Журнал «БИТ. Бизнес&Информационные технологии»      
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Подписка
Архив номеров
Где купить
Наука и технологии
Авторам
Рекламодателям
Контакты
   

  Опросы
1001 и 1 книга  
19.03.2018г.
Просмотров: 6827
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 7359
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

12.03.2018г.
Просмотров: 4608
Комментарии: 0
Глубокое обучение с точки зрения практика

 Читать далее...

12.03.2018г.
Просмотров: 3159
Комментарии: 0
Изучаем pandas

 Читать далее...

12.03.2018г.
Просмотров: 3962
Комментарии: 0
Программирование на языке Rust (Цветное издание)

 Читать далее...

19.12.2017г.
Просмотров: 3966
Комментарии: 0
Глубокое обучение

 Читать далее...

19.12.2017г.
Просмотров: 6467
Комментарии: 0
Анализ социальных медиа на Python

 Читать далее...

19.12.2017г.
Просмотров: 3310
Комментарии: 0
Основы блокчейна

 Читать далее...

19.12.2017г.
Просмотров: 3589
Комментарии: 0
Java 9. Полный обзор нововведений

 Читать далее...

16.02.2017г.
Просмотров: 7448
Комментарии: 0
Опоздавших не бывает, или книга о стеке

 Читать далее...

17.05.2016г.
Просмотров: 10814
Комментарии: 0
Теория вычислений для программистов

 Читать далее...

30.03.2015г.
Просмотров: 12524
Комментарии: 0
От математики к обобщенному программированию

 Читать далее...

18.02.2014г.
Просмотров: 14230
Комментарии: 0
Рецензия на книгу «Читаем Тьюринга»

 Читать далее...

13.02.2014г.
Просмотров: 9262
Комментарии: 0
Читайте, размышляйте, действуйте

 Читать далее...

12.02.2014г.
Просмотров: 7210
Комментарии: 0
Рисуем наши мысли

 Читать далее...

10.02.2014г.
Просмотров: 5517
Комментарии: 3
Страна в цифрах

 Читать далее...

18.12.2013г.
Просмотров: 4746
Комментарии: 0
Большие данные меняют нашу жизнь

 Читать далее...

18.12.2013г.
Просмотров: 3564
Комментарии: 0
Компьютерные технологии – корень зла для точки роста

 Читать далее...

04.12.2013г.
Просмотров: 3274
Комментарии: 0
Паутина в облаках

 Читать далее...

03.12.2013г.
Просмотров: 3506
Комментарии: 1
Рецензия на книгу «MongoDB в действии»

 Читать далее...

02.12.2013г.
Просмотров: 3160
Комментарии: 0
Не думай о минутах свысока

 Читать далее...

Друзья сайта  

 Исследование комбинированного решения трехиндексной задачи о назначениях

Архив номеров / 2019 / Выпуск №05 (198) / Исследование комбинированного решения трехиндексной задачи о назначениях

Рубрика: Наука и технологии

Без фото АФРАЙМОВИЧ Л.Г., доцент, доктор физико-математических наук, профессор кафедры информатики и автоматизации научных исследований Института информационных технологий, математики и механики ННГУ им. Н. И. Лобачевского, г. Нижний Новгород, levafraimovich@gmail.com

Без фото ТЮНТЯЕВ А.С., программист 1-й категории управления информатизации ННГУ им. Н. И. Лобачевского, г. Нижний Новгород, tas@comp.unn.ru

Без фото ТЮНТЯЕВА Л.А., студентка 2-го курса магистратуры Института информационных технологий, математики и механики ННГУ им. Н. И. Лобачевского, г. Нижний Новгород, alilba@mail.ru

Исследование комбинированного
решения трехиндексной задачи о назначениях

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

Введение

Многоиндексные задачи о назначениях (подкласс широкого класса прикладных задач, формализуемых в виде многоиндексных задач (целочисленного) линейного программирования транспортного типа) возникают в теории расписаний, при планировании изготовления скоропортящейся продукции, при планировании прохождения практики студентами, при планировании учебы клинических ординаторов по отделениям, при составлении расписания занятий, при планировании спортивных матчей [1, 4], в области технического анализа данных при сопровождении объектов в многосенсорных системах [1, 6], в военной области при назначении военной техники на цели [1, 7].

Класс многоиндексных задач о назначениях, начиная с трехиндексных, является NP – трудным, то есть на данный момент не известны эффективные алгоритмы для их решения.

Трехиндексная аксиальная задача о назначениях (далее промто задача), подробно рассматриваемая в данной статье, является частным случаем многоиндексных задач о назначениях и имеет широкий спектр приложений [1-4, 8, 9], что говорит об ее актуальности.

В статье изложено исследование задачи, в ходе которого было сделано:

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

Цель исследования – поиск наилучшей (с точки зрения затраченного времени) комбинации параметров алгоритма (стратегий ветвления, выбора алгоритма подсчета нижних оценок) для решения поставленной задачи.

В первом разделе представлены формальное описание и математическая модель задачи.

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

В третьем разделе представлены результаты вычислительного эксперимента и сделаны выводы относительно работы реализованного алгоритма.

Формальная постановка задачи

Есть исполнители, работы и орудия труда, которыми исполнители могут пользоваться при выполнении работ. Заданы зарплаты от назначения исполнителей на работы при использовании того или иного орудия труда. Надо так назначить исполнителей на работы, чтобы:

  • каждый исполнитель получил не более одной работы и не более одного орудия труда;
  • каждую работу делал не более чем один исполнитель, не более чем одним орудием труда;
  • каждое орудие труда использовалось не более чем одним исполнителем для выполнения не более чем одной работы;
  • суммарная стоимость назначений была минимальной.

Критерии и ограничения математической модели задачи представлены ниже:

(1)

(1’)

(2)

(3)

(4)

(5)

где I=J=K={1,2,...,n} – множества работников, работ и орудий труда соответственно.

Критерий задачи (1’) записан с декомпозиционной матрицей стоимостей, где:

  • C=||cijk||n×n×n – трехиндексная матрица зарплат порядка n;
  • M1=||m1ij||n×n×n – матрица стоимости выполнения i-м работником j-й работы, ∀iI, ∀jJ;
  • M2=||m2jk||n×n×n – матрица стоимости выполнения j-й работы k-м орудием труда, ∀jJ, ∀kK;
  • M3=||m3ik||n×n×n – матрица стоимости пользования i-го исполнителя k-м орудием труда, ∀iI, ∀kK.

Далее будет рассматриваться задача с математической моделью (1’) – (5), так как архитектура построенного алгоритма работает только для задач такого вида, задача также является NP – трудной [5].

Алгоритм решения задачи

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

Элемент разбиения представляет собой последовательное назначение ikjk, ∀kK на k-м шаге ветвления. Для каждого элемента разбиения вычисляется верхняя и нижняя оценки. Также на каждом шаге элементы разбиения подвергаются процедуре отсева. Процедура отсева происходит следующим образом:

Если нижняя оценка p-го элемента разбиения (Hp, p{1,…,n}), найденная на k-м шаге ветвления (k = 1,n) не меньше, чем верхняя оценка s-го элемента разбиения на том же шаге ветвления (Bs, p{1,…,n}), то ветка (подмножество решений исходной задачи), содержащая s-й элемент разбиения, отсекается (исключается из дальнейшего рассмотрения для поиска решения).

Формальное описание условия процедуры отсева:

H≥ Вs, p, s = (1,n)

Глобальный оптимум задачи ищется на листьях, у которых известны все назначения ij симплекс-методом. Каждый такой лист содержит n! допустимых решений, оптимум среди которых можно найти за полиномиальное время за счет сведения задачи к двухиндексной задаче о назначениях.

Специфика данной архитектуры ветвления состоит в том, что она работает только для задач с декомпозиционными стоимостями.

Описание стратегий ветвления, использованных в алгоритме метода ветвей и границ:

  • Ветвление в глубину (Length) – при использовании данной стратегии на k-м шаге ветвления выбирается такой элемент разбиения, количество назначений ikjk которого наибольшее (k=1,n);
  • Ветвление в ширину (Width) – при использовании данной стратегии на k-м шаге ветвления выбирается такой элемент разбиения, количество назначений ikjk которого наименьшее (k=1,n);
  • Ветвление по минимальной верхней оценке (EffectiveHB) – при использовании данной стратегии на k-м шаге ветвления выбирается такой элемент разбиения s, верхняя оценка которого наименьшая по сравнению с верхними оценками элементов разбиения, полученных до k-го шага включительно (Bs=minBk, где Bk – множество верхних оценок элементов разбиения, известных на k-м шаге алгоритма (k=1,n);
  • Ветвление по минимальной нижней оценке (LowMax-Branch) – при использовании данной стратегии на k-м шаге ветвления выбирается такой элемент разбиения s, нижняя оценка которого наименьшая по сравнению с нижними оценками элементов разбиения, полученных до k-го шага включительно (Hs=minHk, где Hk – множество нижних оценок элементов разбиения, известных на k-м шаге алгоритма (k=1,n);
  • Ветвление по гибридной оценке (Gybrid) – при использовании данной стратегии на k-м шаге ветвления выбирается такой элемент разбиения s, отношение нижней оценки которого к верхней не менее 0,9 (Hs/Bs≥0,9). При этом на нижнюю оценку выбранного s-го элемента разбиения накладывается дополнительное условие: она должна отличаться от минимальной нижней оценки из множества, (Hk – множество нижних оценок элементов разбиения, известных на k-м шаге алгоритма (k=1,n) не более чем на 10%. (Нижние оценки, удовлетворяющие данному условию, будем называть «хорошими»). Если нет элемента разбиения, удовлетворяющего данным условиям, то берется элемент с наименьшим количеством назначений ikjk (k=1,n);
  • Ветвление по разностной оценке (Subtraction) – при использовании данной стратегии на k-м шаге ветвления выбирается такой элемент разбиения s, разность между верхней и нижней оценкой которого минимальна (Bs–Hsmin);
  • Ветвление по соотношению оценок (Ratio) – при использовании данной стратегии на k-м шаге ветвления выбирается такой элемент разбиения s, отношение нижней оценки которого к верхней максимально (Hs/Bsmax). При этом на нижнюю и верхнюю оценки выбранного s-го элемента разбиения накладываются дополнительные условия: они должны соответственно отличаться от минимальной нижней и верхней оценки из множеств HkBk (HkBk – множество нижних и верхних оценок элементов разбиения, известных на k-м шаге алгоритма (k=1,n) не более чем на 30%. Если нет элемента разбиения, удовлетворяющего данным условиям, то берется элемент с наименьшим количеством назначений ikjk (k=1,n).

При подсчете верхней оценки листа используется жадный алгоритм (для каждого элемента iI выбираются допустимые элементы jJ и kK, при которых стоимость назначения минимальна).

Подсчитать нижнюю оценку листа при реализации используемого алгоритма можно двумя способами:

  • Симплекс-метод. Идея данного метода – избавиться от целочисленности и изменить (5) ограничение задачи на ограничение вида:

(6)

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

Вычислительный эксперимент

Для решения задач данного класса описанным алгоритмом было написано программное приложение в интегрированной среде разработки Visual Studio Professional 2017 (Windows Forms, язык программирования C#).

Вычисления проводились на вычислительной технике фирмы ASUS. Процессор: Intel® Core ™ i5 – 3230M CPU @ 2.60GHz. Тип системы: 64 – разрядная операционная система, процессор х64, операционная система: Windows 8.

На рис. 1 представлено диалоговое окно приложения, в котором выбираются параметры для решения задач. В реализации алгоритма предусмотрены выбор параллельного или последовательного подсчета верхних и нижних оценок для «потомков» вершины, а также последовательный или же параллельный запуск стратегий ветвления. Приложение позволяет генерировать задачи случайным образом или решать предложенные задачи.

Рисунок 1. Диалоговое окно программного приложения

Рисунок 1. Диалоговое окно программного приложения

В ходе вычислительного эксперимента тестировались задачи размерностей (n) равных: 6 (2 задачи), 10 (2 задачи), 15 (2 задачи), 33 (задача с известным оптимумом и решением [10]).

Цели вычислительного эксперимента:

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

Стратегия подсчета нижней оценки для каждого листа выбиралась таким образом. Если у вершины «родителя» верно соотношение:

(7)

(x=0%; 5%; 10%; 20%; 30%; 50%; 100%), то у всех «наследников вершины» нижняя оценка считается потоковым алгоритмом, иначе – симплекс-методом.

Нижняя оценка начальной вершины всегда считается симплекс-методом. Давайте рассмотрим фрагмент таблицы с результатами вычислительного эксперимента (см. таблицу 1).

Таблица 1. Время работы алгоритма в зависимости от выбора параметров

n 0% 5% 10% 20% 30% 50% 100%
6 00:00,948 00:00,868 00:00,984 00:01,947 00:02,614 00:04,880 00:06,565
6 00:03,271 00:03,228 00:03,352 00:03,582 00:05,719 00:11,840 00:13,252
10 01:18,890 01:15,256 01:24,010 01:59,669 12:15,877 >20 мин >20 мин
10 00:44,207 00:43,532 00:48,158 01:13,416 05:43,865 >20 мин >20 мин
15 04:26,672 04:31,905 04:37,223 >20 мин >20 мин >20 мин >20 мин
15 04:46,914 04:51,590 04:59,800 09:01,099 >20 мин >20 мин >20 мин

В первом столбце приведены размерности тестируемых задач. В следующих столбцах приведено время (мин:сек, мсек) работы алгоритма в зависимости от выбранных параметров, где первая строка – процент, меньше которого должно быть соотношение (8), чтобы нижняя оценка вершины «потомка» считалась потоковым алгоритмом.

Задачи размерности, начиная с n=15 при параллельном запуске подсчета оценок, считаются дольше 30 мин, поэтому задачи размерностей выше 15 будем считать второй по эффективности (выявлено из предыдущих экспериментов) стратегией ветвления EffectiveHB, так как при решении самой эффективной стратегией LowMaxBranch при выборе процентов для соотношения (7) в диапазоне 5-30% разница времен выполнения задачи несущественна.

На рис. 2 представлено решение задачи размерностью 33 с известным оптимумом.

Рисунок 2. Решение задачи размерностью n=33

Рисунок 2. Решение задачи размерностью n=33

Решение, полученное нашим алгоритмом, совпадает с известным оптимумом, что говорит о том, что реализованный алгоритм работает верно, ошибок в реализации нет.

Заключение

В ходе исследования и вычислительного эксперимента было установлено:

  • При решении задач с известными оптимальными решениями [10] вышеизложенным алгоритмом решения совпали с известными решениями;
  • Выявлено, что при выполнении соотношения (8) в диапазоне 5-10% тестировавшиеся задачи считаются наименьшее время. Однако при решении задач больших размерностей данный алгоритм не всегда находит решение за приемлемое время. Следовательно, чтобы сократить время решения задач больших размерностей, планируется усовершенствование данного алгоритма, например реализация других алгоритмов подсчета верхней, нижней оценок, более детальное распараллеливание алгоритма и т.д.
  1. He Jiang, Shuwei Zhang, Zhilei Ren, Xiaochen Lai, and Yong Piao «Approximate Muscle Guided Beam Search for Three-Index Assignment Problem» Software School, Dalian University of Technology, Dalian,116621,China jiangle@dlut.edu.cn
  2. Ficker A. M. C., Afraimovich L. G., F. C. R. Spieksma The axial 3Dimensional Problem with perimeter costs revisited. Proceedings of the 12th Workshop on Models and Algorithms for Planning and Scheduling Problems. MAPSP 2015. La Roche-en-Ardenne, Belgium. 8-12 June 2015. P. 83-85.
  3. Афраймович Л. Г. Эвристические методы решения целочисленных декомпозиционных многоиндексных задач // Автоматика и телемеханика, 2014. № 8. С. 3-18.
  4. Афраймович Л. Г. Многоиндексные транспортные задачи с 2-вложенной структурой // Автоматика и телемеханика, 2013. № 1. С. 116-134.
  5. Burkard R. E., Rudolf R., Woeginger G. J. Three-dimensional axial assignment problems with decomposable cost coefficients // Discrete Applied Mathematics. 1996. V. 65. P. 123-139.
  6. Pusztaszeri J. F., Rensing P. E., Liebling T. M. Tracking elementary particles near their primary vertex: A combinatorial approach // Journal of Global Optimization. 1996. V. 9. P. 41-64.
  7. Alighanbari M., How J.P. Cooperative task assignment of unmanned aerial vehicles in adversarial environments // Proceedings of the American Control Conference. 2005. V. 7. P. 4661-4666.
  8. Афраймович Л. Г., Прилуцкий М. Х. Многоиндексные задачи оптимального планирования производства // Автоматика и телемеханика. 2010. № 10. C. 148-155.
  9. Афраймович Л. Г. Многоиндексные транспортные задачи с декомпозиционной структурой // Автоматика и телемеханика. 2012. № 1. С. 130-147.
  10. http://www.win.tue.nl/~fspieksma/instancesEJOR.htm

Ключевые слова: исследование, комбинированное рещение, трехиндексноая задача.


Investigation of the combined solution of the three-index assignment problem

Afraimovich L.G., Associate Professor, Doctor of Physics and Mathematics, Professor at the Department of Informatics and Automation of Scientific Research of the Institute of Information Technologies, Mathematics and Mechanics of UNN them. N. I. Lobachevsky, Nizhny Novgorod, levafraimovich@gmail.com

Tyuntyayev A.S., programmer of the 1st category of management of informatization of UNN named after NI Lobachevsky, Nizhny Novgorod, tas@comp.unn.ru

Tyuntyaeva L.A., 2nd year master student at the Institute of Information Technology, Mathematics and UNN them. N.I. Lobachevsky, Nizhny Novgorod, alilba@mail.ru

Abstract: In the age of information technology, many actions have become automated and most effectively solved. The solutions of some problems have also become more simplified and fast, however, there are a number of problems that, for large dimensions or data, cannot be solved in polynomial time. This article describes one of the classes of such tasks, the class of multi-index assignment problems. The article proves the relevance of the tasks of this class, provides a formal description and a mathematical model, and also understands the implemented algorithm, gives the results of a computational experiment and draws conclusions.

Keywords: research, combined decision, three-index task.


Комментарии отсутствуют

Добавить комментарий

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-45
E-mail: sa@samag.ru