MinGW下编译libpmk,仍旧发现缺这个库...
文章主要参考http://blog.csdn.net/jimmyblind/article/details/5550042
srand48和drand48是Unix库函数,drand48的作用是产生[0,1]之间均匀分布的随机数,采用了线性同余法和48位整数运算来产生伪随机序列
其中
函数用上面的算法产生一个48位的伪随机整数,然后再取出此整数的高32位作为随机数,然后将这个32位的伪随机数规划到[0,1]之间,用函数srand48来初始化drand48(),其只对于48位整数的高32位进行初始化,而其低16位被设定为随机值。
1: #define MNWZ 0x100000000
2: #define ANWZ 0x5DEECE66D
3: #define CNWZ 0xB16
4: #define INFINITY 0xFFFFFFFFF
5:
6: int labelsize;
7: int dim;
8:
9: static unsigned long long seed = 1;
10:
11: double drand48(void)
12: {
13: seed = (ANWZ * seed + CNWZ) & 0xFFFFFFFFFFFFLL;
14: unsigned int x = seed >> 16;
15: return ((double)x / (double)MNWZ);
16: }
17:
18: //static unsigned long long seed = 1;
19:
20: void srand48(unsigned int i)
21: {
22: seed = (((long long int)i) << 16) | rand();
23: }