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

Статистическое моделирование

3.2. Общая характеристика метода имитационного моделирования

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

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

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

Имитационные модели могут быть реализованы средствами универсальных языков программирования (Паскаль, Си, Фортран и др.). Они предоставляют практически неограниченные возможности в разработке и отладке программ моделей. Однако, модель в виде программы на универсальном языке программирования часто непонятна исследователю. Ведь совершенно необязательно исследователь, специалист в конкретной предметной области должен знать тонкости программирования на каком-либо языке. Поэтому были созданы специализированные языки моделирования, которые существенно упрощают создание моделей и обработку результатов моделирования (Симпас, Симула, Арена, семейство языков GPSS и др.). Одна из наиболее распространенных систем моделирования GPSS World рассматривается в настоящем курсе.

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

Если сложность аналитической модели с усложнением моделируемого объекта возрастает с ускорением, как показано на рис. 3.6, то сложность имитационной модели, начиная с некоторого уровня S_{0}, растет незначительно.

Иллюстрация роста сложности моделей

Рис. 3.6. Иллюстрация роста сложности моделей

К достоинствам имитационных моделей можно также отнести:

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

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

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

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

3.3. Статистическое моделирование при решении детерминированных задач

Метод статистических испытаний может быть использован как численный метод решения математических задач. Именно в таком качестве он был применен в США в 1944 г. Джоном фон Нейманом при расчетах по созданию ядерного реактора.

Применение метода рассмотрим на примере вычисления некоторого интеграла.

Пример 3.4. Пусть 0\le f(x)\le 1, 0\le x\le 1. Полагаем, что функция f(x) такова, что интеграл относится к "неберущимся".

Требуется вычислить S = \int\limits_{0}^{1} f(x)dx.

Решение

Представим функцию в координатах f(x) и x как показано на рис. 3.7. Как известно, численное значение интеграла данного вида равно площади S. Площадь S состоит из множества элементарных площадок - точек. Количество точек в этой площади и будет численным значением искомого интеграла.

Имитируем координаты каждой точки значениями x_{i} и y_{i}, принадлежащими равномерному распределению на участке [0, 1]:

x _{1}, x_{2} , \ldots , x_{i}, \ldots , x_{N};\\
y_{1},y_{2},\ldots ,y_{i},\ldots ,y_{N}_{}
Вычисление интеграла

Рис. 3.7. Вычисление интеграла

Рассмотрим пару чисел x_{i}, y_{i}. Вычислим f(x_{i}) и сравним с y_{i}. Если f(x_{i}) < y_{i}, то это означает, что точка M(x_{i}, y_{i}) принадлежит площади S. Если f(x_{i} )>y_{i}, то это означает, что точка M(x_{i}, y_{i}) не принадлежит площади S .

Введем:

z_i = \left \{ 
\begin{array}{l}
1, f(x_i)\le y_i,\\
0, f(x_i)> y_i,
\end{array}

Число точек, попавших в границы S равно \sum\limits_{i=1}^{N}z_{i} , где N - общее число точек, попавших в единичную площадь существования функции и аргумента. Отсюда следует:

\cfrac{\sum\limits_{i=1}^{N}z_i}{N}\approx S = \int\limits_0^1{f(x)dx}.

Чем больше будет элементарных площадей - точек, тем точнее будет вычислен интеграл. Приведенное решение примера справедливо для единичных областей существования функции и аргумента. Однако это несущественно, так как произвольные границы существования a \le x\le b,0\le f(x)\le A заменой переменных можно свести к единичным границам.

Известны статистические алгоритмы численного решения многократных интегралов.

Пример 3.5. Найти оценку I* интеграла I = \int\limits_0^1{dx\int\limits_x^1{(x + y)dy}} .

Решение

Область интегрирования ограничена линиями y = x, y = 1, x = 0 , т. е. принадлежит единичному квадрату (рис. 3.8).

Иллюстрация к примеру 3.5

Рис. 3.8. Иллюстрация к примеру 3.5

Площадь области интегрирования (прямоугольного треугольника) S = (1 ? 1) / 2 = 0,5. Используем формулу

I^*=S\cdot\cfrac{\sum\limits_{i=1}^{M}{f(x_i,y_i)}}{M}= 0.5\cdot\cfrac{\sum\limits_{i=1}^{M}{f(x_i,y_i)}}{M},

в которой M - число случайных точек (x_{i}, y_{i}) , принадлежащих области интегрирования. У этих точек y_{i} \ge x_{i}. Если данное условие выполняется, то вычисляется

\sum\limits_{i=1}^{M}{f(x_i,y_i)}= {\sum\limits_{i=1}^{M}{f(x_i,y_i)}} + (x_i + y_i)

а число случайных точек M увеличивается на 1: M = M +1.

Результаты моделирования приведены в табл. 3.2.

Из данных табл. 3.2 (верхние пять строк) видно, что с увеличением числа реализаций N ошибка \Delta S = S-I^* в определении оценки интеграла I^* уменьшается и при N = 1000 000 становится равной нулю.

Таблица 3.2. Результаты моделирования примера 3.5
N 10 1000 10000 100000 1000000
M 5 500 5038 49658 500364
\ sum\limits_{i=1}^{M}{f(x_i,y_i)} 4,773 487,695 5006,152 49533,242 500191,650
I^* 0,477 0,488 0,497 0,499 0,500
\Delta S = S-I^* 0,023 0,012 0,003 0,001 0
M 6 503 4935 49833
\ sum\limits_{i=1}^{M}{f(x_i,y_i)} 5,025 494,593 4917,236 49802,019
I^* 0,419 0,492 0,498 0,500
\Delta S = S-I^* 0,081 0,008 0,002 0

В четырех нижних строках табл. 3.2 приведены результаты моделирования с другими начальными числами генераторов равномерно распределенных случайных чисел. Как видно, ошибка в оценке интеграла равна нулю уже при N= 100 000 реализаций модели.

В заключение отметим, что имитационное (статистическое) моделирование целесообразно применять в случаях:

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

Подскажите, пожалуйста, планируете ли вы возобновление программ высшего образования? Если да, есть ли какие-то примерные сроки?

Спасибо!

Лариса Парфенова
Лариса Парфенова

1) Можно ли экстерном получить второе высшее образование "Программная инженерия" ?

2) Трудоустраиваете ли Вы выпускников?

3) Можно ли с Вашим дипломом поступить в аспирантуру?