74 lines
1.9 KiB
C
Raw Normal View History

2020-05-17 10:40:08 +02:00
#pragma once
//
// FILE: Prandom.h
// AUTHOR: Rob dot Tillaart at gmail dot com
2022-11-22 14:03:23 +01:00
// VERSION: 0.1.5
2020-05-17 10:40:08 +02:00
// PURPOSE: Arduino library for random numbers with Python Random interface
2020-11-27 11:28:57 +01:00
// The underlying pseudo-random number generator is a
2020-05-17 10:40:08 +02:00
// Multiply-with-carry method invented by George Marsaglia.
2020-11-27 11:28:57 +01:00
// URL: https://github.com/RobTillaart/Prandom
2020-05-17 10:40:08 +02:00
// https://docs.python.org/3/library/random.html
// https://www.pcg-random.org/
2021-12-23 20:43:00 +01:00
2020-05-17 10:40:08 +02:00
#include "Arduino.h"
2022-11-22 14:03:23 +01:00
#define PRANDOM_LIB_VERSION (F("0.1.5"))
2021-12-23 20:43:00 +01:00
2020-05-17 10:40:08 +02:00
class Prandom
{
public:
2020-11-27 11:28:57 +01:00
Prandom();
Prandom(uint32_t s);
2020-05-17 10:40:08 +02:00
2020-11-27 11:28:57 +01:00
void seed();
2022-11-22 14:03:23 +01:00
void seed(uint32_t s, uint32_t t = 2); // Marsaglia need 2 seeds, but 1 will work too
2021-12-23 20:43:00 +01:00
2020-05-17 10:40:08 +02:00
2022-11-22 14:03:23 +01:00
// integer methods
2020-11-27 11:28:57 +01:00
//
uint32_t getrandbits(uint8_t n);
uint32_t randrange(uint32_t stop);
uint32_t randrange(uint32_t start, uint32_t stop, uint32_t step = 1);
2022-11-22 14:03:23 +01:00
// randint is inclusive end value
2020-11-27 11:28:57 +01:00
uint32_t randint(uint32_t start, uint32_t stop) { return randrange(start, stop + 1); };
2020-05-17 10:40:08 +02:00
2021-12-23 20:43:00 +01:00
2022-11-22 14:03:23 +01:00
// real distributions
2020-11-27 11:28:57 +01:00
//
float random(const float top = 1.0);
float uniform(float lo, float hi);
float triangular(float lo = 0, float hi = 1.0, float mid = 0.5);
float normalvariate(float mu = 0, float sigma = 1.0);
float lognormvariate(float mu = 0, float sigma = 1.0);
float gauss(float mu = 0, float sigma = 1.0);
float expovariate(float lambda);
float gammavariate(float alpha, float beta);
float betavariate(float alpha, float beta);
float paretovariate(float alpha);
float weibullvariate(float alpha, float beta);
2021-12-23 20:43:00 +01:00
2022-11-22 14:03:23 +01:00
// Circular distributions
2020-11-27 11:28:57 +01:00
//
2022-11-22 14:03:23 +01:00
// mu is mean angle in radians
// kappa is concentration parameter, 0 -> uniform.
2020-11-27 11:28:57 +01:00
float vonmisesvariate(float mu, float kappa = 0);
2020-05-17 10:40:08 +02:00
2021-12-23 20:43:00 +01:00
2020-05-17 10:40:08 +02:00
private:
uint32_t _rndTime();
uint32_t _rnd(uint32_t n);
2022-11-22 14:03:23 +01:00
// Marsaglia 'constants'
2020-05-17 10:40:08 +02:00
uint32_t _m_w = 1;
2020-11-27 11:28:57 +01:00
uint32_t _m_z = 2;
2020-05-17 10:40:08 +02:00
uint32_t __random();
};
2021-12-23 20:43:00 +01:00
2020-05-17 10:40:08 +02:00
// -- END OF FILE --
2021-12-23 20:43:00 +01:00