random.c 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /* random.c */
  2. #include <grass/gis.h>
  3. #include "ransurf.h"
  4. #define M1 259200
  5. #define IA1 7141
  6. #define IC1 54773
  7. #define RM1 (1.0/M1)
  8. #define M2 134456
  9. #define IA2 8121
  10. #define IC2 28411
  11. #define RM2 (1.0/M2)
  12. #define M3 243000
  13. #define IA3 4561
  14. #define IC3 51349
  15. /* ran1() returns a double with a value between 0.0 and 1.0 */
  16. double ran1(void)
  17. {
  18. static long ix1, ix2, ix3;
  19. static double r[98];
  20. double temp;
  21. static int iff = 0;
  22. int j;
  23. G_debug(2, "ran1()");
  24. if (Seed < 0 || iff == 0) {
  25. iff = 1;
  26. ix1 = (IC1 - Seed) % M1;
  27. ix1 = (IA1 * ix1 + IC1) % M1;
  28. ix2 = ix1 % M2;
  29. ix1 = (IA1 * ix1 + IC1) % M1;
  30. ix3 = ix1 % M3;
  31. for (j = 1; j <= 97; j++) {
  32. ix1 = (IA1 * ix1 + IC1) % M1;
  33. ix2 = (IA2 * ix2 + IC2) % M2;
  34. r[j] = (ix1 + ix2 * RM2) * RM1;
  35. }
  36. Seed = 1;
  37. }
  38. ix1 = (IA1 * ix1 + IC1) % M1;
  39. ix2 = (IA2 * ix2 + IC2) % M2;
  40. ix3 = (IA3 * ix3 + IC3) % M3;
  41. j = 1 + ((97 * ix3) / M3);
  42. if (j > 97 || j < 1)
  43. G_fatal_error("RAN1: j==%d shouldn't happen", j);
  44. temp = r[j];
  45. r[j] = (ix1 + ix2 * RM2) * RM1;
  46. return temp;
  47. }