summaryrefslogtreecommitdiff
path: root/g_src/random.h
blob: a160db9b635f29a00907bd9286a811eed40a3b52 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#ifndef RANDOM_H
#define RANDOM_H

#ifndef WIN32
#include <stdint.h>
#endif //WIN32

#define MT_BUFFER_NUM 10
#define MT_LEN 624


void mt_init();
uint32_t mt_trandom();
static int32_t trandom(uint32_t max=2147483647LU)
	{
	if(max<=1)return 0;
	uint32_t seed=mt_trandom();
	seed=seed%2147483647LU;
	seed=seed/((2147483647LU/max)+1);

	return((int32_t)seed);
	}
static int32_t loadtrandom(uint32_t max=2147483647LU)
	{
	uint32_t seed=mt_trandom();
	seed=seed%max;

	return((int32_t)seed);
	}
void push_trandom_uniform_seed(uint32_t newseed);
void push_trandom_double_seed(uint32_t newseed1,uint32_t newseed2);
void push_trandom_triple_seed(uint32_t newseed1,uint32_t newseed2,uint32_t newseed3);
void pop_trandom_uniform_seed();
void trandom_twist();

void r_num();
int32_t basic_random(int32_t max=2147483647);


#endif