На правах рукописи
ЛОПАТИН Роман Сергеевич
МАТЕМАТИЧЕСКОЕ И ПРОГРАММНОЕ ОБЕСПЕЧЕНИЕ ПЛАНИРОВАНИЯ ЗАДАЧ РАСПРЕДЕЛЕННОЙ ВЫЧИСЛИТЕЛЬНОЙ СИСТЕМЫ НА ОСНОВЕ МУЛЬТИАГЕНТНОГО ПОДХОДА
Специальность: 05.13.11 - Математическое и программное обеспечение вычислительных машин, комплексов и компьютерных сетей
АВТОРЕФЕРАТ
диссертации на соискание ученой степени кандидата технических наук
Воронеж - 2012
Работа выполнена в ФГБОУ ВПО Воронежский государственный технический университет.
Научный руководитель Олейникова Светлана Александровна кандидат технических наук, доцент, Воронежский государственный технический университет, доцент кафедры автоматизированных и вычислительных систем
Официальные оппоненты: Блюмин Семен Львович, доктор физико-математических наук, профессор, Липецкий государственный технический университет, профессор кафедры прикладной математики;
Авсеева Ольга Владимировна, кандидат технических наук, доцент, Воронежский государственный университет инженерных технологий, доцент кафедры информационных технологий моделирования и управления Ведущая организация Нижегородский государственный технический университет им. Р.Е.
Алексеева
Защита состоится 26 апреля 2012 г. в 1000 часов в конференц-зале на заседании диссертационного совета Д212.037.01 ФГБОУ ВПО Воронежский государственный технический университет по адресу: 394026, г. Воронеж, Московский просп., 14, конференц-зал
С диссертацией можно ознакомиться в научно-технической библиотеке ФБГОУ ВПО Воронежский государственный технический университет.
Автореферат разослан л19 марта 2012 г.
Ученый секретарь диссертационного совета Барабанов Владимир Федорович
ОБЩАЯ ХАРАКТЕРИСТИКА РАБОТЫ
Актуальность темы Организация планирования работы больших систем представляет собой сложный процесс, требующий значительных временных ресурсов. Наличие нескольких центров обслуживания, большое количество работ, жесткие ограничения на ресурсы - все это обуславливает необходимость разработки математического, алгоритмического и программного обеспечения для решения данной задачи.
В связи с возможностью распараллеливания большинства операций, наиболее эффективным способом решения такой задачи является разработка распределенной системы, компоненты которой выполняли бы отдельные операции по планированию.
Разработка параллельных и распределенных вычислений начала интенсивно развиваться в 70-х годах прошлого века. Большой вклад в становление и развитие кластерных вычислений и грид-систем внесли такие ученые, как Г. Пфистер, И. Фостер, К. Кессельман, С. Тики и др. Теория многоагентных систем появилась, в частности, благодаря методам теории принятий решений в команде, одними из авторов которых были Д. Маршак, Р. Раднер и др.
Мультиагентные системы получили свое развитие благодаря таким ученым, как С. Рассел, П. Норвиг, И. Шоэм, Д.А. Поспелов, В.Б. Тарасов и многим другим.
Однако, использование распределенных систем применительно к решению задачи планирования задач практически отсутствуют. Почти все виды данных задач отличаются NP-полнотой и требуют существенных временных затрат для своего решения. Данный процесс является итеративным, и на каждой операции выполняется планирование, например, для определенной машины. В связи с этим для больших систем с огромным числом работ целесообразно распараллелить некоторые вычисления и использовать теорию многоагентных систем для организации планирования работ с несколькими машинами.
Таким образом, актуальность диссертационной работы продиктована необходимостью сокращения времени, затрачиваемого на решение задач планирования работ за счет использования параллельного выполнения некоторых операций и использования многоагентного подхода.
Тематика диссертационной работы соответствует научному направлению ФГБОУ ВПО Воронежский государственный технический университет Вычислительные комплексы и проблемно-ориентированные системы управления.
Цель работы. Целью работы является разработка математического, алгоритмического и программного обеспечения для функционирования распределенной вычислительной системы, предназначенной для планирования задач.
Задачи исследования. Для достижения поставленной цели необходимо решить следующие задачи:
1) разработать структуру системы, предназначенной для распределенной обработки данных, поступающих от линтеллектуальных агентов;
2) разработать математическое и алгоритмическое обеспечение, позволяющее интеллектуальному агенту принимать решение о планировании работ;
3) спроектировать алгоритмы, языки и программные инструменты для организации взаимодействия интеллектуальных агентов;
4) реализовать программные средства, позволяющие осуществлять процесс планирования.
Методы исследования. При решении поставленных в диссертации задач использовались методы теории многоагентных систем, теории распределенных вычислений, теории принятия решений, а также методы объектноориентированного программирования.
Тематика работы соответствует следующим пунктам паспорта специальности 05.13.11 Математическое и программное обеспечение вычислительных машин, комплексов и компьютерных сетей: п.3 Модели, методы, алгоритмы, языки и программные инструменты для организации взаимодействия программ и программных систем и п. 8 Модели и методы создания программ и программных систем для параллельной и распределенной обработки данных, языки и инструментальные средства параллельного программирования.
Научная новизна работы. В диссертации получены следующие результаты, характеризующиеся научной новизной:
1. Математическое обеспечение для системы принятия решений интеллектуального агента, отличающееся возможностью выбора целевой функции и ограничений, а также учитывающее ограничения, накладываемые другими агентами, и обеспечивающее возможность планирования работ для данного агента с учетом выбранного критерия и имеющихся ограничений.
2. Алгоритм для распределенной обработки данных в мультиагентной системе, учитывающий предпочтения и ограничения всех агентов и обеспечивающий сокращение времени, затрачиваемое на процесс составления расписания за счет параллелизма выполнения отдельных операций.
3. Лингвистические механизмы обеспечения межмодульного взаимодействия с коммуникационной подсистемой, учитывающие специфику передаваемых команд и обеспечивающих гарантированную доставку групповых сообщений.
4. Программное обеспечение процесса планирования работ, учитывающие параллелизм выполнения отдельных этапов агентами и обеспечивающее автоматизацию процесса планирования.
Практическая значимость работы. Практическая значимость работы заключается в разработке программного обеспечения, позволяющего осуществлять процесс планирования на примере составления расписания учебных занятий. Программное обеспечение, реализованное в составе центра управления и интеллектуальных агентов, отличается распределенностью компонент и параллелизмом их функционирования.
Результаты внедрения. Разработанный программный комплекс в составе программных компонент, представляющих собой центр управления и интеллектуальных агентов, апробирован в НОУ ВПО Международный институт компьютерных технологий для планирования расписания учебных занятий. Эффект от внедрения заключается в сокращении времени, затрачиваемого на процесс планирования.
Апробация работы. Основные положения диссертационного исследования докладывались на следующих Международных и Российских конференциях: I Всероссийской научно-практической конференции Критические технологии вычислительных и информационных систем (Воронеж, 2011), IV Международной научно-практической конференции Перспективы развития информационных технологий (Новосибирск, 2011), V Международной конференции Актуальные вопросы современной техники и технологии (Липецк, 2011), III Международной научно-практической конференции Применение инновационных технологий в научных исследованиях (Курск, 2011), Всероссийской научной школе Информационно-телекоммуникационные системы и управление (Воронеж, 2011), Современные проблемы информатизации (Воронеж, 2012).
Публикации. По результатам диссертационного исследования опубликовано 13 работ, из которых 3 опубликованы в журналах, рекомендованных ВАК РФ. В статьях, опубликованных в соавторстве, лично автором получены следующие результаты: [1] - разработка структуры распределенной системы;
[2, 3] Цматематическое обеспечение для распределенной системы; [5] - оценка возможности распараллеливания работ при формировании расписания; [8, 10] - алгоритмическое обеспечение функционирования системы и ее отдельных компонент; [12,13] - реализация программного обеспечения для процесса планирования.
Структура и объем работы. Диссертационная работа состоит из введения, четырех глав, заключения, списка литературы из 108 наименований.
Основная часть работы изложена на 129 страницах, содержит 28 рисунков, таблиц.
ОСНОВНОЕ СОДЕРЖАНИЕ РАБОТЫ
.
Во введении обоснована актуальность исследования, сформулированы цель и задачи исследования, их научная новизна и практическая значимость полученных результатов, приведены сведения об апробации и внедрении работы.
В первой главе описывается специфика функционирования распределенных систем и особенности организации межмодульного взаимодействия между компонентами таких систем. Первая часть посвящена классификации многоагентных систем и особенностям их применения для описания функционирования распределенных систем. Во второй части описываются особенности межмодульного взаимодействия распределенных систем и обзор основных протоколов для обмена данными по сети. Специфика задачи пла нирования загрузки сложных систем приведена в третьей части главы. В четвертой части приведены цель и задачи диссертационного исследования.
Вторая глава посвящена разработке распределенной системы планирования задач, а также математического и алгоритмического ее обеспечения.
Пусть имеется p машин M1,Е,Mp, причем каждая машина j выполняет работы wj1,Е, wj kj, 1,Е,p. Каждая работа предназначена для обслуживания некоторой заявки zr, r=1,Е,k и требует для своего выполнения одного из q видов ресурсов. Всего имеется ri, единиц ресурса типа i, i=1,Е,q. Процесс обслуживания любой заявки представляет собой перечень работ wr1,Е, wr kr.
Необходимо составить план-график выполнения работ. Графически данную систему можно отобразить следующим образом (рисунок 1).
Рисунок 1 - Структура распределенной системы Опишем данную задачу математически. Пусть качество составленного расписания задается некоторой целевой функцией F(S(M1),Е, S(Mp)), где p - число машин, выполняющих расписание. Здесь S(Mj) - некоторое расписа ние, составленное для машины j, j=1,Е,p. Оно представляет собой множество, каждый элемент l которого определяет время, в которое будет выполняться работа l.
S(Mj)={T(wj1), T(wj2),Е,T(wj kj)}. (1) Здесь wj1, wj2, Е, wj kj - работы, которые необходимо выполнить машине j, а T(wj1), T(wj2),Е,T(wj kj) - время выполнения этих работ.
В качестве ограничений используем ограничения на запрет одновременного проведения работ по обслуживанию одной заявки в одно время.
T(wr1) T(wr2)... T(wr _ mr),r = 1,...,k. (2) Еще одно ограничение необходимо ввести для учета количества используемых ресурсов каждого типа. Пусть существует q типов ресурсов:
r1,Е,rq. Пусть V(i,t) - функция, описывающая количество используемых ресурсов i-го типа в момент времени t. Тогда ограничение на ресурсы можно описать следующим образом:
V(i, t) ri,i = 1,...,q. (3) Тогда математически задачу планирования работ можно записать следующим образом:
F (S(M1)) extr;
D1(t) V (i,t) ri,i = 1,...,q (wr1) ) ),r = 1,...,k.
T T(wr2 ... T(wr _ mr D1(t) .
...
(4) F(S(Mp)) extr;
Dp (t) V (i,t) ri,i = 1,...,q (wr1) ) ),r T T(wr2 ... T(wr _ mr = 1,...,k.
Dp (t) .
Здесь D1(t),Е,Dp(t) - множества, представляющие собой число способов расстановки расписания для машин 1,Е, p соответственно.
Алгоритм решаемой задачи можно описать следующим образом (рисунок 2).
Таким образом, на основании специфики данной задачи можно для ее решения предложить распределенную структуру. Для ее формирования необходимо решить следующие задачи:
- определить состав системы (т.е. множество ее участников);
- определить связи между элементами системы (т.е. ее структуру);
- определить множество допустимых действий участников системы, отражающих существующие физические, нормативные и др. ограничения, в которых могут находиться участники системы;
- целевые функции, описывающие интересы и предпочтения участников;
- информированность и порядок функционирования.
Рисунок 2 - общий алгоритм планирования загрузки агентов Исходя из этого, была предложена структура, состоящая из интеллектуальных агентов, которые будут формировать расписание для каждой машины, и центра управления, предназначенного для координации процесса планирования и его контроля. Структура системы, а также связь между элементами отражена на рисунке 3.
Рисунок 3 - Структура мультиагентной системы Здесь символами ИА1,Е, ИАn обозначены интеллектуальные агенты;
CNI (Central - Network Interface) - интерфейс, необходимый для взаимодействия центра с другими компонентами по сети; ANI (Agent - Network Interface) - интерфейс, необходимый для взаимодействия интеллектуальных агентов по сети; БД - база данных, в которой хранится расписание, составляемое на каждом шаге; Средства удаленного доступа к БД - компоненты, предназначенные для организации удаленного соединения пользователей с СУБД FireBird. З1,Е,Зk - множество заявок; ОРР - общий разделяемый ресурс.
Следующим этапом является разработка структуры центра управления и интеллектуальных агентов. В частности, центр управления состоит из системы принятия решений, которая на каждом этапе позволяет сделать вывод о выборе того или иного агента для планирования единицы расписания, из модуля для доступа к базе данных и модуля, обеспечивающего взаимодействие с остальными подсистемами. Далее описывается основная концепция, лежащая в основе алгоритма планирования работ. В задачах с жесткими ограничениями на ресурсы весьма вероятна ситуация, когда на некотором шаге для некоторой единицы нагрузки нет ни одного способа постановки в расписание. Это так называемая тупиковая ситуация, ликвидировать которую можно лишь возвратившись на предыдущий этап и отменив предыдущее решение.
Очевидно, что при большом числе работ вычислительная сложность алго ритма при этом будет существенно увеличена. В связи с этим, в основе алгоритма лежит идея о выборе на каждом шаге самой дефицитной единицы нагрузки (для которой число способов формирования расписания минимально) и определении времени выполнения данной единицы. Очевидно, что это существенно уменьшает возникновение тупиковой ситуации.
Основная задача по планированию работ ложится на интеллектуальных агентов. В общем виде структура агентов сходна со структурой центра управления, поскольку также содержит систему принятия решений, модуль доступа к базе данных и подсистема взаимодействия, обеспечивающая возможность обмена сообщениями с центром. В частности, и у центра управления и у интеллектуальных агентов возникает необходимость выбора некоторого лэлемента, для которого в данный момент будет планироваться нагрузка. Однако, если для центра управления это будет выбор интеллектуального агента, то для самого агента это единица нагрузки вида заявка - машина - ресурсы. У интеллектуальных агентов и центра также сходным является модуль доступа к базе данных. Остальные компоненты этих составляющих распределенной системы будут отличаться по набору выполняемых функций.
Рассмотрим более подробно математическое обеспечение интеллектуального агента, позволяющего сделать выбор о наиболее дефицитной единице нагрузки и времени ее выполнения. Для этого проанализированы факторы, влияющие на дефицитность нагрузки. К ним, в частности, относятся:
- число способов расстановки данной единицы в расписание - f1;
- коэффициент загрузки машины - f2;
- коэффициент занятости заявки - f3;
- коэффициент загрузки ресурсов - f4.
Для количественного определения коэффициента загрузки машины рассмотрим следующие две характеристики:
- число возможных временных интервалов, когда машина i может работать Ti_общ;
- число временных интервалов, которые машина i должна потратить на обслуживание всех заявок Ti_необ.
Тогда коэффициент загрузки i-й машины изначально будет определяться формулой:
Ti _ общ mi = (5) Ti _ необ При наличии некоторого расписания в системе, данный коэффициент можно переопределить следующим образом:
Ti _ общ - Ti _ сост - z _ m(i) mi =. (6) Ti _ необ - Ti _ сост Здесь Ti_сост - число записей, которое уже составлено для данной машины;
z_m(i) - количество запретов, связанное с невозможностью машине i работать в некоторое время.
Для расчета коэффициента занятости заявки необходимо знать:
- число возможных временных интервалов, когда заявка j может быть обслужена Zj_общ;
- число временных интервалов, необходимых заявке j для полного завершения обслуживания Zj_необ.
Тогда коэффициент загрузки для заявки будет определяться следующим образом:
Z j_ общ z =. (7) j Z j_ необ Данный коэффициент также должен пересчитываться при составлении расписания. Это можно сделать с помощью характеристики Zj_сост, которая показывает время, которое уже запланировано для данной заявки.
Таким образом, на некотором текущем шаге занятость заявки определяется формулой:
Z - Z - z _ z( j) j_ общ j_ сост z =. (8) j Z - Z j_ необ j_ сост Для расчета коэффициента использования ресурсов, необходимы следующие показатели:
- общая величина ресурсов Rk_общ;
- необходимый объем ресурсов Rk_необ.
Пусть имеется qk ресурсов типа k. Тогда общую величину ресурсов можно рассчитать по формуле:
R = qk T, (9) k _ общ где T - общее количество возможных способов планирования расписания с использованием данного ресурса. Изначально Т равно общему периоду составления расписания. Rk_необ - это общее время, которое требуется затратить на обслуживание всех заявок, требующих для своего выполнения наличие данного вида ресурсов.
На основании этих двух параметров занятость ресурсов определяется формулой:
R k _ общ rk =. (10) R k _ необ Аналогично двум предыдущим случаям данный коэффициент на некотором шаге может быть пересчитан следующим образом:
R - R k _ общ k _ сост rk =. (11) R - R k _ необ k _ сост Здесь Rk_сост - время, которое уже запланировано для обслуживания заявок с данным видом ресурса.
Число способов расстановки данной единицы нагрузки х= определяется как мощность множества D(x).
Следовательно, для любой единицы нагрузки х получим следующую многокритериальную задачу:
D(x) min Ti _ общ - Ti _ сост - z _ m(i) min Ti _ необ - Ti _ сост Z - Z - z _ z( j) (12) j_ общ j_ сост min Z - Z j_ необ j_ сост R - R k _ общ k _ сост min R k _ необ - R k _ сост В качестве основного метода решения данной задачи был выбран метод главного критерия, поскольку он обладает достаточно невысокой вычислительной сложностью и весьма эффективен при большом числе альтернатив.
Однако, в случае нескольких одинаковых значений у целевой функции, выбранной в качестве главного критерия, метод не предоставляет никаких дополнительных средств для выбора оптимальной из этих альтернатив. Исходя из этого, была представлена доработка для данного метода, позволяющая выбрать наилучшее решение в том случае, когда есть несколько одинаковых значений главной целевой функции. В этом случае в качестве ответа из этих значений выберем такую альтернативу, для которой минимально следующее произведение: f2(x) f3(x) f4 (x).
Последним этапом является выбор наиболее оптимального времени для выбранной для планирования заявки. Этот выбор должен основываться на критерии, выбранном ЛПР. В частности, в работе рассмотрены следующие два критерия:
- равномерная загрузка агента в течение всего рассматриваемого периода;
- использование минимального числа дней в течение рассматриваемого периода.
В качестве ограничения были рассмотрены ограничения на отсутствие окон при обслуживании заявки или работе машины.
Особенностью программной реализации данного алгоритма является то, что каждый интеллектуальный агент может выбрать свою целевую функцию и необходимые для данного агента ограничения.
Третья глава посвящена разработке механизмов, предназначенных для обеспечения процесса взаимодействия компонент распределенной системы.
Анализ особенностей данных, которыми будут обмениваться приложения, позволил сделать вывод о том, что сообщения должны быть как индивидуальными, так и групповыми.
Для индивидуальных сообщений в качестве протокола транспортного уровня выбран протокол TCP, а для групповых - протокол UDP. Однако, протокол UDP не содержит механизмов, позволяющих гарантировать доставку данных. Другим недостатком данного протокола является возможность дублирования дейтаграмм или поступления их не в том порядке, в котором они были отправлены.
Для устранения этих недостатков были разработаны механизмы, позволяющие гарантировать доставку групповых сообщений. В частности, были предложены следующие меры.
1. Создание таймера для центра управления, чтобы по истечении заданного времени проверить уведомление о получении. С учетом того, что система будет функционировать в режиме запрос - лответ, а также с учетом того, что одно передаваемое сообщение будет столь невелико по объему, что для него будет достаточно одной дейтаграммы, уведомлением о получении будем считать ответ приложения на групповой запрос. В случае, если по прошествии времени какой-либо пользователь не предоставил ответ, ему высылается повторное индивидуальное сообщение.
2. Создание у агентов счетчиков, которые по пришествии очередного сообщения увеличивают его на 1. Таким образом агенты могут проверить отсутствие дублирования дейтаграмм. Следует отметить, что для данной системы дейтаграммы не могут прийти не в том порядке, в котором они высылались, поскольку каждый раз посылается одна дейтаграмма, на которую приложение-агент должно отправить ответ.
Предлагаемые меры позволяют гарантировать доставку групповых сообщений, передаваемых с помощью протокола UDP.
Следующим этапом являлась разработка структуры передаваемых сообщений, которая бы учитывала специфику рассматриваемой задачи. Анализ возможных действий, которые потребуются при взаимодействии приложений, позволил выделить следующие команды, подлежащие передаче.
Таблица 1 - Перечень команд разрабатываемого языка № п/п Команда Символ 1 статус лактивен А 2 ошибка E 3 указать приоритет P 4 значение приоритета V 5 тупиковая ситуация T 6 приостановить расчет S 7 требование отменить предыдущее действие C 8 завершение формирования единицы расписания I 9 завершение формирования своего расписания R 10 завершение формирования расписания F При этом некоторые команды требуют детализации, которая заключается в необходимости передачи дополнительных числовых значений. В частности, требуется детализация для команд Значение приоритета, Pавершение формирования единицы расписания и Ошибка.
С учетом этого, структура передаваемого сообщения должна быть следующей:
П А_н А_о Ид К И З Здесь: П - поле преамбулы; А_н - адрес назначения; А_о - адрес отправителя; Ид - идентификатор сообщения; К - передаваемая команда; И - информационное поле, уточняющее содержимое команды; З - признак завершения.
На основании синтаксиса передаваемых сообщений был предложен алгоритм семантической обработки пришедших данных. В общем случае он будет иметь вид, представленный на рисунке 4.
Рисунок 4 - Семантическая обработка пришедшего сообщения Здесь # - символ, которым заканчивается преамбула; S - считанная строка; preamb - преамбула; Adr_n - адрес назначения; Adr_O - адрес отправителя; Ip - IP - адрес агента; IP_CC - IP - адрес центра; Id Цсчетчик;
ACT - действие; D - множество возможных действий; Inf - информационное дополнение к команде.
В четвертой главе рассматривается реализация распределенной системы, построенной на основе математического и алгоритмического обеспечения, разработанного ранее. Структура программного средства для центра управления системой представлена на рисунке 5.
Рисунок 5 - Структура центра управления Система состоит из следующих модулей: Main_Unit ( главный модуль программы); Dis_Making_Unit (модуль системы принятия решений центра);
Edit_Unit (модуль, предназначенный для редактирования данных в базе);
Int_Con_Unit (модуль для организации взаимодействия центра с удаленными компонентами); DataModule (модуль, содержащий основные компоненты и запросы для работы с базами данных.
Структура программного средства, реализующего функции интеллектуального агента, представлена на рисунке 6.
Рисунок 6 - Структура интеллектуального агента Эта система состоит из следующих модулей: Main_Unit - главный модуль программы; Dis_Making_Unit - модуль системы принятия решений центра; Edit_Unit - модуль, предназначенный для редактирования данных в базе;
Int_Con_Unit - модуль для организации взаимодействия центра с удаленными компонентами; DataModule - модуль, содержащий основные компоненты и запросы для работы с базами данных.
В качестве предметной области применения программы выбран процесс планирования учебных занятий в ВУЗе. Для хранения всей необходимой информации была спроектирована база данных, структура которой приведена на рисунке 7.
Рисунок 7 - Структура базы данных Функции центра управления заключаются в подключении агентов, возможности различных настроек, редактировании процесса планирования.
Главное окно интеллектуального агента представлено на рисунке 8.
Выбрав кафедру, а далее - преподавателя, переходим в личный кабинет. В данном окне в таблице на основании SQL-запросов определены дисциплины, закрепленные за данным преподавателем, а также количество часов каждого типа по данным дисциплинам. В окне можно также ввести критерий предпочтения и ограничения для данного преподавателя. Нажав на кнопку Со ставить расписание, перейдем в окно, отображающее реализованный процесс планирования работ.
Рисунок 8 - Главное окно интеллектуального агента.
Результат планирования можно увидеть на рисунке 9.
Рисунок 9 - Готовое расписание Разработанные компоненты распределенной системы зарегистрированы в ФГНУ ЦИТИС. Полученная распределенная система внедрена в НОУ ВПО Международный институт компьютерных технологий. Эффект от внедрения заключается в сокращении времени, затрачиваемого на процесс планирования расписания учебных занятий.
ОСНОВНЫЕ РЕЗУЛЬТАТЫ РАБОТЫ В процессе выполнения диссертационного исследования были полу чены следующие основные результаты:
1. Разработана структура системы, предназначенной для планирования работ сложного комплекса, отличительными чертами которого являются наличие нескольких центров обслуживания, большое число работ и ограниченность ресурсов.
2. Разработано математическое обеспечение для системы принятия решений интеллектуального агента, отличающееся возможностью выбора целевой функции и ограничений, а также учитывающее ограничения, накладываемые другими агентами, и обеспечивающее возможность планирования работ для данного агента с учетом выбранного критерия и имеющихся ограничений.
3. Предложен алгоритм для распределенной обработки данных, учитывающий предпочтения и ограничения всех агентов и обеспечивающий сокращение времени, затрачиваемое на процесс составления расписания за счет параллелизма выполнения отдельных операций.
4. Разработана структура передаваемого сообщения, учитывающая специфику данных, подлежащих обмену, и особенности алгоритма планирования, и обеспечивающая возможность дальнейшей передачи как индивидуальных, так и групповых сообщений.
5. Предложены механизмы межмодульного взаимодействия с коммуникационной подсистемой, учитывающие специфику передаваемых команд и обеспечивающих гарантированную доставку групповых сообщений.
6. Разработано программное обеспечение, предназначенное для планирования учебных занятий в ВУЗе. Оно включает в себя две программы, первая из которых является центром управления, а вторая - интеллектуальным агентом. Каждая из компонент распределенной системы зарегистрирована в ФГНУ ЦИТИС.
Основные результаты диссертации опубликованы в следующих работах:
Публикации в изданиях, рекомендованных ВАК РФ 1. Лопатин Р.С. Разработка структуры распределенной системы для одной задачи планирования работ/ Р.С. Лопатин, С.А. Олейникова // Системы управления и информационные технологии. № 3.1 (45). Москва- Воронеж, Научная книга, 2011. - с. 173-176.
2. Лопатин Р.С. Математическое обеспечение для распределенной системы планирования работ/ Р.С. Лопатин, С.А. Олейникова // Вестник Воронежского государственного технического университета, 2011. № 10. - с. 3336.
3. Лопатин Р.С. Применение математических методов моделирования в задачах составления учебного расписания/ Р.С. Лопатин, Е.Д. Федорков// Вестник Воронежского государственного технического университета. 2010.
№ 12.С. 110-113.
Статьи и материалы конференций 4. Лопатин Р.С. Модели и алгоритмы составления учебного расписания // Высокие технологии в технике, медицине, экономике и образовании: межвуз.
сб. науч. тр. Воронеж: ВГТУ, 2006. С. 263.
5. Лопатин Р.С., Стратегия распределения имеющегося ресурса между элементами системы/ Р. С. Лопатин, Е.Д. Федорков, А.Н. Чекменев // Высокие технологии в технике, медицине, экономике и образовании: межвуз. сб.
науч. тр. Воронеж: ВГТУ, 2008. С. 48.
6. Лопатин Р.С. Разработка синтаксиса языка для организации взаимодействия программных систем для одной задачи планирования работ// Перспективы развития информационных технологий: сборник материалов IV Международной научно-практической конференции. - Новосибирск: Издательство НГТУ, 2011. с.239-27. Лопатин Р.С. Разработка структуры программной системы для решения одной задачи планирования работ// Критические технологии вычислительных и информационных систем. Сб. трудов. - Воронеж, МИКТ, 2011.
с.126-18. Лопатин Р.С. Алгоритм функционирования распределенной системы планирования работ/ Лопатин Р.С., Олейникова С.А. // Материалы III Международной научно-практической конференции Применение инновационных технологий в научных исследованиях. Курск, 2011. - с. 182-185.
9. Лопатин Р.С. Система принятия решений интеллектуального агента распределенной системы// Материалы Всероссийской научной школе Информационно-телекоммуникационные системы и управление. Воронеж, 2011. с. 43-47.
10. Лопатин Р.С. Разработка алгоритма функционирования интеллектуального агента распределенной системы// Лопатин Р.С., Олейникова С.А. // Материалы V Международной конференции Актуальные вопросы современной техники и технологии. Липецк, 2011. с. 18-11. Лопатин Р.С. Программные инструменты для организации взаимодействия компонентов системы планирования// Современные проблемы информатизации в экономике и обеспечении безопасности. - Воронеж, 2012. с. 33-35.
12. Лопатин Р.С. Программа. Центр управления распределенной системы планирования учебных занятий/ Р.С. Лопатин, С.А. Олейникова. Москва:
ФГНУ ЦИТИС, 2011. № 50201151280 от 02.10.11.
13. Лопатин Р.С. Программа. Интеллектуальный агент распределенной системы планирования учебных занятий/ Р.С. Лопатин, С.А. Олейникова.
Москва: ФГНУ ЦИТИС, 2011. № 50201151279 от 02.10.11.
Авторефераты по всем темам >> Авторефераты по техническим специальностям