! ******************************************************************* ! * * ! * Function gausv * ! * * ! ******************************************************************* ! Single Precision Version 3.2 ! Written by Gordon A. Fenton, TUNS, Mar. 21, 1993. ! Latest Update: Dec. 5, 1996 ! ! PURPOSE return a normally distributed N(0,var) random realization. ! ! Returns a normally distributed, zero mean, random variable. ! The argument "var" is the variance of the random number. ! Ensure that the machine specific random number generator "randu" is ! initiated in the calling routine with a suitable seed. See `iseed'. ! Arguments to the function are; ! ! var real value prescribing the variance of the random variate. (input) ! ! ! Notes: ! 1) since randu returns random numbers in the range (0,1), excluding ! the endpoints, we need not guard against taking the log of zero ! below. ! ! REVISION HISTORY: ! 3.1 now using new randu function (RAN2 from Numerical Recipes, 2nd Ed) ! (Oct 14/96) ! 3.2 eliminated unused local variable `zero' (Dec 5/96) !--------------------------------------------------------------------------- real function gausv2( var ) real var, aa, rr logical getnxt save aa, rr data twopi/6.2831853071795864769/ data two/2.0/ data getnxt/.true./ if( getnxt ) then aa = twopi*randu2(0) rr = sqrt(-two*var*alog(randu2(0))) gausv2 = rr*cos(aa) getnxt = .false. else gausv2 = rr*sin(aa) getnxt = .true. endif return end