72 lines
1.1 KiB
Arduino
Raw Normal View History

2021-01-29 12:31:58 +01:00
//
// FILE: Kelvin2RGB_timing.ino
// AUTHOR: Rob Tillaart
2021-11-06 15:56:44 +01:00
// VERSION: 0.1.1
2021-01-29 12:31:58 +01:00
// PURPOSE: demo - shows timing 2 methods
// DATE: 2020-07-29
// URL: https://github.com/RobTillaart/Kelvin2RGB
//
#include "Kelvin2RGB.h"
Kelvin2RGB KRGB;
2021-11-06 15:56:44 +01:00
uint32_t start, stop, duration1, duration2;
2021-01-29 12:31:58 +01:00
void setup()
{
Serial.begin(115200);
Serial.println(__FILE__);
KRGB.begin();
test_timing();
2021-11-06 15:56:44 +01:00
Serial.println("\ndone...");
2021-01-29 12:31:58 +01:00
}
2021-11-06 15:56:44 +01:00
2021-01-29 12:31:58 +01:00
void loop()
{
}
2021-11-06 15:56:44 +01:00
2021-01-29 12:31:58 +01:00
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();
2021-11-06 15:56:44 +01:00
duration1 = stop - start;
2021-01-29 12:31:58 +01:00
start = micros();
for (int i = 0; i < 1000; i++)
{
KRGB.convert_NB(temp, bright);
}
stop = micros();
2021-11-06 15:56:44 +01:00
duration2 = stop - start;
2021-01-29 12:31:58 +01:00
Serial.print("TH:\t");
2021-11-06 15:56:44 +01:00
Serial.println(duration1 * 0.001);
2021-01-29 12:31:58 +01:00
Serial.print("NB:\t");
2021-11-06 15:56:44 +01:00
Serial.println(duration2 * 0.001);
2021-01-29 12:31:58 +01:00
Serial.print("ratio:\t");
2021-11-06 15:56:44 +01:00
Serial.println(1.0 * duration1 / duration2, 4);
2021-01-29 12:31:58 +01:00
}
2021-11-06 15:56:44 +01:00
2021-01-29 12:31:58 +01:00
// -- END OF FILE --
2021-11-06 15:56:44 +01:00