Опубликован: 26.07.2006 | Уровень: специалист | Доступ: свободно
Лекция 13:

Алгоритмы нечеткой оптимизации

< Лекция 12 || Лекция 13: 1234 || Лекция 14 >

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

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

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

f(x) \to \max
,\;\t{\char239}\t{\char240}\t{\char232}\;\varphi _i (x) \leqslant 0,\quad
\quad i = 1,...,m,\;x \in X,
где X — заданное множество альтернатив, f\colon X\to
R — заданная функция, которую нужно максимизировать, и \varphi_{i}\colon X\to
R — заданные функции ограничений.

При моделировании в нечеткой форме реальных задач принятия решений в распоряжении исследователя-математика могут оказаться лишь нечеткие описания функции f и \varphi_{i}, параметров, от которых зависят эти функции, и самого множества X. Таким образом, задача стандартного математического программирования превратится в задачу нечеткого математического программирования.

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

Перечислим некоторые из таких формулировок.

Задача 1. Максимизация заданной обычной функции f\colon X\to R на заданном нечетком множестве допустимых альтернатив \(\mu\colon {{X}} \to {{R}}\).

Задача 2. Нечеткий вариант стандартной задачи математического программирования. Пусть определена следующая задача:

f(x) \to \max
,\;\t{\char239}\t{\char240}\t{\char232}\;\varphi _i (x) \leqslant 0,
\quad
i = 1,...,m,\;x \in X.

Нечеткий вариант этой задачи получается, если "смягчить" ограничения, т.е. допустить возможность их нарушения с той или иной степенью. Кроме того, вместо максимизации функции f(x) можно стремиться к достижению некоторого заданного значения этой функции, причем различным отклонениям значения функции от этой величины приписывать разные степени допустимости.

Задача 3. Нечетко описана "максимизируемая" функция, т.е. задано отображение \(\mu _\varphi  ;X \times R \to [0,1]\), где Xуниверсальное множество альтернатив, Rчисловая ось.

В этом случае функция \(\mu _\varphi  ({{x}}_{{0}}^{}{{,r}})\) при каждом фиксированном x_{0}\in X представляет собой нечеткое описание оценки результата выбора альтернативы x_{0} (нечеткую оценку альтернативы x_{0} ) или нечетко известную реакцию управляемой системы на управление x_{0}. Задано также нечеткое множество допустимых альтернатив \(\mu _C \); \(X \to [0,1]\).

Задача 4. Заданы обычная максимизируемая функция f\colon X\to R и система ограничений вида \(\varphi _{{i}} {{(x)}} \leqslant {{b}}_{{i}}^{} {{,}}\quad {{i}} =
{{1}},\ldots,{{m}}\), причем параметры в описаниях функций \(\varphi _{{i}} {{(x)}}\) заданы в форме нечетких множеств.

Задача 5. Нечетко описаны как параметры функций, определяющих ограничения задачи, так и самой максимизируемой функции.

Рассмотрим, например, подробнее задачу линейного программирования с нечёткими коэффициентами. Нечеткость в постановке задачи нечеткого математического программирования может содержаться как в описании множества альтернатив, так и в описании целевой функции.

\begin{equation}
f(x) \to \max ,\;\quad g(x) \leqslant 0,\quad \quad x \in X.
\end{equation} ( 1)

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

Нечеткую обстановку можно рассматривать как множество X альтернатив вместе с его нечеткими подмножествами, представляющими собой нечетко сформулированные критерии (цели и ограничения), т.е. как систему (X,
f_{0}, f_{1}, \ldots ,f_{n}). Принять во внимание по возможности все критерии в такой задаче означает построить функцию

\begin{equation}
D = f_{0}\cap   f_{1}\cap   \ldots\cap   f_{n},
\end{equation} ( 2)
в которую цели и ограничения входят одинаковым образом.

Решение можно определить как нечеткое подмножество универсального множества альтернатив. Оптимум соответствует той области X, элементы которой максимизируют D. Это и есть случай нечеткого математического программирования.

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

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

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

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

< Лекция 12 || Лекция 13: 1234 || Лекция 14 >
Владимир Власов
Владимир Власов

Зачем необходимы треугольные нормы и конормы? Как их использовать? Имеется ввиду, на практике.
 

Тимур Швецов
Тимур Швецов
Казахстан