JosAntonioSandovalAc
27,041 views
61 slides
Dec 24, 2016
Slide 1 of 61
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
About This Presentation
TecNM
Ingeniería en Sistemas Computacionales
Simulación
Unidad 2 numeros pseudoaleatorios
Size: 1.44 MB
Language: es
Added: Dec 24, 2016
Slides: 61 pages
Slide Content
TECNOLÓGICO NACIONAL DE MÉXICO Ingeniería en Sistemas Computacionales Simulación Unidad II: Números Pseudoaleatorios Material de clase desarrollado para la asignatura de Simulación para Ingeniería en Sistemas Computacionales SIMULACIÓN
FUNDAMENTOS DE INGENIERÍA DE SOFTWARE Competencias: Conocer la diferencia entre un número aleatorio y un pseudoaleatorio . Identificar y aplicar los métodos de generación de números pseudoaleatorios . Aplicar e interpretar las pruebas estadísticas a los números pseudoaleatorios . Seleccionar el generador de números pseudoaleatorios a utilizar en la unidad siguiente. Aplicar el método de Montecarlo a la solución de un problema matemático.
Se llama números pseudoaleatorios a una sucesión determinística de números en el intervalo [0,1] que tiene las mismas propiedades estadísticas que una sucesión de números aleatorios. Los números pseudoaleatorios son necesarios cuando se pone en práctica un modelo de simulación, para obtener observaciones aleatorias a partir de distribuciones de probabilidad. Los números aleatorios generados en un inicio por una computadora casi siempre son números aleatorios enteros GENERACIÓN DE NÚMEROS PSEUDOALEATORIOS SIMULACIÓN
La aplicación de los números aleatorios se remonta a los tiempos de la primera revolución industrial, cuando los procesos manuales tuvieron que reemplazarse por procesos mecanizados como consecuencia de la explosión demográfica que se estaba presentando en los países desarrollados con la disminución de las tasas de mortalidad y el aumento de las tasas de natalidad y que, para satisfacer las necesidades de la población cada vez más creciente hubo necesidad de incrementar la producción de toda clase de bienes y servicios. SIMULACIÓN
El procedimiento usado por una computadora para generar números aleatorios se llama: GENERADOR DE NÚMEROS ALEATORIOS La referencia a secuencias de números aleatorios significa que: el algoritmo produce muchos números aleatorios en serie . Es posible identificar diferentes métodos usados a través de la historia para generar números aleatorios que pudieran ser utilizados en los procesos de simulación de las actividades industriales. Dichos métodos pudiéramos clasificarlos en: Manuales Tablas de Biblioteca Generadores Analógicos Generadores Digitales Métodos de Recurrencia o Congruenciales SIMULACIÓN
Método de los cuadrados medios Procedimiento : Seleccionar un valor para semilla número entero, positivo, con e dígitos par Elevar al cuadrado no, completar con ceros a la izquierda del número hasta tener 2*e dígitos, seleccionar los e dígitos centrales del número como n i Calcular Repetir 2 y 3 tantas veces como sea necesario. SIMULACIÓN
Ejemplo: Suponga que se desean generar números aleatorios por el método de los cuadrados medios con 1111 como semilla y e=8. SIMULACIÓN
Ejercicio Generar 20 números pseudoaleatorios en base a la semilla 1572 con e=3 Genere la tabla correspondiente SIMULACIÓN
Algoritmo de los P roductos Medios La mecánica de generación de números pseudoaleatorios de este algoritmo no congruencial es similar a la del algoritmo de cuadrados medios. La diferencia entre ambos radica en que el algoritmo de productos medios requiere dos semillas, ambas con D dígitos ; además , en lugar de elevarlas al cuadrado, las semillas se multiplican y del producto se seleccionan los D dígitos del centro, los cuales formarán el primer número pseudoaleatorio r¡ = 0.D dígitos. SIMULACIÓN
Después se elimina una semilla , y la otra se multiplica por el primer número de D dígitos, para luego seleccionar del producto los D dígitos que conformarán un segundo número r ( .. Entonces se elimina la segunda semilla y se multiplican el primer número de D dígitos por el segundo número de D dígitos; del producto se obtiene el tercer número r¡. Siempre se irá eliminando el número más antiguo, y el procedimiento se repetirá hasta generar los n números pseudo aleatorios. SIMULACIÓN
A continuación se presentan con más detalle los pasos del método para generar números con el algoritmo de producto medios. 1. Seleccionar una semilla (X ) con D dígitos (D > 3). 2. Seleccionar una semilla (X } ) con D dígitos (D > 3). 3. Sea V = X Q *X : ; sea X 2 = los D dígitos del centro, y sea r. = 0.D dígitos del centro. 4. Sea f¡ = X*X Í+1 ; sea X ¡+2 = los D dígitos del centro, y sea r í+1 = 0.D dígitos del centro para toda f¡= 1,2,3,...,/?; 5. Repetir el paso 4 hasta obtener los n números r¡ deseados. Nota: Si no es posible obtener los D dígitos del centro del número /^agregue ceros a la izquierda del número Y¡. SIMULACIÓN
Ejemplo Generar los primeros 5 números r¡ a partir de las semillas X = 5 015 y X 1 , = 5 734; observe que ambas semillas tienen D = 4 dígitos. SIMULACIÓN
Algoritmo de multiplicador constante Este algoritmo no congruencial es similar al algoritmo de productos medios. Los siguientes son los pasos necesarios para generar números pseudoaleatorios con el algoritmo de multiplicador constante . Seleccionar una semilla (X ) con D dígitos (D > 3). Seleccionar una constante (a) con D dígitos (D > 3). Sea Y Q - a*X ; sea X, = los D dígitos del centro, y sea r¡ = 0.D dígitos del centro. Sea Y¡ = a*X ¡ ; sea X /+1 = los D dígitos del centro, y sea r M = 0.D dígitos del centro para toda /' = 1,2,3,..., n. Repetir el paso 4 hasta obtener los n números f. deseados . Nota : Si no es posible obtener los D dígitos del centro del número Y jt agregue ceros a la izquierda del número Y r SIMULACIÓN
Ejemplo: Generar los primeros 5 números pseudoaleatorios r¡ a partir de la semilla X = 9 803 y con la constante a = 6 965. Observe que tanto la semilla como la constante tienen D = 4 dígitos, e=3. SIMULACIÓN
Algoritmo lineal Este algoritmo congruencial fue propuesto por D. H. Lehmer , en 1951. Según Law y Kel -ton , este algoritmo ha sido el más usado. El algoritmo congruencial lineal genera una secuencia de números enteros por medio de la siguiente ecuación recursiva: X í+1 = ( aX (. + c) mod (m) /'= 0,1,2,3,n Donde X es la semilla, a es la constante multiplicativa, c es una constante aditiva y m es el módulo; X >0 , a > , c >0 y m >0 deben ser números enteros. La operación " mod m " significa multiplicar X ( por a , sumar c y dividir el resultado entre m para obtener el residuo X /+1 . SIMULACIÓN
Es importante señalar que la ecuación recursiva del algoritmo congruencial lineal genera una secuencia de números enteros S = {0,1,2,3, ...,m - 1},y que para obtener números pseudo aleatorios en el intervalo (0,1) se requiere la siguiente ecuación: SIMULACIÓN
Ejemplo: Generar 4 números entre O y 1 con los siguientes parámetros : X = 37 , a = 19 , c = 33 y m = 100. SIMULACIÓN
Algoritmo congruencial multiplicativo El algoritmo congruencial multiplicativo surge del algoritmo congruencial lineal cuando c = 0. Entonces la ecuación recursiva es: En comparación con el algoritmo congruencial lineal, la ventaja del algoritmo multiplicativo es que implica una operación menos a realizar. Los parámetros de arranque de este algoritmo son X QI a y m , todos los cuales deben ser números enteros y mayores que cero. SIMULACIÓN
Para transformar los números X (. en el intervalo (0,1) se usa la ecuación r¡ - x.J {m - 1). De acuerdo con Banks, Carson, Nelson y Nicollas condiciones que deben cumplir los parámetros para que el algoritmo congruencial multiplicativo alcance su máximo periodo son: SIMULACIÓN
Generar suficientes números entre 0 y 1 con los siguientes parámetros : X = 17, k = 2 y g = 5, hasta encontrar el periodo o ciclo de vida. Solución: a = 5+8(2) = 21 ; m= 32 SIMULACIÓN
Algoritmo congruencial aditivo Este algoritmo requiere una secuencia previa de n números enteros X 1 , X 2 , X 3 , X 4 ,..., X n para generar una nueva secuencia de números enteros que empieza en X n+1 , X n+2 , X n+3 , X n+4 ,... Su ecuación recursiva es: SIMULACIÓN
Ejemplo : Generar 7 números pseudoaleatorios entre cero y uno a partir de la siguiente secuencia de números enteros: 65, 89, 98, 03, 69; m = 100. X = 60. Sean X 1 = 65, X 2 = 89, X 3 = 98, X 4 = 03, X 5 = 69. Para generar e v r 2 , r y , r 4 , r 5 , r 6 y r 7 antes es necesario generar X^, X^, X^, X^, X^, X^, X^. SIMULACIÓN
Algoritmos congruenciales no lineales Algoritmo congruencial cuadrático SIMULACIÓN
Ejemplo: Generar , a partir del algoritmo congruencial cuadrático, suficientes números enteros hasta alcanzar el periodo de vida, considerando los parámetros: X = 13, m = 8, a = 26, b = 27 y c = 27. Como todas las condiciones estipuladas para los parámetros se satisfacen, es de esperarse que el periodo de vida del generador sea N = m = 8, tal como podrá comprobar al revisar los cálculos correspondientes, que se presentan a continuación. SIMULACIÓN
PRUEBAS DE ALEATORIEDAD SIMULACIÓN
1) Distribución Uniforme 2) Independencia (no correlacionados) ADEMÁS SON IMPORTANTES LOS SIGUIENTES ASPECTOS: a) Las subsecuenticas también deben cumplir 1) y 2) b ) Deben ser secuencias largas y sin huecos (densas) c) Algoritmos rápidos y que no demanden mucha memoria. HIPÓTESIS SIMULACIÓN
NÚMEROS ALEATORIOS ENTEROS . Es una observación aleatoria de una distribución uniforme sincretizada en el intervalo n, n+1… Por lo general , n =0 ó 1 donde estos son valores convenientes para la mayoría de las aplicaciones NÚMEROS ALEATORIOS UNIFORMES . Es una observación aleatoria a partir de una distribución uniforme (continua) en un intervalo [a, b] LOS NÚMEROS ALEATORIOS SE PUEDEN DIVIDIR EN DOS CATEGORÍAS PRINCIPALES: SIMULACIÓN
Ajustarse a una distribución U (0,1). Ser estadísticamente independientes (no debe deducirse un número conociendo otros ya generados). Ser reproducibles (la misma semilla debe dar la misma sucesión). Ciclo repetitivo muy largo. Facilidad de obtención. Ocupar poca memoria. PROPIEDADES MÍNIMAS QUE DEBERÁN SATISFACER LOS NÚMEROS PSEUDOALEATORIOS: SIMULACIÓN
DEBEN SER: Uniformemente distribuidos Estadísticamente independientes Reproducibles Sin repetición dentro de una longitud determinada de la sucesión Generación a grandes velocidades Requerir el mínimo de capacidad de almacenamiento Instituto CONDICIONES SIMULACIÓN
Las propiedades estadísticas que deben poseer los números pseudoaleatorios generados por los métodos congruenciales tienen que ver con independencia y aleatoriedad estadísticas. PRUEBAS ESTADÍSTICAS DE ALEATORIEDAD SIMULACIÓN
Una de las propiedades que deben cumplir los números del conjunto r ¡ , es que el valor esperado sea igual a 0.5. La prueba que busca determinar lo anterior es la llamada prueba de medias , en la cual se plantean las siguientes hipótesis: La prueba de medias consiste en determinar el promedio de los n números que contiene el conjunto r ¡ , mediante la ecuación siguiente: SIMULACIÓN Hipótesis Nula Hipótesis Interna
Prueba de Medias Esta prueba consiste en verificar que los números generados tengan una media estadísticamente igual a ½ o 0.5, de este modo la hipótesis planteada es : Paso 1, Calcular la media de los n números generados Paso 2, Calcular los límites superior e inferior de aceptación. Paso 3, Si el valor se encuentra entre li y ls , aceptamos que los números tienen una media estadísticamente igual a ½ con un nivel de aceptación 1-α. SIMULACIÓN
Ejemplo SIMULACIÓN
Ejercicio SIMULACIÓN
Ejercicio SIMULACIÓN
Prueba de Varianza Otra propiedad que debe satisfacer el conjunto de r i , es que sus números tengan una varianza de 1/12. la prueba que busca determinar lo anterior es la prueba de varianza, que establece las siguientes hipótesis: H : σ 2 ri =1/12 H 1 : σ 2 ri ≠1/12 SIMULACIÓN
La prueba de varianza consiste en determinar la varianza de los n números que contiene r i , mediante la ecuación siguiente: Después se calculan los limites de aceptación inferior y superior con las ecuaciones siguientes: SIMULACIÓN
Si el valor de V(r) se encuentra entre los límites de aceptación, decimos: No se puede rechazar que el conjunto r i tiene una varianza de 1/12, con un nivel de aceptación de 1- α ; De lo contrario, se rechaza que el conjunto r i tiene una varianza de 1/12. SIMULACIÓN
Ejemplo: realizar la prueba de varianza a los 40 números r i de la siguiente tabla. Considerando que n=40 y α =5%, procedemos a calcular la varianza de los números, y los límites de aceptación correspondientes SIMULACIÓN
Resultados SIMULACIÓN Chi Cuadrada
Dado que el valor de la varianza: V(r)= 0.087034 está entre los limites de aceptación, podemos decir que no se puede rechazar que el conjunto de 40 números r i tiene una varianza de 1/12= 0.08333. SIMULACIÓN
Ejemplo 2 : determine si el siguiente conjunto n=30 números cumple con la prueba de varianza, teniendo un α =5 %. SIMULACIÓN
Ejemplo 3 : determine si el siguiente conjunto n=30 números cumple con la prueba de varianza, teniendo un α =5%. SIMULACIÓN
Una de las propiedades más importantes que debe cumplir un conjunto de números ri es la uniformidad. Para comprobar su acatamiento se han desarrollado pruebas estadísticas tales como las pruebas Chi-cuadrada y de Kolmogorov-Smirnov . En cualquiera de ambos cosas, para probar la uniformidad de los números de un conjunto r i es necesario formular las siguientes hipótesis: Prueba de Chi-Cuadrada SIMULACIÓN
Tenemos dos hipótesis: Ho: ri ~U (0,1) (es distribución uniforme) H1: r i no son uniformes SIMULACIÓN
La prueba Chi-cuadrada busca determinar si los números del conjunto ri se distribuyen uniformemente en el intervalo (0,1). Para llevar a cabo esta prueba es necesario dividir el intervalo (0,1), en m subintervalos, en donde es recomendable m= √n. Posteriormente se clasifica cada número pseudo aleatorio del conjunto ri en los m intervalos . SIMULACIÓN
A la cantidad de números ri que se clasifican en cada intervalo se le denomina frecuencia observada (Oi), y a la cantidad de números ri que se espera encontrar en cada intervalo se le llama frecuencia esperada (Ei); teóricamente, la ri es igual a n/m. A partir de los valores de Oi y Ei se determina el estadístico mediante la ecuación: SIMULACIÓN
Si el valor del estadístico es menor al valor de tablas de , entonces no se puede rechazar que el conjunto de números ri sigue una distribución uniforme. En caso contrario, se rechaza que ri sigue una distribución uniforme. SIMULACIÓN
SIMULACIÓN Ej. Realizar la prueba de chi -cuadrada a los siguientes 100 números de un conjunto ri , con un nivel de confianza del 95 % y a=5%
Cálculos para la prueba chi -cuadrada SIMULACIÓN
El estadístico =6.2 es menor al estadístico correspondiente de la chi - cuadrada = 16.9. En consecuencia, no se puede rechazar que los números ri siguen una distribución uniforme. Resultado SIMULACIÓN
Ejercicio: Realizar la prueba de chi -cuadrada a los siguientes 100 números de un conjunto ri , con un nivel de confianza del 95% y a=5% SIMULACIÓN
Ejercicio: Realizar la prueba de chi -cuadrada a los siguientes 100 números de un conjunto ri , con un nivel de confianza del 99% y a=1% SIMULACIÓN 0.9550 0.8932 0.0828 0.3670 0.2364 0.4713 0.1902 0.9972 0.8630 0.6944 0.4048 0.1691 0.9587 0.4497 0.3330 0.8932 0.2024 0.2133 0.7432 0.5486 0.8930 0.8930 0.6384 0.2322 0.4678 0.5872 0.4035 0.3151 0.2168 0.4510 0.1505 0.4461 0.5730 0.6885 0.4465 0.7365 0.3029 0.6068 0.6507 0.4593 0.6742 0.7428 0.5764 0.9657 0.4596 0.7932 0.9662 0.1931 0.8500 0.6076 0.2990 0.6736 0.3407 0.7466 0.9325 0.0098 0.8561 0.2708 0.8821 0.2515 0.1750 0.7691 0.2763 0.0421 0.8792 0.2516 0.4566 0.8877 0.7192 0.7397 0.1938 0.9258 0.8053 0.7505 0.8296 0.4957 0.2403 0.0769 0.1835 0.7654 0.2169 0.2935 0.8560 0.6746 0.8516 0.6540 0.1670 0.9600 0.7875 0.5586 0.6455 0.3088 0.4140 0.9188 0.1937 0.9959 0.6978 0.2760 0.8005 0.8569
Propuesta por Kolmogorov-Smirnov , esta es una prueba estadística que también nos sirve para determinar si un conjunto ri cumple la propiedad de uniformidad. Es recomendable aplicarla en conjuntos ri pequeños, por ejemplo n<20 . El procedimiento es el siguiente: Prueba de Kolmogorov-Smirnov SIMULACIÓN
1. Ordenar de menor a mayor los números del conjunto ri. r 1 ≤r 2 ≤r 3 ≤… ≤ r n 2. Determinar los valores de D+, D- y D con las siguientes ecuaciones: SIMULACIÓN
3. Determinar el valor critico de acuerdo con la tabla de valores críticos de Kolmogorov-Smirnov para un grado de confianza α , y según el tamaño de la muestra n. 4. Si el valor D es mayor que el valor critico: Se concluye que los números del conjunto ri no siguen una distribución uniforme; de lo contrario se dice que no se ha detectado diferencia significativa entre la distribución de los números del conjunto ri y la distribución uniforme. SIMULACIÓN
Ej. Realizar una prueba de Kolgomorov-Smirnov , con un nivel de confianza de 90%, al siguiente conjunto ri de 10 números Para determinar los valores de D+, D- y D es recomendable realizar una tabla como la siguiente: SIMULACIÓN r i = 0.97 0.11 0.65 0.26 0.98 0.03 0.13 0.89 0.21 0.69
De acuerdo con la tabla de valores para la prueba de Kolmogorov-Smirnov , el valor crítico; correspondiente a n=10 es =0.368, que resulta mayor al valor D=.24; por lo tanto, se concluye que los números del conjunto r i , se distribuyen uniformemente. SIMULACIÓN
Ejercicio: Realizar una prueba de Kolgomorov-Smirnov , con un nivel de confianza de 95%, al siguiente conjunto ri de 10 números Para determinar los valores de D+ , D- y D realice la tabla correspondiente: SIMULACIÓN r i = 0.7012 0.1828 0.8336 0.5178 0.8875 0.6833 0.5517 0.8590 0.4331 0.3338