Генерация равномерно распределенной на отрезке случайной величины и имитация случайных событий
Получение случайных чисел, равномерно распределенных на интервале, вычислительные алгоритмы, позволяющие получить длинные последовательности псевдослучайных чисел. Метод линейного конгруента Лехмера. Имитация наступления события с заданной вероятностью.
Рубрика | Экономико-математическое моделирование |
Вид | лабораторная работа |
Язык | русский |
Дата добавления | 21.05.2014 |
Размер файла | 168,3 K |
Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже
Студенты, аспиранты, молодые ученые, использующие базу знаний в своей учебе и работе, будут вам очень благодарны.
Размещено на http://www.allbest.ru/
Лабораторный практикум
Генерация равномерно распределенной на отрезке (0,1) случайной величины и имитация случайных событий
Оглавление
- 1. Цель работы
- 2. Теоретические сведения
- 3. Получение случайных чисел, равномерно распределенных на интервале [0,1]
- 4. Имитация наступления события с заданной вероятностью
- 5. Задание
- 6. Отчет по работе
- 7. Контрольные вопросы
- Приложение
1. Цель работы
Изучение:
1) метода линейного конгруента получения псевдослучайных чисел, равномерно распределенных на интервале 0-1,
2) метода имитации наступления (ненаступления) событий.
2. Теоретические сведения
Эффективными методами исследования процессов и систем, получившими широкое распространение, являются методы компьютерного моделирования, в частности, имитационное моделирование и метод статистических испытаний (метод Монте-Карло). В основе вычислений по методу статистических испытаний лежит случайный выбор чисел из заданного вероятностного распределения. При практических вычислениях эти числа берут из таблиц или получают путем некоторых операций, результатами которых являются псевдослучайные числа с теми же свойствами, что и числа, получаемые путем случайной выборки. Имеется большое число вычислительных алгоритмов, которые позволяют получить длинные последовательности псевдослучайных чисел.
3. Получение случайных чисел, равномерно распределенных на интервале [0,1]
псевдослучайный алгоритм конгруент вероятность
Один из наиболее простых и эффективных вычислительных методов получения последовательности равномерно распределенных случайных чисел, включающий только одну операцию умножения, разработан Лехмером и известен как метод линейного конгруента.
Алгоритм имеет четыре параметра:
- модуль (основание системы), ;
- множитель, ;
- приращение, ;
- начальное значение, или зерно (seed), .
Последовательность случайных чисел получается с помощью следующего итерационного равенства:
.
Если , и являются целыми, то создается последовательность целых чисел в диапазоне .
Выбор значений , и является критичным для разработки хорошего генератора случайных чисел.
Очевидно, что должно быть очень большим, чтобы была возможность создать много случайных чисел. Считается, что должно быть приблизительно равно максимальному положительному целому числу для данного компьютера. Таким образом, обычно значение близко или равно 231.
Существует три критерия, используемые при выборе генератора случайных чисел:
- функция должна создавать полный период, т.е., должны появиться все числа между 0 и до того, как создаваемые числа начнут повторяться;
- создаваемая последовательность должна появляться случайно. Фактически последовательность чисел не является случайной, так как она создается детерминированным образом, но различные статистические тесты, которые могут применяться, должны показывать, что последовательность случайна;
- программа, реализующая метод, должна эффективно выполняться на 32-битных процессорах.
Значения , и должны быть выбраны таким образом, чтобы эти три критерия выполнялись. В соответствии с первым критерием можно показать, что если является простым и , то при определенном значении период, создаваемый функцией, будет равен . Для 32-битной арифметики соответствующее простое значение . Таким образом, функция создания псевдослучайных чисел имеет вид:
.
Только небольшое число значений удовлетворяет всем трем критериям. Одно из таких значений , которое использовалось в семействе компьютеров IBM 360.
Генератор широко применяется, и прошел более тысячи тестов, больше, чем все другие генераторы псевдослучайных чисел.
Программа на языке С++ имеет следующий вид
Для задания базового значения в программе использовано битовое содержимое таймера компьютера, что обеспечивает случайных характер выбора начальной точки последовательности чисел. Это удобно для проведения экспериментов на модели, но создает сложности в процессе ее отладки, так как не дает возможность обеспечить воспроизводимость запусков. С целью обойти эту проблему следует задавать в качестве начального значения конкретную величину, одну и ту же для всех отладочных тестов.
4. Имитация наступления события с заданной вероятностью
Пусть некоторое событие происходит с вероятностью . Требуется воспроизвести факт наступления события .
Поставим в соответствие событию событие , состоящее в том, что , где - случайное число с равномерным на интервале (0…1) законом распределения. Вычислим вероятность события :
.
Таким образом, события и являются равновероятными. Отсюда следует процедура имитации факта появления события . Она сводится к проверке неравенства , и алгоритм заключается в следующем:
1) Генерируется случайное число ;
2) Проверяется выполнение неравенства ;
3) Если неравенство выполняется, считается, что событие произошло, если нет - не произошло.
5. Задание
Подготовка эксперимента
Соберите проект С++ в соответствии с указаниями, содержащимися в Приложении (используется модуль 001). Запустите табличный редактор Microsoft Excel.
Изучение генератора случайных чисел
1. Запустите несколько раз программу для небольшого значения NexpR с получением трассировочного вывода и убедитесь, что это приводит к появлению различных последовательностей псевдослучайных чисел.
2. Замените (long)time(NULL) в тексте функции rundum() на выражение
или на заранее просчитанное по этой формуле значение.
Запустите несколько раз программу и убедитесь, что все запуски приводят к появлению одинаковых последовательностей псевдослучайных чисел.
3. Восстановите текст функции rundum() и осуществите прогоны программы с разными значениями числа выполнения программы-генератора NexpR, задавая в разделе параметров модели значения NexpR равные
- 100;
- 1000;
- 10000.
Для каждого значения NexpR проведите по пять запусков и найдите среднее значение для оценок математического ожидания случайной величины, получаемой в результате выполнения программы-генератора, по всем запускам. Результаты занесите в Excel-таблицу:
№N |
1 |
2 |
3 |
4 |
5 |
СРЕДНЕЕ |
|
100 |
|||||||
1000 |
|||||||
10000 |
|||||||
100000 |
Чтобы отменить вывод в файл итог каждого испытания, возьмите в знаки комментария оператор вывода получаемого значения в цикле.
4. Проанализируйте полученные данные.
5. Для отключения в последующих запусках экспериментов с генератором случайных чисел установите в разделе "Параметры модели" NexpR=0.
Изучение алгоритма имитации наступления событий
1) В разделе параметров модели задайте значение вероятности наступления события равное
2) Выполните пробные прогоны программы с небольшим значением NexpE и изучите трассировочный вывод.
3) Осуществите прогоны программы с разными значениями числа выполнения программы-генератора NexpE, задавая в разделе параметров модели значения NexpE равные
- 100
- 1000
- 10000
4) Для каждого значения NexpE проведите по пять запусков и найдите среднее значение для оценок математического ожидания случайной величины, получаемой в результате выполнения программы-генератора, по всем запускам. Результаты занесите в Excel-таблицу:
№N |
1 |
2 |
3 |
4 |
5 |
СРЕДНЕЕ |
|
100 |
|||||||
1000 |
|||||||
10000 |
Чтобы отменить вывод в файл итоги всех испытаний, возьмите в знаки комментария оператор вывода получаемого в цикле значения.
5) Проанализируйте полученные данные.
6) Для отключения в последующих запусках экспериментов с программой имитации наступления события установите в разделе "Параметры модели" NexpR=0.
6. Отчет по работе
Отчет по работе должен включать таблицы результатов экспериментов с
1) генератором случайных чисел
2) имитатором наступления события
7. Контрольные вопросы
1. Чем вызывается необходимость применения программного генератора псевдослучайных чисел?
2. Чем отличается псевдослучайное число от случайного?
3. Какие требования предъявляются к программным генераторам псевдослучайных чисел?
4. В каких случаях целесообразно задавать начальное значение в виде константы, а в каких - случайной (псевдослучайной) величиной?
5. Какой прием обычно используется для задания начального значения последовательности случайных чисел?
6. Что понимается под имитацией случайного события?
7. Какой прием применяется для имитации случайных событий?
Приложение
Размещено на Allbest.ru
...Подобные документы
Понятие равномерно распределенной случайной величины. Мультипликативный конгруэнтный метод. Моделирование непрерывных случайных величин и дискретных распределений. Алгоритм имитационного моделирования экономических отношений между кредитором и заемщиком.
курсовая работа [164,7 K], добавлен 03.01.2011Элементарные понятия о случайных событиях, величинах и функциях. Числовые характеристики случайных величин. Виды асимметрии распределений. Статистическая оценка распределения случайных величин. Решение задач структурно-параметрической идентификации.
курсовая работа [756,0 K], добавлен 06.03.2012Управление материальными, информационными и финансовыми потоками предприятия. Основные модели имитации денежных потоков. Понятие случайного процесса. Финальные вероятности состояний. Правила составления системы уравнений А.Н. Колмогорова и их решение.
презентация [654,5 K], добавлен 22.10.2014Теория измерений. Использование чисел в жизни и хозяйственной деятельности людей. Инвариантные алгоритмы и средние величины. Численность работников различных категорий, их заработная плата и доходы. Величины в порядковой шкале. Средние по Колмогорову.
реферат [34,5 K], добавлен 09.01.2009Особенности метода проверки гипотезы о законе распределения по критерию согласия хи-квадрат Пирсона. Свойства базовой псевдослучайной последовательности. Методы оценки закона распределения и вероятностных характеристик случайной последовательности.
лабораторная работа [234,7 K], добавлен 28.02.2010Алгоритм построения полиномиальной функции регрессии с оценкой степени полинома по заданному набору точек. Разработка программы, моделирующей выборку случайных пар чисел и выявление стохастической зависимости между ними при помощи уравнения регрессии.
контрольная работа [114,3 K], добавлен 19.02.2014Изучение показателей качества конструкционного газобетона как случайных величин. Проведение модульного эксперимента и дисперсионного анализа с целью определения достоверности влияния факторов на поведение выбранных показателей качества данной продукции.
курсовая работа [342,3 K], добавлен 08.05.2012Ковариация и коэффициент корреляции, пары случайных переменных. Вычисление их выборочных значений и оценка статистической значимости в Excel. Математическая мера корреляции двух случайных величин. Построение моделей парной и множественной регрессии.
контрольная работа [2,2 M], добавлен 24.12.2014Вычисление раннего и позднего сроков наступления событий. Расчет резерва времени работ. Определение критического пути проекта, вычисление его длительности. Момент наступления исходного события. Построение сетевого графика с обозначением критического пути.
контрольная работа [22,5 K], добавлен 04.08.2013Эконометрическая модель и исследование проблемы автокорреляции случайных отклонений с помощью тестов Бреуша-Годфри, Сведа-Эйзенхарта и статистики Дарбина-Уотсона. Связь между реальным и номинальным обменными курсами на примере белорусского рубля.
курсовая работа [483,8 K], добавлен 19.12.2011Структура и параметры эффективности функционирования систем массового обслуживания. Процесс имитационного моделирования. Распределения и генераторы псевдослучайных чисел. Описание метода решения задачи вручную. Перевод модели на язык программирования.
курсовая работа [440,4 K], добавлен 30.10.2010Статистическая модель случайного процесса. Численный метод Монте-Карло. Типы имитации, ее достоинства и возможности. Простая имитационная модель системы обработки документов. Использование для моделирования языка Siman. Его основные моделирующие блоки.
презентация [1,6 M], добавлен 22.10.2014Способы описания случайной величины, основные распределения и их генерация в Excel. Дисперсионный анализ как особая форма анализа регрессии. Применение элементов линейной алгебры в моделировании экономических процессов и решение транспортной задачи.
курс лекций [1,6 M], добавлен 05.05.2010Сущность закона больших чисел. Принцип диверсификации с математической точки зрения. Расчёт среднего ожидаемого дохода и среднего риска двух финансовых операций. Нетто-ставка как вероятность страхового случая. Обеспечение репрезентативности выборки.
презентация [78,1 K], добавлен 01.11.2013Методи генерування послідовності рівномірно розподілених випадкових чисел. Перевірка якості псевдовипадкових чисел. Використання методу Монте-Карло в імітаційному моделюванні. Обчислення інтегралу методом Монте-Карло. Переваги програмного методу.
методичка [2,8 M], добавлен 29.01.2010Определение ранних и поздних сроков совершения событий, критического пути. Расчет полного резерва времени, раннего срока наступления начального события и длительность самой работы. Способы вычисления свободных и полных резервов не критических работ.
контрольная работа [1,9 M], добавлен 18.05.2015Роль статистических методов в объективной оценке количественных и качественных характеристик процесса управления. Использование инструментов качества при анализе процессов и параметров продукции. Дискретные случайные величины. Теория вероятности.
курсовая работа [1,5 M], добавлен 11.01.2015Нахождение последовательности многочленов, нахождение их суммы и произведения. Вычисление суммы и среднего арифметического данного ряда чисел, нахождение минимального и максимального числа. Определение цены реализации товара в точке безубыточности.
контрольная работа [178,7 K], добавлен 06.11.2009Получение функции отклика показателя качества Y2 и формирование выборки объемом 15 и более 60. Зависимость выбранного Y от одного из факторов Х. Дисперсионный анализ и планирование эксперимента. Проведение корреляционного и регрессионного анализа.
курсовая работа [827,2 K], добавлен 19.06.2012Нахождение взаимосвязи между изменениями валютного курса, ставкой рефинансирования, доходами банка и изменением величины депозитов с ноября 2010 года по октябрь 2013 года. Корреляционный анализ экзогенных переменных. Значение коэффициента детерминации.
курсовая работа [41,8 K], добавлен 29.05.2014