GY-63_MS5611/libraries/Kelvin2RGB/examples/Kelvin2RGB_timing/Kelvin2RGB_timing.ino
2021-12-20 17:09:35 +01:00

70 lines
1.1 KiB
C++

//
// FILE: Kelvin2RGB_timing.ino
// AUTHOR: Rob Tillaart
// PURPOSE: demo - shows timing 2 methods
// DATE: 2020-07-29
// URL: https://github.com/RobTillaart/Kelvin2RGB
#include "Kelvin2RGB.h"
Kelvin2RGB KRGB;
uint32_t start, stop, duration1, duration2;
void setup()
{
Serial.begin(115200);
Serial.println(__FILE__);
KRGB.begin();
test_timing();
Serial.println("\ndone...");
}
void loop()
{
}
void test_timing()
{
Serial.println(__FUNCTION__);
Serial.println();
// volatile to minimize optimization
volatile float bright = 100.0;
volatile float temp = 6500.0;
start = micros();
for (int i = 0; i < 1000; i++)
{
KRGB.convert_TH(temp, bright);
}
stop = micros();
duration1 = stop - start;
start = micros();
for (int i = 0; i < 1000; i++)
{
KRGB.convert_NB(temp, bright);
}
stop = micros();
duration2 = stop - start;
Serial.print("TH:\t");
Serial.println(duration1 * 0.001);
Serial.print("NB:\t");
Serial.println(duration2 * 0.001);
Serial.print("ratio:\t");
Serial.println(1.0 * duration1 / duration2, 4);
}
// -- END OF FILE --