kusano 7d535a
/*  -- translated by f2c (version 19940927).
kusano 7d535a
   You must link the resulting object file with the libraries:
kusano 7d535a
	-lf2c -lm   (in that order)
kusano 7d535a
*/
kusano 7d535a
kusano 7d535a
#include "f2c.h"
kusano 7d535a
kusano 7d535a
doublereal dlaran_(integer *iseed)
kusano 7d535a
{
kusano 7d535a
    /* System generated locals */
kusano 7d535a
    doublereal ret_val;
kusano 7d535a
kusano 7d535a
    /* Local variables */
kusano 7d535a
    static integer it1, it2, it3, it4;
kusano 7d535a
kusano 7d535a
kusano 7d535a
/*  -- LAPACK auxiliary routine (version 2.0) --   
kusano 7d535a
       Univ. of Tennessee, Univ. of California Berkeley, NAG Ltd.,   
kusano 7d535a
       Courant Institute, Argonne National Lab, and Rice University   
kusano 7d535a
       February 29, 1992   
kusano 7d535a
kusano 7d535a
kusano 7d535a
    Purpose   
kusano 7d535a
    =======   
kusano 7d535a
kusano 7d535a
    DLARAN returns a random real number from a uniform (0,1)   
kusano 7d535a
    distribution.   
kusano 7d535a
kusano 7d535a
    Arguments   
kusano 7d535a
    =========   
kusano 7d535a
kusano 7d535a
    ISEED   (input/output) INTEGER array, dimension (4)   
kusano 7d535a
            On entry, the seed of the random number generator; the array 
kusano 7d535a
  
kusano 7d535a
            elements must be between 0 and 4095, and ISEED(4) must be   
kusano 7d535a
            odd.   
kusano 7d535a
            On exit, the seed is updated.   
kusano 7d535a
kusano 7d535a
    Further Details   
kusano 7d535a
    ===============   
kusano 7d535a
kusano 7d535a
    This routine uses a multiplicative congruential method with modulus   
kusano 7d535a
    2**48 and multiplier 33952834046453 (see G.S.Fishman,   
kusano 7d535a
    'Multiplicative congruential random number generators with modulus   
kusano 7d535a
    2**b: an exhaustive analysis for b = 32 and a partial analysis for   
kusano 7d535a
    b = 48', Math. Comp. 189, pp 331-344, 1990).   
kusano 7d535a
kusano 7d535a
    48-bit integers are stored in 4 integer array elements with 12 bits   
kusano 7d535a
    per element. Hence the routine is portable across machines with   
kusano 7d535a
    integers of 32 bits or more.   
kusano 7d535a
kusano 7d535a
    ===================================================================== 
kusano 7d535a
  
kusano 7d535a
kusano 7d535a
kusano 7d535a
       multiply the seed by the multiplier modulo 2**48   
kusano 7d535a
kusano 7d535a
       Parameter adjustments */
kusano 7d535a
    --iseed;
kusano 7d535a
kusano 7d535a
    /* Function Body */
kusano 7d535a
    it4 = iseed[4] * 2549;
kusano 7d535a
    it3 = it4 / 4096;
kusano 7d535a
    it4 -= it3 << 12;
kusano 7d535a
    it3 = it3 + iseed[3] * 2549 + iseed[4] * 2508;
kusano 7d535a
    it2 = it3 / 4096;
kusano 7d535a
    it3 -= it2 << 12;
kusano 7d535a
    it2 = it2 + iseed[2] * 2549 + iseed[3] * 2508 + iseed[4] * 322;
kusano 7d535a
    it1 = it2 / 4096;
kusano 7d535a
    it2 -= it1 << 12;
kusano 7d535a
    it1 = it1 + iseed[1] * 2549 + iseed[2] * 2508 + iseed[3] * 322 + iseed[4] 
kusano 7d535a
	    * 494;
kusano 7d535a
    it1 %= 4096;
kusano 7d535a
kusano 7d535a
/*     return updated seed */
kusano 7d535a
kusano 7d535a
    iseed[1] = it1;
kusano 7d535a
    iseed[2] = it2;
kusano 7d535a
    iseed[3] = it3;
kusano 7d535a
    iseed[4] = it4;
kusano 7d535a
kusano 7d535a
/*     convert 48-bit integer to a real number in the interval (0,1) */
kusano 7d535a
kusano 7d535a
    ret_val = ((doublereal) it1 + ((doublereal) it2 + ((doublereal) it3 + (
kusano 7d535a
	    doublereal) it4 * 2.44140625e-4) * 2.44140625e-4) * 2.44140625e-4)
kusano 7d535a
	     * 2.44140625e-4;
kusano 7d535a
    return ret_val;
kusano 7d535a
kusano 7d535a
/*     End of DLARAN */
kusano 7d535a
kusano 7d535a
} /* dlaran_ */
kusano 7d535a