Geração de números uniformes

Documentos relacionados
GNA pelo método da aceitação e rejeição

Simulação estocásaca

Introdução aos Números Pseudo-aleatórios. Profa. Dra. Soraia Raupp Musse

O ALEATÓRIO EM COMPUTAÇÃO. Por Diogo Anderson Integrante do Grupo PET Computação

Estatística Computacional II

Estatística e Modelos Probabilísticos - COE241

O método Jackknife. Fundamentos e aplicações. Prof. Walmes Zeviani.

Um modelo estocástico para o fluxo de caixa de um plano de previdência de um indivíduo 15

Monte Carlo Method. Peter Frank Perroni. December 1, Monte Carlo Simulation

Estatística e Modelos Probabilísticos - COE241

Estatística e Modelos Probabilísticos - COE241

Estatística e Modelos Probabilísticos - COE241

Aula 7. Aula de hoje. Aula passada

Métodos de Monte Carlo

Aula 5. Como gerar amostras de uma distribuição qualquer a partir de sua CDF e de um gerador de números aleatórios?

Modelagem e Análise de Sistemas - COS767

Modelagem e Avaliação de Desempenho. Pós Graduação em Engenharia Elétrica - PPGEE Prof. Carlos Marcelo Pedroso 2016

Funções Geradoras de Variáveis Aleatórias. Simulação Discreta de Sistemas - Prof. Paulo Freitas - UFSC/CTC/INE

COMO FUNCIONA A SIMULAÇÃO. Capítulo 2 - Aula 2. Simulação Discreta de Sistemas - Prof. Paulo Freitas - UFSC/CTC/INE

Sexta Lista: Geração de Números Pseudo-Aleatórios e Método de Monte Carlo

Simulação: Pseudoaleatoriedade, um estudo sobre o método do meio do quadrado

Métodos Computacionais em Física

Métodos Computacionais em Física

Noções de Simulação. Ciências Contábeis - FEA - Noturno. 2 o Semestre MAE0219 (IME-USP) Noções de Simulação 2 o Semestre / 23

Física Estatística Computacional

Modelagem e Análise de Sistemas de Computação Aula 19

3 Definições. 3.1 Processos Estocásticos e Processo de Wiener

Aula de hoje. administração. São Paulo: Ática, 2007, Cap. 3. ! Tópicos. ! Referências. ! Distribuição de probabilidades! Variáveis aleatórias

Revisão de programação no R

Modelagem e Avaliação de Desempenho. Pós Graduação em Engenharia Elétrica - PPGEE Prof. Carlos Marcelo Pedroso 2017

Unidade VII Amostragem

SERVIÇO PÚBLICO FEDERAL MINISTÉRIO DA EDUCAÇÃO INSTITUTO FEDERAL DE EDUCAÇÃO, CIÊNCIA E TECNOLOGIA DE MINAS GERAIS IFMG

Variáveis Aleatórias Contínuas e Distribuição de Probabilidad

Simulações Computacionais de Sistemas Complexos

Modelagem e Avaliação de Desempenho. Pós Graduação em Engenharia Elétrica - PPGEE Prof. Carlos Marcelo Pedroso 2018

SERVIÇO PÚBLICO FEDERAL MINISTÉRIO DA EDUCAÇÃO INSTITUTO FEDERAL DE EDUCAÇÃO, CIÊNCIA E TECNOLOGIA DE MINAS GERAIS IFMG

SERVIÇO PÚBLICO FEDERAL MINISTÉRIO DA EDUCAÇÃO INSTITUTO FEDERAL DE EDUCAÇÃO, CIÊNCIA E TECNOLOGIA DE MINAS GERAIS IFMG

SERVIÇO PÚBLICO FEDERAL MINISTÉRIO DA EDUCAÇÃO INSTITUTO FEDERAL DE EDUCAÇÃO, CIÊNCIA E TECNOLOGIA DE MINAS GERAIS IFMG

CE Estatística I

Estatística Aplicada II. } Revisão: Probabilidade } Propriedades da Média Amostral

Exercícios de programação

Momentos: Esperança e Variância. Introdução

Monitor: Diego Augusto Silva (P8 Eng. Elétrica) Atendimento: 2as. de 19:45h às 21:30h

UMA APLICAÇÃO INGÊNUA DO MÉTODO DE MONTE CARLO: VISUALIZAÇÃO DE ORBITAIS ATÔMICOS MÁRIO GOTO 1 VERÍSSIMO MANOEL DE AQUINO 1

Processos Estocásticos. Variáveis Aleatórias. Variáveis Aleatórias. Luiz Affonso Guedes. Como devemos descrever um experimento aleatório?

Processos Estocásticos. Luiz Affonso Guedes

Mat2274 Estatística Computacional. Números (Pseudo) Aleatórios. Conceitos. Básicos. Conceito

Princípios de Modelagem Matemática Aula 09

Física Computacional 4 Integrais numéricos

Modelagem e Avaliação de Desempenho. Pós Graduação em Engenharia Elétrica - PPGEE Prof. Carlos Marcelo Pedroso 2014

Estatística e Modelos Probabilísticos - COE241

Aula 11. Prof. Laura Silva de Assis. Engenharia da Computação. CEFET/RJ - Centro Federal de Educação Tecnológica Celso Suckow da Fonseca

A Matemática como Serviço a Ciência da Computação. Prof. Dr. Carlos Eduardo de Barros Paes Coordenador do Curso de Ciência da Computação

Análise de dados em Fisica de Particulas

SERVIÇO PÚBLICO FEDERAL MINISTÉRIO DA EDUCAÇÃO INSTITUTO FEDERAL DE EDUCAÇÃO, CIÊNCIA E TECNOLOGIA DE MINAS GERAIS IFMG

2. EXERCÍCIOS PROPOSTOS SOBRE V.A. E DISTRIB.PROBAB.

SERVIÇO PÚBLICO FEDERAL MINISTÉRIO DA EDUCAÇÃO INSTITUTO FEDERAL DE EDUCAÇÃO, CIÊNCIA E TECNOLOGIA DE MINAS GERAIS IFMG

Cálculo das Probabilidades e Estatística I

Algoritmos Genéticos

6 Simulação de Monte Carlo - Visão Geral

Cálculo das Probabilidades I

ESTATÍSTICA COMPUTACIONAL

SERVIÇO PÚBLICO FEDERAL MINISTÉRIO DA EDUCAÇÃO INSTITUTO FEDERAL DE EDUCAÇÃO, CIÊNCIA E TECNOLOGIA DE MINAS GERAIS IFMG

Variáveis Aleatórias. Probabilidade e Estatística. Prof. Dr. Narciso Gonçalves da Silva

Processos Estocásticos. Variáveis Aleatórias. Variáveis Aleatórias. Variáveis Aleatórias. Variáveis Aleatórias. Luiz Affonso Guedes

Probabilidades. Wagner H. Bonat Elias T. Krainski Fernando P. Mayer

Simulações Computacionais de Sistemas Complexos

Inteligência Artificial

Sistemas Aleatórios. Um sistema é aleatório quando seu estado futuro só pode ser conhecido. jogar uma moeda ou um dado. decaimento de uma partícula

Variável aleatória. O resultado de um experimento aleatório é designado variável aleatória (X)

Modelos Probabilísticos Teóricos Discretos e Contínuos. Bernoulli, Binomial, Poisson, Uniforme, Exponencial, Normal

Distribuição Normal. Prof. Eduardo Bezerra. (CEFET/RJ) - BCC - Inferência Estatística. 25 de agosto de 2017

Estatística Básica. Prof. Dr. Walmes Marques Zeviani Prof. Dr. Paulo Justiniano Ribeiro Jr

IND 1115 Inferência Estatística Aula 6

Análise de Dados em Astronomia. 4. Simulações de Monte Carlo

Variáveis Aleatórias Contínuas

UMA INTRODUÇÃO AOS MÉTODOS DE GERAÇÃO DE NÚMEROS E VARIÁVEIS ALEATÓRIAS PARA APLICAÇÕES EM SIMULADORES

Redes Complexas Aula 7

Técnicas Computacionais em Probabilidade e Estatística I

Uma Breve Introdução ao Monte Carlo

RESOLUÇÃO Nº 01/2016

IND 1115 Inferência Estatística Aula 7

GERAÇÃO DE NÚMEROS E VARIÁVEIS ALEATÓRIAS

DISCIPLINAS OPTATIVAS PERFIL TEÓRICO

2. GERAÇÃO DE NÚMEROS PSEUDO-RANDÔMICOS. Para a utilização de seqüências de números randômicos precisamos dispor de meios 2.1.

PRE29006 LISTA DE EXERCÍCIOS #

Teoria das Filas aplicadas a Sistemas Computacionais. Aula 08

1) Deseja-se usar o algoritmo de rejeição para simular de uma v.a. normal positiva, cuja densidade é dada por. 2 x > 0.

Simulação a Eventos Discretos. Fernando Nogueira Simulação 1

Computação 1 - Python Aula 8 - Teórica: Estrutura de Repetição : for 1/ 10

CE Estatística I

4 Processos Estocásticos e Simulação de Monte Carlo

Modelagem em Engenharia C & A Aula 6 - Modelos Estatísticos/Estocásticos Aleatoriedade

Fernando Nogueira Simulação 1

Processamento de Imagens CPS755

Processo de chegada: o Chegadas em grupo ocorrem segundo um processo Poisson com taxa. O tamanho do grupo é uma variável aleatória discreta

Tiago Viana Flor de Santana

Inferência via abordagens computacionalmente intensivas. Walmes Zeviani

1) Considere Y N(1, 1) e X Y = y N(y, 4). A quantidade de interesse é θ = P (X > 1).

Transcrição:

Geração de números uniformes Importância e principais algorítmos Prof. Walmes Zeviani walmes@ufpr.br Laboratório de Estatística e Geoinformação Departamento de Estatística Universidade Federal do Paraná Atualizado em 2018-08-13

Justificativas Simulação computacional de processos estocásticos depende da geração de números aleatórios (GNA). TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO TODO Objetivos Discutir a importância da geração de números aleatórios em Estatística. Descrever os principais algorítmos para GNA uniformes. Walmes Zeviani DEST/UFPR Geração de números uniformes 2

A distribuição uniforme Se uma variável aleatória X tem distribuição uniforme contínua entre a e b, denotamos X U(a, b), e sua função de densidade é f(x, a, b) = 1 I(a x < b), < a < b <. (1) b a A função de probabilidade é F(x, a, b) = Pr(X < x) = x 0, x < a x a f(x, a, b) dx = b a, a x < b 1, x b. (2) A média e variância são funções dos parâmetros E(X) = a + b 2 e V(X) = (b a)2. (3) 12 Walmes Zeviani DEST/UFPR Geração de números uniformes 3

Importância da distribuição uniforme A distribuição tem pouca importância do ponto de vista de modelagem. Porém, para simulação computacional, ela é central. Números aleatório da Uniforme são: O principal ingrediente para GNA de outras distribuições. Usados em várias aplicações de Monte Carlo (e.g. integração MC, inf. Bayesiana por MCMC, etc.) Utilizados em otimização estocástica. Empregados em jogos digitais (e.g. poker online). Walmes Zeviani DEST/UFPR Geração de números uniformes 4

Geração de números aleatórios Números aleatórios reais São gerados por dispositivos via processos físicos. Globo de sorteio da Mega-Sena e bingos. Lançamento de um dado, moeda. Roleta de cassino. Para uso em maior escala, são geralmente baseados em fenômenos que geram um nível baixo de rúido. Ruído termal. Ruído fotoelétrico. Ruído acústico. Movimento browniano de partículas. Os sinais precisam ser traduzidos para números (intensidade). A distribuição da v.a. pode não ter forma conhecida. A v.a. pode ter correlação serial. São usados em criptografia. Walmes Zeviani DEST/UFPR Geração de números uniformes 5

Geração de números aleatórios Números pseudo-aleatórios reais São gerados por programas de computador, ou seja, algorítmos. Os número não são realmente aleatórios, pois, dado o algorítmo gerador, pode-se prever os números (tem reprodutibilidade). Do ponto de vista Estatístico, os números são imprevisíveis. Bons GNA terão propriedades interessantes para aplicações Estatística. Walmes Zeviani DEST/UFPR Geração de números uniformes 6

Propriedades desejáveis de um GNA Os valores gerados são completamente imprevisíveis e passam em testes de detecção de não aleatoriedade. A distribuição da v.a. é matematicamente conhecida (e.g. distribuição Uniforme). O GNA produz v.a. que não apresentarem correlação serial, ou seja, as realizações são independentes umas das outras. Walmes Zeviani DEST/UFPR Geração de números uniformes 7

Algorítmos para GNA Uniformes Existem vários algorítmos para GNA. No R, existem 7 opções para o algorítmo de GNA. Peça help(random) para consultar a respectiva documentação. Algorítmos disponíveis no R Wichmann-Hill. Marsaglia-Multicarry. Super-Duper. Mersenne-Twister (default). Knuth-TAOCP-2002. Knuth-TAOCP. L Ecuyer-CMRG. Walmes Zeviani DEST/UFPR Geração de números uniformes 8

GNA feito por mim Algorítmo 1. Definir um número u 0 (0, 1) e atribuir i = 0. 2. Calcular u i+1 = 0.5 + 0.5 sin(2πu i ). 3. Incrementar i fazendo i = i + 1. 4. Repetir 2 3 até obter a sequência de tamanho desejado. Atividades Implemente em R o algorítmo acima. Considere x 0 = 0.3 e gere 1000 números. Inspecione a amostra de números varificar existência de independência, periodicidade e forma da distribuição. Walmes Zeviani DEST/UFPR Geração de números uniformes 9

GNA de von Neumann Artigo von Neumann, J. (1951). Various Techniques Used in Connection with Random Digits. In the Monte Carlo Method (ed. A.S. Householder et al., 36-38). Nat. Bur. Standards Appl. Math Ser. no. 12. Algorítmo 1. Definir um número u 0 de quadro digitos decimais e atribuir i = 0. 2. Calcular u 2 i. Agregar zeros à esquerda, quando necessário, para manter representação com 4 digitos: u 2 i = d 7 d 6... d 0, onde cada d j é um inteiro entre 0 e 9. 3. Fazer u i+1 = d 5 d 4 d 3 d 2. 4. Incrementar i fazendo i = i + 1. 5. Repetir 2 4 até obter a sequência de tamanho desejado. Implemente e inspecione as propriedades deste GNA Uniformes. Walmes Zeviani DEST/UFPR Geração de números uniformes 10

O método congruencial linear O método congruencial linear é baseado na seguinte expressão recursiva em que u i N no intervalo [0, m 1], a N + é chamado de multiplicador, c N + é chamado de incremento, m N + é chamado de módulo. u i+1 = (au i + c) mod m, (4) Se a, c e m forem adequadamente escolhidos, a cardinalidade do conjunto de valores gerados é no máximo m. Walmes Zeviani DEST/UFPR Geração de números uniformes 11

Implementação e avaliação Baseado nas orientações em Ferreira 2013. Implemente e inspecione usando as configurações u 0 = 7, a = 7, c = 7 e m = 10. u 0 = 7, a = 7 5, c = 0 e m = 2 31 1 (Park & Miller, 1988, apud Ferreira 2013). Ferreira 2013 citando Schrage (1979), comenta que { a(u i mod q) r u i /q se maior que 0, au i mod m = a(u i mod q) r u i /q + m caso contrário, (5) é uma implementação mais portável para linguagens de baixo nível. Em que q = m/a e r = m mod a, que resulta em m aq + r. Walmes Zeviani DEST/UFPR Geração de números uniformes 12

Implementação em R Método congruencial linear # a = 7^5 # m = 2^31-1 rand_congr0 <- function(n = 1, x0, a = 16807, m = 2147483647) { if (missing(x0)) x0 <- as.integer(sys.time()) stopifnot(x0 < m) n <- n + 1 x <- vector(mode = "integer", length = n) x[1] <- x0 for (i in 2:n) { x[i] <- (a * x[i - 1]) %% m } return(x[-1]) } rand_congr0(n = 10, x0 = 321) Walmes Zeviani DEST/UFPR Geração de números uniformes 13

Implementação em R Método congruencial linear de Schrage rand_congr1 <- function(n = 1, x0) { a <- 16807; m <- 2147483647; q <- 127773; r <- 2836 # Verifique que: a * (321 %% q) == a * (321 - r * floor(321/q)). if (missing(x0)) x0 <- as.integer(sys.time()) stopifnot(x0 < m) n <- n + 1 x <- vector(mode = "integer", length = n) x[1] <- x0 for (i in 2:n) { k <- floor(x[i - 1]/q) x[i] <- a * (x[i - 1] - k * q) - k * r if (x[i] < 0) { x[i] <- x[i] + m } } return(x[-1]) } Walmes Zeviani DEST/UFPR Geração de números uniformes 14

Próxima aula Outros algorítmos para GNA Uniforme. GNA de variáveis aleatórias discretas. GNA de variáveis aleatórias contínuas. Pacote purrr. Avisos Sabatina no Moodle do conteúdo da semana passada. Notas das sabatinas já estão disponíveis! Walmes Zeviani DEST/UFPR Geração de números uniformes 15

Referências bibliográficas Ferreira, D. F. (2013). Estatística Computational em Java. Editora UFLA. Walmes Zeviani DEST/UFPR Geração de números uniformes 16