2021-12-28 15:37:03 +01:00

100 lines
1.9 KiB
C++

//
// FILE: permutations.ino
// AUTHOR: Rob Tillaart
// PURPOSE: demo
// DATE: 2020-07-02
// URL: https://github.com/RobTillaart/statHelpers
#include "statHelpers.h"
#include "printHelpers.h"
uint32_t start, duration1, duration2;
volatile uint32_t x;
void setup()
{
Serial.begin(115200);
Serial.println(__FILE__);
Serial.println("permutations(n, k)");
delay(10);
start = micros();
for (int n = 0; n < 13; n++)
{
for (int k = 0; k <= n; k++)
{
// x = permutations(n, k);
Serial.print(n);
Serial.print('\t');
Serial.print(k);
Serial.print('\t');
Serial.print(permutations(n, k));
Serial.println();
}
Serial.println();
}
duration1 = micros() - start;
Serial.println(duration1);
Serial.println();
///////////////////////////////////////////
Serial.println("permutations64(n, k)");
start = micros();
for (int n = 0; n < 20; n++)
{
for (int k = 0; k <= n; k++)
{
// x = permutations64(n, k);
Serial.print(n);
Serial.print('\t');
Serial.print(k);
Serial.print('\t');
Serial.print(print64(permutations64(n, k)));
Serial.println();
}
Serial.println();
}
duration1 = micros() - start;
Serial.println(duration1);
Serial.println();
///////////////////////////////////////////
Serial.println("dpermutations(n, k) - double can be 4 or 8 bit.");
start = micros();
int nmax = 34;
if (sizeof(double) == 8) nmax = 170;
for (int n = 0; n <= nmax; n++)
{
for (int k = 0; k <= n; k++)
{
// x = dpermutations(n, k);
Serial.print(n);
Serial.print('\t');
Serial.print(k);
Serial.print('\t');
Serial.print(sci(dpermutations(n, k), 15));
Serial.println();
}
Serial.println();
}
duration1 = micros() - start;
Serial.println(duration1);
Serial.println();
Serial.println("\nDone...");
}
void loop()
{
}
// -- END OF FILE --