2021-01-29 12:31:58 +01:00
|
|
|
#pragma once
|
|
|
|
//
|
|
|
|
// FILE: randomHelpers.h
|
2022-04-15 20:51:51 +02:00
|
|
|
// AUTHOR: Rob Tillaart
|
|
|
|
// VERSION: 0.2.4
|
2021-01-29 12:31:58 +01:00
|
|
|
// PURPOSE: Arduino library with helper function for faster random bits
|
|
|
|
// URL: https://github.com/RobTillaart/randomHelpers
|
|
|
|
|
|
|
|
|
|
|
|
#include "Arduino.h"
|
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
#define RANDOM_HELPERS_VERSION (F("0.2.4"))
|
2021-12-27 20:38:20 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
// the idea is to have one buffer ( __randomBuffer) which holds 32 random bits.
|
|
|
|
// Every call fetches bits from that buffer and if it does not hold enough
|
2021-11-15 17:10:01 +01:00
|
|
|
// bits any more it fills the buffer first. This way the relative expensive
|
2021-01-29 12:31:58 +01:00
|
|
|
// calls to random() which produces a 32 bit number are minimized in an
|
2021-11-15 17:10:01 +01:00
|
|
|
// efficient way.
|
2021-01-29 12:31:58 +01:00
|
|
|
//
|
|
|
|
// TBD: put it in a class ?
|
|
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// An example of a simple pseudo-random number generator is the
|
|
|
|
// Multiply-with-carry method invented by George Marsaglia.
|
|
|
|
// it has two initializers (not zero) which can be changed
|
|
|
|
// to seed the generator.
|
|
|
|
//
|
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
uint32_t Marsaglia();
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
bool seedMarsaglia(uint32_t a, uint32_t b);
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
uint32_t getRandom32();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
bool getRandom1();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
// typical use
|
2022-04-15 20:51:51 +02:00
|
|
|
bool inline flipCoin();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
uint8_t getRandom4();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
uint8_t getRandom5();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
uint8_t getRandom6();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
// typical use
|
2022-04-15 20:51:51 +02:00
|
|
|
uint8_t throwDice();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
uint8_t getRandom8();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
uint16_t getRandom16();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
uint32_t getRandom24();
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2022-04-15 20:51:51 +02:00
|
|
|
uint64_t getRandom64();
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
/*
|
|
|
|
// works well for 1..16; but above it is worse
|
|
|
|
uint32_t getRandomBits(uint8_t n)
|
|
|
|
{
|
|
|
|
if (__randomIdx < n)
|
|
|
|
{
|
|
|
|
__randomBuffer = getRandom32();
|
|
|
|
__randomIdx = 32;
|
|
|
|
}
|
|
|
|
uint32_t rv = __randomBuffer & ((1UL << n) - 1);
|
|
|
|
__randomBuffer >>= n;
|
|
|
|
__randomIdx -= n;
|
|
|
|
return rv;
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
// n = 1..31
|
|
|
|
// TODO: performance gain too low for n > 16
|
2022-04-15 20:51:51 +02:00
|
|
|
uint32_t getRandomBits(uint8_t n);
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
// -- END OF FILE --
|
2021-11-15 17:10:01 +01:00
|
|
|
|