2021-01-29 12:31:58 +01:00
|
|
|
//
|
|
|
|
// FILE: randomHelpers_test.ino
|
|
|
|
// AUTHOR: Rob Tillaart
|
|
|
|
// PURPOSE: demo
|
2021-11-15 17:10:01 +01:00
|
|
|
// DATE: 2020-07-01
|
2021-01-29 12:31:58 +01:00
|
|
|
// URL: https://github.com/RobTillaart/randomHelpers
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
#include "randomHelpers.h"
|
|
|
|
|
|
|
|
uint32_t start, stop, duration1, duration2;
|
|
|
|
|
|
|
|
volatile uint32_t x;
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void setup()
|
|
|
|
{
|
|
|
|
Serial.begin(115200);
|
|
|
|
Serial.println(__FILE__);
|
|
|
|
|
|
|
|
test_getRandom1();
|
|
|
|
test_getRandom6();
|
|
|
|
test_getRandom8();
|
|
|
|
test_getRandom16();
|
|
|
|
test_getRandom24();
|
|
|
|
test_getRandom32();
|
|
|
|
test_throwDice();
|
|
|
|
}
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void loop()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void test_getRandom1()
|
|
|
|
{
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = random(2);
|
|
|
|
}
|
|
|
|
duration1 = micros() - start;
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = getRandom1();
|
|
|
|
}
|
|
|
|
duration2 = micros() - start;
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("TIME 1:\t");
|
|
|
|
Serial.print(duration1);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("TIME 2:\t");
|
|
|
|
Serial.print(duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("RATIO :\t");
|
|
|
|
Serial.print((1.0 * duration1) / duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.println();
|
|
|
|
delay(10);
|
|
|
|
}
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void test_getRandom6()
|
|
|
|
{
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = random(32);
|
|
|
|
}
|
|
|
|
duration1 = micros() - start;
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = getRandom6();
|
|
|
|
}
|
|
|
|
duration2 = micros() - start;
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("TIME 1:\t");
|
|
|
|
Serial.print(duration1);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("TIME 2:\t");
|
|
|
|
Serial.print(duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("RATIO :\t");
|
|
|
|
Serial.print((1.0 * duration1) / duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.println();
|
|
|
|
delay(10);
|
|
|
|
}
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void test_getRandom8()
|
|
|
|
{
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = random(256);
|
|
|
|
}
|
|
|
|
duration1 = micros() - start;
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = getRandom8();
|
|
|
|
}
|
|
|
|
duration2 = micros() - start;
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("TIME 1:\t");
|
|
|
|
Serial.print(duration1);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("TIME 2:\t");
|
|
|
|
Serial.print(duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("RATIO :\t");
|
|
|
|
Serial.print((1.0 * duration1) / duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.println();
|
|
|
|
delay(10);
|
|
|
|
}
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void test_getRandom16()
|
|
|
|
{
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = random(65536);
|
|
|
|
}
|
|
|
|
duration1 = micros() - start;
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = getRandom16();
|
|
|
|
}
|
|
|
|
duration2 = micros() - start;
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("TIME 1:\t");
|
|
|
|
Serial.print(duration1);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("TIME 2:\t");
|
|
|
|
Serial.print(duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("RATIO :\t");
|
|
|
|
Serial.print((1.0 * duration1) / duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.println();
|
|
|
|
delay(10);
|
|
|
|
}
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void test_getRandom24()
|
|
|
|
{
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = random(16777216);
|
|
|
|
}
|
|
|
|
duration1 = micros() - start;
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = getRandom24();
|
|
|
|
}
|
|
|
|
duration2 = micros() - start;
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("TIME 1:\t");
|
|
|
|
Serial.print(duration1);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("TIME 2:\t");
|
|
|
|
Serial.print(duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("RATIO :\t");
|
|
|
|
Serial.print((1.0 * duration1) / duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.println();
|
|
|
|
delay(10);
|
|
|
|
}
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void test_getRandom32()
|
|
|
|
{
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = random(0xFFFFFFFF);
|
|
|
|
}
|
|
|
|
duration1 = micros() - start;
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = getRandom32();
|
|
|
|
}
|
|
|
|
duration2 = micros() - start;
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("TIME 1:\t");
|
|
|
|
Serial.print(duration1);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("TIME 2:\t");
|
|
|
|
Serial.print(duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("RATIO :\t");
|
|
|
|
Serial.print((1.0 * duration1) / duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.println();
|
|
|
|
delay(10);
|
|
|
|
}
|
2021-11-15 17:10:01 +01:00
|
|
|
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void test_throwDice()
|
|
|
|
{
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = random(6) + 1;
|
|
|
|
}
|
|
|
|
duration1 = micros() - start;
|
|
|
|
start = micros();
|
|
|
|
for (int i = 0; i < 10000; i++)
|
|
|
|
{
|
|
|
|
x = throwDice();
|
|
|
|
}
|
|
|
|
duration2 = micros() - start;
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("TIME 1:\t");
|
|
|
|
Serial.print(duration1);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("TIME 2:\t");
|
|
|
|
Serial.print(duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.print("RATIO :\t");
|
|
|
|
Serial.print((1.0 * duration1) / duration2);
|
|
|
|
Serial.println();
|
|
|
|
Serial.println();
|
|
|
|
delay(10);
|
|
|
|
}
|
|
|
|
|
2021-11-15 17:10:01 +01:00
|
|
|
|
|
|
|
// -- END OF FILE --
|
|
|
|
|