97 lines
2.3 KiB
C
97 lines
2.3 KiB
C
|
/****************************************************************
|
||
|
* *
|
||
|
* Copyright 2001, 2007 Fidelity Information Services, Inc *
|
||
|
* *
|
||
|
* This source code contains the intellectual property *
|
||
|
* of its copyright holder(s), and is made available *
|
||
|
* under a license. If you do not know the terms of *
|
||
|
* the license, please stop and do not read further. *
|
||
|
* *
|
||
|
****************************************************************/
|
||
|
|
||
|
#include "mdef.h"
|
||
|
|
||
|
#include "gtm_string.h"
|
||
|
#include "gtm_stdio.h"
|
||
|
#include "gtm_time.h"
|
||
|
|
||
|
#include <stdlib.h>
|
||
|
|
||
|
#include "random.h"
|
||
|
|
||
|
#define MAXNUM 2147483561L
|
||
|
#define MAX_RND_IDX 99
|
||
|
#define MAX_SEED_LEN 85
|
||
|
|
||
|
/* "global" random table -- must be visible to get_rand_from_table and
|
||
|
init_rand_table */
|
||
|
static int rannum_table[MAX_RND_IDX+1];
|
||
|
|
||
|
int get_rand_from_table (void)
|
||
|
{
|
||
|
int ini_index = rannum_table[MAX_RND_IDX - 1]%MAX_RND_IDX;
|
||
|
int fin_index = rannum_table[MAX_RND_IDX]%MAX_RND_IDX;
|
||
|
|
||
|
int temp_val1, temp_val2;
|
||
|
|
||
|
if ((temp_val2 = rannum_table[ini_index] - rannum_table[fin_index]) < 0) temp_val2 += 1000000000;
|
||
|
|
||
|
rannum_table[ini_index] = temp_val2;
|
||
|
|
||
|
rannum_table[MAX_RND_IDX - 1]--;
|
||
|
rannum_table[MAX_RND_IDX]--;
|
||
|
|
||
|
if (rannum_table[MAX_RND_IDX - 1] == 0) rannum_table[MAX_RND_IDX - 1] = 55;
|
||
|
|
||
|
if (rannum_table[MAX_RND_IDX] == 0) rannum_table[MAX_RND_IDX] = 55;
|
||
|
|
||
|
temp_val1 = rannum_table[MAX_RND_IDX]%42 + 56;
|
||
|
rannum_table[MAX_RND_IDX] = rannum_table[temp_val1];
|
||
|
|
||
|
rannum_table[temp_val1] = temp_val2;
|
||
|
|
||
|
return(rannum_table[MAX_RND_IDX]);
|
||
|
}
|
||
|
|
||
|
|
||
|
int init_rand_table (void)
|
||
|
{
|
||
|
char buf[MAX_RND_IDX+2];
|
||
|
char c_seed[MAX_SEED_LEN+1];
|
||
|
int i_seed, seed_len;
|
||
|
int i, j, k;
|
||
|
|
||
|
i_seed = (int) time(NULL);
|
||
|
SPRINTF(c_seed,"%d",i_seed);
|
||
|
seed_len = STRLEN(c_seed);
|
||
|
|
||
|
if (seed_len > MAX_SEED_LEN)
|
||
|
return(0);
|
||
|
|
||
|
SPRINTF(buf, "%s aEbFcGdHeI", c_seed);
|
||
|
|
||
|
for (i = 1; i < MAX_RND_IDX; i++)
|
||
|
rannum_table[i] = buf[i%seed_len] * 8171717 + i * 997;
|
||
|
|
||
|
i = 97; j = 12;
|
||
|
|
||
|
for (k = 1; k < MAX_RND_IDX; k++)
|
||
|
{
|
||
|
rannum_table[i] -= rannum_table[j];
|
||
|
if (rannum_table[i] < 0)
|
||
|
rannum_table[i] = -rannum_table[i];
|
||
|
|
||
|
i--; j--;
|
||
|
if (i == 0)
|
||
|
i=97;
|
||
|
if (j == 0)
|
||
|
j=97;
|
||
|
}
|
||
|
|
||
|
rannum_table[MAX_RND_IDX - 2] = 55;
|
||
|
rannum_table[MAX_RND_IDX - 1] = 24;
|
||
|
rannum_table[MAX_RND_IDX] = 77;
|
||
|
|
||
|
return 1; /* No error. This is added to make compiler happy */
|
||
|
}
|