Организация решения задач исследования операций в MATHCAD | Статья в журнале «Молодой ученый»

Отправьте статью сегодня! Журнал выйдет 28 декабря, печатный экземпляр отправим 1 января.

Опубликовать статью в журнале

Авторы: ,

Рубрика: Математика

Опубликовано в Молодой учёный №8 (88) апрель-2 2015 г.

Дата публикации: 15.04.2015

Статья просмотрена: 2829 раз

Библиографическое описание:

Имомов, А. И. Организация решения задач исследования операций в MATHCAD / А. И. Имомов, Б. С. Эргашев. — Текст : непосредственный // Молодой ученый. — 2015. — № 8 (88). — С. 5-10. — URL: https://moluch.ru/archive/88/17276/ (дата обращения: 16.12.2024).

Основная цель работы — показать, как решаются основные задачи исследования операций, такие как задача линейного программирования, транспортная задача, задача о назначении, задача о коммивояжере, матричная игра в MathCAD.

Ключевые слова: исследование операций, задача линейного программирования, транспортная задача, задача о назначении, задача о коммивояжере, матричная игра, решения задач в MathCAD.

 

1. Управление и планирование являются наиболее сложными функциями в работе предприятий, фирм, служб администраций всех уровней. Долгое время они являлись монополией человека с соответствующей подготовкой и опытом работы [1–3].

Создание компьютеров и программных средств создало огромные возможности для развития науки, совершенствования методов планирования и управления производством. Однако без строгих формулировок задач, без математического описания процессов современный уровень управления и планирования не может быть достигнут. В последнее время появились математические системы- математические программы, позволяющие решить многие задачи без составления компьютерных программ, такие как MathCAD, Maple, Mathematica и т. д. [3–5].

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

Требуется найти максимум или минимум функции

                                                                             (1)

при условиях:

                                                                                                       (2)

.                                                                                          (3)

где ,  — функции,  — параметры управления [1–3].

Выражение (1) называется функцией цели. Условия (2),(3) представляют собой ограничения поставленной задачи. Условия (3) справедливы для многих задач, особенно экономических, когда параметры управления  по своему физическому смыслу не могут быть отрицательными. Среди условий задачи могут быть равенства.

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

2. Решение задачи линейного программирования в MathCAD.

В задаче линейного программирования целевая функция и ограничения линейны:

,                                                                               (4)

.                                  (5)

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

Каноническая задача линейного программирования решается с помощью хорошо известного симплекс метода [1–3]. Здесь мы покажем, как можно решить задачу линейного программирования с помощью математической системы MathCAD.

Решим задачу ([1],21.1). После знака // записываем замечание-смысл команд MathCAD.

ORIGIN: =1 m: =2 n: =4 i: =1..m j: =1..n // ввод конечных значений индексов

 // целевая функция

 // матрица и вектор ограничений

Given   // обращение к внутренней функции

 // вывод результатов

Переменная введена для экономии места. Здесь и дальше в блоке Given …Minimize знаки равенств и неравенств жирные. Они набираются в панели MathCAD булево.

3. Решение транспортной задачи в MathCAD. Задачи о назначении и коммивояжере.

В организации перевозок некоторого продукта (груза) между пунктами его производства , , и пунктами потребления , , возникает транспортная задача. Каждый пункт производства  характеризуется запасом продукта  . Каждый пункт потребления  характеризуется потребностью в продукте , . Сеть дорог, соединяющая систему рассматриваемых пунктов, моделируется с помощью матрицы . Элемент  представляет собой нормы затрат на перевозку единицы груза из пункта производства  в пункт потребления . Через  обозначим количество продукта, перевозимого из пункта  в пункт . Тогда план перевозок груза представляется в виде матрицы:

.

Транспортная задача ставиться так:

,                                                                                       (6)

,                                                                                                   (7)

.                                                                                                   (8)

.                                                                                         (9)

Для решения закрытой транспортной задачи, т. е. для случая , хорошо известным методом является метод потенциалов [1–3].

С транспортной задачей связаны задачи о назначении и о коммивояжере.

Задача о назначении формулируется таким образом: для реализации производственного процесса необходимо выполнить  операций. Имеется  рабочих, которые способны осуществить их, и время (затраты) выполнения каждым рабочим любой из  операций. Требуется определить: кто и какую операцию должен выполнить, чтобы суммарное время (затраты) выполнения всего производственного процесса было минимально. Возможны и другие постановки.

Формализация задачи. Введём матрицу, , где  при  и  при . Тогда каждый рабочий может выполнить лишь одну операцию и справедливо ограничение:

.                                                                                                      (10)

Каждая операция может выполняться лишь одним рабочим и справедливо ограничение:

.                                                                                                     (11)

Матрица системы (10,11) имеет ранг , т. е. из  неизвестных  являются свободными.

Если обозначить себестоимость выполнения операции рабочим через , то суммарная себестоимость выполнения всех работ будет:

.                                                                                                   (12)

Задача о назначении заключается в минимизации сумму (12) при выполнении ограничений (10), (11) и . Для решения задачи о назначении разработан венгерский метод [1–3]. В решении задачи в матрице , в главной диагонали могут стоять либо 1 либо 0, но в каждой строке и столбце могуть стоять только по одной 1. Матрица С есть матрица себестоимости выполнения соответствующих операций.

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

Задача о коммивояжере формализуется как задача о назначении, но только в матрице решений , в главной диагонали всегда должна стоять 0. Кроме того, в матрице С в главной диогонали должны стоять большие числа.

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

Решим сначала транспортную задачу ([1],23.1).

ORIGIN: =1 m:=3 n: =4 i: =1..m j: =1..n // ввод конечных значений индексов

  // матрица и вектор ограничений

 //начальный план перевозок

 // целевая функция

Given  // обращение к внутренней функции

  // вывод результатов

Решим теперь задачу о назначении ([1], 26.1).

 //индексы

 //матрица и вектор ограничений

 // начальное приближение

 // целевая функция

Given  // внутренняя функция

  // вывод результатов

Given  // внутренняя функция

  // вывод результатов

Решим теперь задача о коммивояжере [5].

 // индексы

  // платёжная матрица

 // векторы ограничений

  // целевая функция

Given

   // внутренняя функция

  // вывод результатов

4. Решение матричных игр в MathCAD.

Матричные игры задаются платёжной матрицей , .

В матричной игре участвуют два игрока. Строки являются чистыми стратегиями первого игрока, а столбцы являются чистыми стратегиями второго игрока. Гарантированный выигрыш первого игрока, применяющего ю стратегию равен . Число

называется нижним значением игры, и называется максиминной стратегией первого игрока. Аналогично, число

называется верхним значением игры. Всегда . Если , то игра имеет седловую точку в чистых стратегиях, а число  называется значением (ценой) игры. Если игра имеет седловую точку, то существует элемент матрицы такой, что

.                                                                                                             (13)

Если игра не имеет седловую точку в чистых стратегиях, то по теореме Фона Неймана, игра имеет седловую точку в смешанных стратегиях. Для этого определяем вероятности

, .                                                      (14)

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

.                                                                                               (15)

Выигрыш называется функцией игры. Пара смешанных стратегий называется седловой точкой функции , если

.                                                                                      (16)

Задача максимизации гарантированного выигрыша первого игрока и задача минимизации гарантированного проигрыша второго игрока сводятся к паре двойственных задач линейного программирования:

Задача первого игрока заключается в следующем

.                                  (17)

Задача второго игрока заключается в следующем

.                                 (18)

Процесс решения задач упрощается, если перейти к переменным

; .

Это возможно, если . Если так, то имеем:

Задача первого игрока принимает вид

.                                            (19)

Задача второго игрока принимает вид

.                                         (20)

Оптимальные стратегии игроков не изменится, если матрицу игры заменить матрицей . Так как, при этом цена игры увеличивается на .

Решим задачу ([1],31.3)

ORIGIN: =1 // начальное значение индексов

 // платёжная матрица

 // целевая функция

Given  // внутренняя функция

 // вывод результатов

 // целевая функция

Given  // внутренняя функция

 // внутренняя функция

 // вывод результатов

 

Литература:

 

1.         Красс М. С., Чупрынов Б. П. Основы математики и ее приложения в экономическом образовании: Учеб. — 2-е изд., испр. — М.: Дело, 2001. — 688 с.

2.         Таха Х. А. Введение в исследование операций, 7-е издание.: Пер. с англ. — М.: Издательский дом «Вильямс», 2005. — 912 с: ил. — Парал. тит. англ.

3.         Охорзин В. А. Прикладная математика в системе MathCAD. -СПб, Лань.2008.-352 с.

4.         Имомов А «Организация приближённого решения интегральных уравнений в MathCAD». Молодой учёный, № 14(73), сентябрь 1, 2014 г.-с.6–15.

5.         Мусатенко К. Е., Раводин О. М. Компьютерная модель для лабораторной работы «Выбор оптимальной траектории движения транспортного робота с использованием задачи о коммивояжере». Молодой учёный, 12 (59), 2013 г.-с.71–75.

Основные термины (генерируются автоматически): задача, линейное программирование, транспортная задача, внутренняя функция, вывод результатов, целевая функция, ORIGIN, вектор ограничений, коммивояжер, чистая стратегия.


Ключевые слова

транспортная задача, исследование операций, задача линейного программирования, задача о назначении, задача о коммивояжере, матричная игра, решения задач в MathCAD., решения задач в MathCAD

Похожие статьи

Решение транспортных задач с использованием свойств многомерного пространства

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

Алгоритмы расщепления для задачи о пропозициональной выполнимости

В статье исследуется задача о пропозициональной выполнимости и известные алгоритмы ее решения. Приведено обоснование её значимости как широко применимой задачи, для которой впервые было сформулировано и доказано свойство NP-полноты. Автором разработа...

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

Рассматривается задача разработки и использования методов параллельного программирования при численном решении задач оптимизации методами координатного и градиентного спусков. Задача оптимизации рассматривается в контексте решения задачи гашения коле...

Компьютерная модель для лабораторной работы «Выбор оптимальной траектории движения транспортного робота с использованием задачи о коммивояжере»

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

Алгоритмические аспекты доминирования в графах

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

Методы и алгоритмы эффективного решения задачи маршрутизации транспорта на сетях больших размерностей

В данной работе подробно рассмотрена задача маршрутизации транспорта с временными окнами и ограниченной грузоподъёмностью. В ходе работы рассматриваются различные эвристические и мета-эвристические алгоритмы, применённые к данному типу задач. Более п...

Методы решения нелинейных уравнений

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

Создание и использование программы для статистического анализа сведенных задач теории игр в экономической интерпретации к задачам линейного программирования

В данной работе решается задача сбора статистических данных при использовании программы, которая решает экономические задачи теории игр, сводя их к задачам линейного программирования (ЗЛП). Приводится теоретическая часть экономической интерпретации т...

Проектирование и оптимизация несущей системы квадрокоптера

В статье рассматривается задача проектирования и оптимизации несущей системы квадрокоптера на базе рамы F450 (APM). Выполнен анализ прочности и жесткости базового проектного решения. Задача оптимизации по массе решена как задача нелинейного математич...

Решение транспортных задач с применением программирования в системе MathCAD

В данной статье рассматривается понятие линейного программирования, а также наиболее распространенная задача данного класса математического моделирования – транспортная задача. Приводится классификация по разным признакам: критериям времени и стоимос...

Похожие статьи

Решение транспортных задач с использованием свойств многомерного пространства

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

Алгоритмы расщепления для задачи о пропозициональной выполнимости

В статье исследуется задача о пропозициональной выполнимости и известные алгоритмы ее решения. Приведено обоснование её значимости как широко применимой задачи, для которой впервые было сформулировано и доказано свойство NP-полноты. Автором разработа...

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

Рассматривается задача разработки и использования методов параллельного программирования при численном решении задач оптимизации методами координатного и градиентного спусков. Задача оптимизации рассматривается в контексте решения задачи гашения коле...

Компьютерная модель для лабораторной работы «Выбор оптимальной траектории движения транспортного робота с использованием задачи о коммивояжере»

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

Алгоритмические аспекты доминирования в графах

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

Методы и алгоритмы эффективного решения задачи маршрутизации транспорта на сетях больших размерностей

В данной работе подробно рассмотрена задача маршрутизации транспорта с временными окнами и ограниченной грузоподъёмностью. В ходе работы рассматриваются различные эвристические и мета-эвристические алгоритмы, применённые к данному типу задач. Более п...

Методы решения нелинейных уравнений

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

Создание и использование программы для статистического анализа сведенных задач теории игр в экономической интерпретации к задачам линейного программирования

В данной работе решается задача сбора статистических данных при использовании программы, которая решает экономические задачи теории игр, сводя их к задачам линейного программирования (ЗЛП). Приводится теоретическая часть экономической интерпретации т...

Проектирование и оптимизация несущей системы квадрокоптера

В статье рассматривается задача проектирования и оптимизации несущей системы квадрокоптера на базе рамы F450 (APM). Выполнен анализ прочности и жесткости базового проектного решения. Задача оптимизации по массе решена как задача нелинейного математич...

Решение транспортных задач с применением программирования в системе MathCAD

В данной статье рассматривается понятие линейного программирования, а также наиболее распространенная задача данного класса математического моделирования – транспортная задача. Приводится классификация по разным признакам: критериям времени и стоимос...

Задать вопрос