]> git.mxchange.org Git - flightgear.git/blob - Math/fg_random.c
Integrated new event manager with subsystem initializations.
[flightgear.git] / Math / fg_random.c
1 /**************************************************************************
2  * fg_random.c -- routines to handle random number generation
3  *
4  * Written by Curtis Olson, started July 1997.
5  *
6  * Copyright (C) 1997  Curtis L. Olson  - curt@infoplane.com
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License as
10  * published by the Free Software Foundation; either version 2 of the
11  * License, or (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful, but
14  * WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21  *
22  * $Id$
23  * (Log is kept at end of this file)
24  **************************************************************************/
25
26
27 #include <stdio.h>
28 #include <stdlib.h>         /* for random(), srandom() */
29 #include <time.h>           /* for time() to seed srandom() */        
30
31 #include "fg_random.h"
32
33 #ifndef USE_RAND
34 #  ifdef sgi
35 #    undef RAND_MAX
36 #    define RAND_MAX 2147483647
37 #  endif
38 #endif
39
40
41 /* Seed the random number generater with time() so we don't see the
42  * same sequence every time */
43 void fg_srandom(void) {
44     printf("Seeding random number generater\n");
45
46 #ifdef USE_RAND
47     srand(time(NULL));
48 #else
49     srandom(time(NULL));
50 #endif                                       
51 }
52
53
54 /* return a random number between [0.0, 1.0) */
55 double fg_random(void) {
56 #ifdef USE_RAND
57     return(rand() / (double)RAND_MAX);
58 #else
59     return(random() / (double)RAND_MAX);
60 #endif
61 }
62
63
64 /* $Log$
65 /* Revision 1.2  1997/12/30 20:47:48  curt
66 /* Integrated new event manager with subsystem initializations.
67 /*
68  * Revision 1.1  1997/07/30 16:04:09  curt
69  * Moved random routines from Utils/ to Math/
70  *
71  * Revision 1.1  1997/07/19 22:31:57  curt
72  * Initial revision.
73  *
74  */