2 * random.c - functions to get random values
14 /* global and extern variables */
17 extern u32 *rand_buf,*rand_current;
18 extern char random_file[MAX_CHARS_RANDOM_FILE];
20 /* return random integer between 0 - max-1 */
23 if(rand_current>=rand_buf+(RAND_BUF_SIZE/sizeof(u32)))
25 printfd("debug: reading new random bytes\n");
26 if(read(random_fd,rand_buf,RAND_BUF_SIZE)!=RAND_BUF_SIZE)
28 if(!strcmp(random_file,""))
30 puts("random file end, starting over ...");
31 lseek(random_fd,0,SEEK_SET);
34 puts("failed reading 1 mega bytes of random data");
38 printfd("debug: finished reading random bytes\n");
39 rand_current=rand_buf;
41 /* cells numbered 0...max-1 */
42 return((u32)(*(rand_current++)*(max*1.0/URAND_MAX)));
45 /* get z value (linear growth of probability with depths) */
46 u32 rand_get_lgp(int slope,int start,u32 z_max)
50 weighted_sum_z=z_max*start+slope*gr;
51 z=rand_get(weighted_sum_z)+1; /* +1 as rand_get returns values 0...max-1 */
57 return(i-1); /* return values 0...z_cell-1 */