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 3 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.
40 static pthread_mutex_t rand_mutex
;
43 unsigned int state_ui
;
44 unsigned short state_us3
[3];
48 void seed(unsigned int s
) {
50 state_vars
.state_us3
[0] = (unsigned short) s
;
51 state_vars
.state_us3
[1] = 0;
52 state_vars
.state_us3
[2] = 0;
53 state_vars
.state_ui
= s
;
61 return (int) nrand48(state_vars
.state_us3
) % RAND_MAX
;
63 return rand_r(&state_vars
.state_ui
);
67 pthread_mutex_lock(&rand_mutex
);
68 srand(state_vars
.state_ui
);
70 pthread_mutex_unlock(&rand_mutex
);
72 state_vars
.state_ui
= (unsigned int) result
;