5 |
|
#include "simError.h" |
6 |
|
|
7 |
|
|
8 |
< |
randomSPRNG::randomSPRNG(){ |
8 |
> |
/* randomStreamSPRNF creates a new SPRNG stream for random numbers |
9 |
> |
*/ |
10 |
|
|
11 |
+ |
int ranStreamSPRNG::nSPRNGStreams; |
12 |
|
|
13 |
+ |
randomStreamSPRNG::randomStreamSPRNG(){ |
14 |
+ |
#ifdef IS_MPI |
15 |
|
|
16 |
+ |
|
17 |
+ |
|
18 |
+ |
#else |
19 |
+ |
nSPRNGStreams++; |
20 |
+ |
|
21 |
+ |
myStreamNumber = nSPRNGStreams; |
22 |
+ |
|
23 |
+ |
thisStream = init_sprng(GTYPE,streamnum,nstreams,SEED,SPRNG_DEFAULT); |
24 |
+ |
|
25 |
+ |
|
26 |
+ |
#endif |
27 |
|
} |
28 |
+ |
|
29 |
+ |
randomStreamSPRNG::~randomStreamSPRNG(){ |
30 |
+ |
|
31 |
+ |
free_sprng(int *thisStream); |
32 |
+ |
nSPRNGStreams--; |
33 |
+ |
|
34 |
+ |
|
35 |
+ |
} |
36 |
+ |
|
37 |
+ |
|
38 |
+ |
double getRanStreamSPRNG(){ |
39 |
+ |
double ranNum; |
40 |
+ |
nanNum = sprng(thisStream); |
41 |
+ |
return ranNum; |
42 |
+ |
} |