Continue transition to using removal checks for alignment reliability.
[Ale.git] / rand.h
blob5ca9acbd2521acb3ef1efce8a9aff5c31c11ae2b
1 // Copyright 2006 David Hilvert <dhilvert@auricle.dyndns.org>,
2 // <dhilvert@ugcs.caltech.edu>
3 // <dhilvert@gmail.com>
5 /* This file is part of the Anti-Lamenessing Engine.
7 The Anti-Lamenessing Engine is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2 of the License, or
10 (at your option) any later version.
12 The Anti-Lamenessing Engine is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with the Anti-Lamenessing Engine; if not, write to the Free Software
19 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
23 * rand.h: random number generator class.
26 #ifndef __rand_h__
27 #define __rand_h__
29 #include <assert.h>
30 #include <stdio.h>
31 #include <string.h>
32 #include <stdlib.h>
34 #ifdef USE_PTHREAD
35 #include <pthread.h>
36 #endif
38 class rng_t {
39 #ifdef USE_PTHREAD
40 static pthread_mutex_t rand_mutex;
41 #endif
42 union {
43 unsigned int state_ui;
44 unsigned short state_us3[3];
45 } state_vars;
46 public:
48 void seed(unsigned int s) {
49 #ifdef USE_PTHREAD
50 state_vars.state_us3[0] = (unsigned short) s;
51 state_vars.state_ui = s;
52 #else
53 srand(s);
54 #endif
56 int get() {
57 #ifdef USE_PTHREAD
58 #if HAVE_NRAND48
59 return (int) nrand48(state_vars.state_us3) % RAND_MAX;
60 #elif HAVE_RAND_R
61 return rand_r(&state_vars.state_ui);
62 #else
63 int result;
65 pthread_mutex_lock(&rand_mutex);
66 srand(state_vars.state_ui);
67 result = rand();
68 pthread_mutex_unlock(&rand_mutex);
70 state_vars.state_ui = (unsigned int) result;
72 return result;
73 #endif
74 #else
75 return rand();
76 #endif
80 #endif