Pers.narod.ru. Обучение. Стохастическое интегрирование (метод Монте-Карло) в MathCAD

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

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

Взять определённый интеграл в MathCAD - одна из самых простых задач, о которых я слышал. Нажимаем в программе символ "&", а дальше можно догадаться...

Но мы лёгких путей не ищем, тем более, что практически все трудоёмкие расчёты можно приблизительно выполнить на основе последовательностей псевдослучайных чисел - были бы достаточно длинными их серии.

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

Поскольку для примера мы взяли синусоиду и интервал интегрирования от 0 до π, площадь нашего прямоугольника тоже равна π (максимум синуса на этом интервале равен 1).

Отношение числа n попаданий "камешка" под график к общему числу "камешков" N даст значение определённого интеграла :) Просто умножим эту величину на площадь прямоугольника, получая формулу I=π*n/N.

Определённый интеграл методом Монте-Карло

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

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

В прилагаемом документе всё сделано удобней, чем на скрине (есть поля для ввода пределов интегрирования a, b, автоматически проводится исследование функции на максиммум в интервале x∈[a,b], лучше визуализация). В целях совместимости файл сохранён в формате MathCAD 11, значит, открывается в любой старшей версии.

 Интегрирование методом Монте-Карло в MathCAD (11 Кб)

Кстати, если Ваш MathCAD показывает вместо русских шрифтов "козяблики" - а этим грешат все версии от 10 до 14 - то либо поменяйте шрифт текстовых надписей на любой, имеющий в окончании названия Cyr (не Times New Roman, а Times New Roman Cyr), либо выполните на компьютере такой же патчик, как в этой заметке блога.

Рейтинг@Mail.ru

вверх гостевая; E-mail
Hosted by uCoz