gasdev.c 558 B

1234567891011121314151617181920212223
  1. /* gasdev.c */
  2. #include <math.h>
  3. #include "ransurf.h"
  4. #include "local_proto.h"
  5. /* GasDev() returns a random double with a mean of 0.0 and a standard */
  6. /* deviation of 1.0. */
  7. double GasDev(void)
  8. {
  9. double fac, r, v1, v2;
  10. do {
  11. v1 = 2.0 * ran1() - 1.0;
  12. v2 = 2.0 * ran1() - 1.0;
  13. r = v1 * v1 + v2 * v2;
  14. } while (r >= 1.0);
  15. fac = sqrt(-2.0 * log(r) / r);
  16. G_debug(3, "(v2 * fac):%.12lf", v2 * fac);
  17. return (v2 * fac);
  18. }