123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281 |
- #define MICRIUM_SOURCE
- #define LIB_MATH_MODULE
- #include <lib_math.h>
- RAND_NBR Math_RandSeedCur;
- void Math_Init (void)
- {
- Math_RandSetSeed((RAND_NBR)RAND_SEED_INIT_VAL);
- }
- void Math_RandSetSeed (RAND_NBR seed)
- {
- CPU_SR_ALLOC();
- CPU_CRITICAL_ENTER();
- Math_RandSeedCur = seed;
- CPU_CRITICAL_EXIT();
- }
- RAND_NBR Math_Rand (void)
- {
- RAND_NBR seed;
- RAND_NBR rand_nbr;
- CPU_SR_ALLOC();
- CPU_CRITICAL_ENTER();
- seed = Math_RandSeedCur;
- rand_nbr = Math_RandSeed(seed);
- Math_RandSeedCur = rand_nbr;
- CPU_CRITICAL_EXIT();
- return (rand_nbr);
- }
- RAND_NBR Math_RandSeed (RAND_NBR seed)
- {
- RAND_NBR rand_nbr;
- rand_nbr = (((RAND_NBR)RAND_LCG_PARAM_A * seed) + (RAND_NBR)RAND_LCG_PARAM_B) % ((RAND_NBR)RAND_LCG_PARAM_M + 1u);
- return (rand_nbr);
- }
|