95 lines
1.8 KiB
C
Raw Normal View History

2021-01-29 12:31:58 +01:00
#pragma once
//
// FILE: randomHelpers.h
2022-04-15 20:51:51 +02:00
// AUTHOR: Rob Tillaart
2023-02-26 13:36:39 +01:00
// VERSION: 0.2.6
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"
2023-02-26 13:36:39 +01:00
#define RANDOM_HELPERS_VERSION (F("0.2.6"))
2021-12-27 20:38:20 +01:00
2021-01-29 12:31:58 +01:00
2022-11-23 13:56:17 +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
// bits any more it fills the buffer first. This way the relative expensive
// calls to random() which produces a 32 bit number are minimized in an
// efficient way.
2021-01-29 12:31:58 +01:00
//
2022-11-23 13:56:17 +01:00
// TBD: put it in a class ?
2021-01-29 12:31:58 +01:00
///////////////////////////////////////////////////////////////////////////
//
2022-11-23 13:56:17 +01:00
// 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.
2021-01-29 12:31:58 +01:00
//
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
bool getRandom1();
2021-01-29 12:31:58 +01:00
2023-02-26 13:36:39 +01:00
uint8_t getRandom2();
uint8_t getRandom3();
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
2023-02-26 13:36:39 +01:00
uint8_t getRandom7();
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
2023-02-26 13:36:39 +01:00
uint32_t getRandom32();
2022-04-15 20:51:51 +02:00
uint64_t getRandom64();
2021-01-29 12:31:58 +01:00
2023-02-26 13:36:39 +01:00
/////////////////////////////////////////////////
//
// TYPICAL USES
//
bool inline flipCoin(); // 0..1
uint8_t throwDice(); // 1..6
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
2023-02-26 13:36:39 +01:00
// -- END OF FILE --
2021-11-15 17:10:01 +01:00