random_number.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. /*
  2. Copyright (C) 2004 Michael Liebscher
  3. This program is free software; you can redistribute it and/or
  4. modify it under the terms of the GNU General Public License
  5. as published by the Free Software Foundation; either version 2
  6. of the License, or (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU General Public License for more details.
  11. You should have received a copy of the GNU General Public License
  12. along with this program; if not, write to the Free Software
  13. Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  14. */
  15. /*
  16. * random_number.c: Wolfenstein3-D random number generator.
  17. *
  18. * Author: Michael Liebscher <johnnycanuck@users.sourceforge.net>
  19. * Date: 2004
  20. *
  21. * Acknowledgement:
  22. * This code was derived from Wolfenstein3-D, and was originally
  23. * written by Id Software, Inc.
  24. *
  25. */
  26. #include "../wolfiphone.h"
  27. /* This is just John Carmack's table driven pseudo-random number generator */
  28. W32 rndtable[] = {
  29. 0, 8, 109, 220, 222, 241, 149, 107, 75, 248, 254, 140, 16, 66,
  30. 74, 21, 211, 47, 80, 242, 154, 27, 205, 128, 161, 89, 77, 36,
  31. 95, 110, 85, 48, 212, 140, 211, 249, 22, 79, 200, 50, 28, 188,
  32. 52, 140, 202, 120, 68, 145, 62, 70, 184, 190, 91, 197, 152, 224,
  33. 149, 104, 25, 178, 252, 182, 202, 182, 141, 197, 4, 81, 181, 242,
  34. 145, 42, 39, 227, 156, 198, 225, 193, 219, 93, 122, 175, 249, 0,
  35. 175, 143, 70, 239, 46, 246, 163, 53, 163, 109, 168, 135, 2, 235,
  36. 25, 92, 20, 145, 138, 77, 69, 166, 78, 176, 173, 212, 166, 113,
  37. 94, 161, 41, 50, 239, 49, 111, 164, 70, 60, 2, 37, 171, 75,
  38. 136, 156, 11, 56, 42, 146, 138, 229, 73, 146, 77, 61, 98, 196,
  39. 135, 106, 63, 197, 195, 86, 96, 203, 113, 101, 170, 247, 181, 113,
  40. 80, 250, 108, 7, 255, 237, 129, 226, 79, 107, 112, 166, 103, 241,
  41. 24, 223, 239, 120, 198, 58, 60, 82, 128, 3, 184, 66, 143, 224,
  42. 145, 224, 81, 206, 163, 45, 63, 90, 168, 114, 59, 33, 159, 95,
  43. 28, 139, 123, 98, 125, 196, 15, 70, 194, 253, 54, 14, 109, 226,
  44. 71, 17, 161, 93, 186, 87, 244, 138, 20, 52, 123, 251, 26, 36,
  45. 17, 46, 52, 231, 232, 76, 31, 221, 84, 37, 216, 165, 212, 106,
  46. 197, 242, 98, 43, 39, 175, 254, 145, 190, 84, 118, 222, 187, 136,
  47. 120, 163, 236, 249
  48. };
  49. W32 rndindex = 0;
  50. /*
  51. -----------------------------------------------------------------------------
  52. Function:
  53. Parameters:
  54. Returns:
  55. Notes:
  56. -----------------------------------------------------------------------------
  57. */
  58. PUBLIC void US_InitRndT( int randomize )
  59. {
  60. if( randomize )
  61. {
  62. rndindex = time( NULL ) & 0xFF;
  63. }
  64. else
  65. {
  66. rndindex = 0;
  67. }
  68. }
  69. /*
  70. -----------------------------------------------------------------------------
  71. Function:
  72. Parameters:
  73. Returns:
  74. Notes:
  75. -----------------------------------------------------------------------------
  76. */
  77. PUBLIC int US_RndT( void )
  78. {
  79. rndindex++;
  80. rndindex &= 0xFF;
  81. return rndtable[ rndindex ];
  82. }