Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube
JC Mouse Bolivia
Index / Java / Generador de números aleatorios UNIX

Generador de números aleatorios UNIX

Autor jc mouse domingo, marzo 30, 2014

El Método Congruencial Lineal Mixto es el más utilizado en simulación en computadoras digitales y esta basado en una relación de recurrencia que ademas utiliza el operador MOD.

El objetivo de los GCL  es generar un valor aleatorio a partir de otro anterior

El GCL Mixto esta definido como:

Formula 1

Formula 2

Donde:

Xo : Semilla del generador Xo > 0

a: Constante multiplicativa a>0

c: Constante aditiva c>0

m: modulo m>a; m>Xo ; m>c

La suma (a*Xo+c) será dividida por «m» y «Xn+1» será el residuo de la división

Xn : es el valor base anterior

Xn+1 : es el nuevo valor uniforme entero

rn : es el número aleatorio normalizado

GENERADOR UNIX

El Sistema Operativo UNIX soporta el siguiente GCL mixto:

GCL UNIX

Implementado este en lenguaje java tenemos

import java.math.*;
/**
 * @web http://jc-mouse.net/
 * @author Mouse
 */
public class Unix {

    // parametros del generador
    private BigInteger xn=new BigInteger("0"); //semilla 
    private final BigInteger a  = new BigInteger("1103515245"); //Multiplicador
    private final BigInteger m = new BigInteger("2").pow(32); //Modulo
    private final BigInteger c  = new BigInteger("12345"); //Constante aditiva

    private int precision = 5;//cantidad de digitos despues del punto decimal

    /** Constructor de clase */
    public Unix(){} 

    public BigInteger getXn() {
        return xn;
    }

    public void setXn(BigInteger xn) {
        this.xn = xn;
    }

    public int getPrecision() {
        return precision;
    }

    public void setPrecision(int precision) {
        this.precision = precision;
    }   

    /**
 * Metodo que obtiene un numero aleatorio entre 0 y 1
 * 
 * @param No existe parametros de entrada
 * @return El numero aleatorio estandar 
 */
    public BigDecimal next()
    {           
        //xn = (a * xn + c) % m ;
        xn = ((xn.multiply(a)).add(c)).mod(m);        
        BigDecimal x  = new BigDecimal( xn.floatValue() / m.floatValue() ).setScale( precision, BigDecimal.ROUND_HALF_UP);        
        return  x;
    }

}

Realizando un test para un valor semilla Xo de 111 para una cantidad de 100 números aleatorios tenemos:

Unix unix = new Unix();
unix.setXn( new BigInteger( "111" ) );
unix.setPrecision( 5 );        
for( int i=1 ; i<=100 ; i++){            
    System.out.println( unix.next() );
}

Excel GCL

enjoy!!! 🙂

Tags

Si te ha gustado podrías compartirlo o dejar un comentario. ¡Muchas gracias!
Autor: JC Mouse

Yo soy yo :) JC Mouse, Soy orgullosamente boliviano soy fundador y CEO de la web jc-Mouse.net uno de las pocas web en emprendimiento y tecnología en Bolivia.

Toda la información que encuentres en este sitio es y sera completamente gratis siempre, puedes copiar, descargar y re-publicar si así lo deseas en otros blogs o sitios web, solo te pido a cambio que dejes una referencia a esta web. Esto nos ayuda a crecer y seguir aportando. Bye

Enjoy! :)

También Te Podría Interesar

Uso de BorderPane

Uso de BorderPane

BorderPane es un layout que distribuye los nodos hijos en 5 posiciones TOP, LEFT, BOTTOM, RIGHT y CENTER Los nodos hijos...

Material Design: Notificaciones (Snackbar)

Material Design: Notificaciones (Snackbar)

Material Design introduce una nueva forma de mostrar notificaciones al usuario, estos son los snackbar, similares a los...

Crea un «Juego de Memoria» en java

Crea un «Juego de Memoria» en java

En este tutorial crearemos un sencillo juego de memoria en lenguaje java. Necesitamos IDE Netbeans 7.x Editor de imágene...

Tweetbotornot: Detección de Bots de Twitter

Tweetbotornot: Detección de Bots de Twitter

El modelo Tweetbotornot es un algoritmo de aprendizaje automático que se entrenó en miles de cuentas reales de bot y no...

Sourcetrail ahora es Open Source

Sourcetrail ahora es Open Source

Sourcetrail el explorador de código fuente de los lenguaje C, C ++, Java y Python se pasa al Software Libre y desde ahor...

Reportes y Subreportes con iReport

Reportes y Subreportes con iReport

Cuando creamos reportes en iReport que son un poco complicadas o reportes personalizados, osea, tratando de evitar el cl...

6 comentarios en “Generador de números aleatorios UNIX”

  1. NELSON dice:

    EXCELENTE HERMANO!! VAMOS GANANDOOO SOMOS LOS PRIMEROSSS COLOMBIAAA!!! JEJEJ

  2. Brother excelente trabajo, con esto me doy cuenta que me falta muchísimo por aprender pero estoy trabajando para lograrlo, saludos y continúa haciendo este tipo de tutoriales, te agradezco mucho.

  3. Luis Rodriguez dice:

    Hola, buenas noches, mi pregunta es: como podria aplicar este codigo en el patron MVC? me seria de mucha ayuda para mi proyecto 🙂 gracias y saludos desde Venezuela

  4. Adan dice:

    Hola, una pregunta, ya obtuve la contraseña, pero dónde la tengo que ingresar?

  5. liz andrea mamani dice:

    muuchas gracias !!! un excelente trabajo, gracias por el aporte 🙂

Los comentarios estan cerrados

Comparte lo que sabes

Categorias

Últimas entradas

Si trabajas con redes sociales (RRSS) a continuación te muestro tres herramintas gratuitas que te ayudaran a la hora de...

Por lo general se usan transacciones a nivel base de datos y posteriormente se llaman estos a través de procedimientos a...

En este post, aprenderemos como conectar Visual Basic 6 con SQL Server, abrir una tabla, leer su contenido y mostrar est...

Lo que veremos en este post es la configuración del driver para PHP de SQL Server que ha creado Microsoft el cual permit...

Herramientas

Generador de Enlaces a Whatsapp