2017-12-09 12:23:18 -05:00
|
|
|
//
|
|
|
|
// FILE: averageAngle.ino
|
|
|
|
// AUTHOR: Rob Tillaart
|
2021-10-18 15:44:20 -04:00
|
|
|
// VERSION: 0.1.1
|
|
|
|
// DATE: 2017-11-21
|
|
|
|
// PURPOSE: demonstrates the usage of the AverageAngle Class
|
2017-12-09 12:23:18 -05:00
|
|
|
//
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2017-12-09 12:23:18 -05:00
|
|
|
|
|
|
|
#include "AverageAngle.h"
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2017-12-09 12:23:18 -05:00
|
|
|
void setup()
|
|
|
|
{
|
|
|
|
Serial.begin(115200);
|
|
|
|
Serial.println(__FILE__);
|
|
|
|
|
|
|
|
test0();
|
|
|
|
test1();
|
|
|
|
test2(1000);
|
|
|
|
test3(1000);
|
2021-01-29 06:31:58 -05:00
|
|
|
test4();
|
|
|
|
test5();
|
|
|
|
test6();
|
|
|
|
test7();
|
2017-12-09 12:23:18 -05:00
|
|
|
}
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2017-12-09 12:23:18 -05:00
|
|
|
void loop()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2017-12-09 12:23:18 -05:00
|
|
|
void test0()
|
|
|
|
{
|
|
|
|
AverageAngle AA(AverageAngle::DEGREES);
|
|
|
|
|
|
|
|
AA.reset();
|
|
|
|
AA.add(10);
|
|
|
|
int cnt = AA.count();
|
|
|
|
float avg = AA.getAverage();
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("COUNT:\t");
|
|
|
|
Serial.println(cnt);
|
|
|
|
Serial.print("AVG:\t");
|
|
|
|
Serial.println(avg, 6);
|
|
|
|
Serial.println("EXPECT:\t10");
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2017-12-09 12:23:18 -05:00
|
|
|
void test1()
|
|
|
|
{
|
|
|
|
AverageAngle AA(AverageAngle::DEGREES);
|
|
|
|
|
|
|
|
AA.reset();
|
|
|
|
for (int i = 0; i < 10; i++)
|
|
|
|
{
|
|
|
|
AA.add(i);
|
|
|
|
}
|
|
|
|
int cnt = AA.count();
|
|
|
|
float avg = AA.getAverage();
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("COUNT:\t");
|
|
|
|
Serial.println(cnt);
|
|
|
|
Serial.print("AVG:\t");
|
|
|
|
Serial.println(avg, 6);
|
|
|
|
Serial.println("EXPECT:\t4.5");
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2017-12-09 12:23:18 -05:00
|
|
|
void test2(int count)
|
|
|
|
{
|
|
|
|
AverageAngle AA(AverageAngle::DEGREES);
|
|
|
|
|
|
|
|
AA.reset();
|
|
|
|
for (int i = 0; i < count; i++)
|
|
|
|
{
|
|
|
|
AA.add(random(180));
|
|
|
|
}
|
|
|
|
int cnt = AA.count();
|
|
|
|
float avg = AA.getAverage();
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("COUNT:\t");
|
|
|
|
Serial.println(cnt);
|
|
|
|
Serial.print("AVG:\t");
|
|
|
|
Serial.println(avg, 6);
|
|
|
|
Serial.println("EXPECT:\t~90");
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2017-12-09 12:23:18 -05:00
|
|
|
void test3(int count)
|
|
|
|
{
|
|
|
|
AverageAngle AA(AverageAngle::RADIANS);
|
|
|
|
|
|
|
|
AA.reset();
|
|
|
|
for (int i = 0; i < count; i++)
|
|
|
|
{
|
|
|
|
AA.add( PI / 180 * random(180));
|
|
|
|
}
|
|
|
|
int cnt = AA.count();
|
|
|
|
float avg = AA.getAverage();
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("COUNT:\t");
|
|
|
|
Serial.println(cnt);
|
|
|
|
Serial.print("AVG:\t");
|
|
|
|
Serial.println(avg, 6);
|
|
|
|
Serial.println("EXPECT:\t~PI/2");
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2021-01-29 06:31:58 -05:00
|
|
|
void test4()
|
2017-12-09 12:23:18 -05:00
|
|
|
{
|
|
|
|
AverageAngle AA(AverageAngle::DEGREES);
|
|
|
|
|
|
|
|
AA.reset();
|
|
|
|
|
|
|
|
AA.add(358);
|
|
|
|
AA.add(359);
|
|
|
|
AA.add(0);
|
|
|
|
AA.add(1);
|
|
|
|
AA.add(2);
|
|
|
|
|
|
|
|
int cnt = AA.count();
|
|
|
|
float avg = AA.getAverage();
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("COUNT:\t");
|
|
|
|
Serial.println(cnt);
|
|
|
|
Serial.print("AVG:\t");
|
|
|
|
Serial.println(avg, 6);
|
|
|
|
Serial.println("EXPECT:\t~0");
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2021-01-29 06:31:58 -05:00
|
|
|
void test5()
|
2017-12-09 12:23:18 -05:00
|
|
|
{
|
|
|
|
AverageAngle AA(AverageAngle::DEGREES);
|
|
|
|
|
|
|
|
AA.reset();
|
|
|
|
|
|
|
|
AA.add(357);
|
|
|
|
AA.add(358);
|
|
|
|
AA.add(359);
|
|
|
|
AA.add(360);
|
|
|
|
AA.add(1);
|
|
|
|
|
|
|
|
int cnt = AA.count();
|
|
|
|
float avg = AA.getAverage();
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("COUNT:\t");
|
|
|
|
Serial.println(cnt);
|
|
|
|
Serial.print("AVG:\t");
|
|
|
|
Serial.println(avg, 6);
|
|
|
|
Serial.println("EXPECT:\t~359");
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2021-01-29 06:31:58 -05:00
|
|
|
void test6()
|
2017-12-09 12:23:18 -05:00
|
|
|
{
|
|
|
|
AverageAngle AA(AverageAngle::DEGREES);
|
|
|
|
|
|
|
|
AA.reset();
|
|
|
|
|
|
|
|
AA.add(359);
|
|
|
|
AA.add(360);
|
|
|
|
AA.add(361);
|
|
|
|
AA.add(362);
|
|
|
|
AA.add(363);
|
|
|
|
|
|
|
|
int cnt = AA.count();
|
|
|
|
float avg = AA.getAverage();
|
|
|
|
|
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("COUNT:\t");
|
|
|
|
Serial.println(cnt);
|
|
|
|
Serial.print("AVG:\t");
|
|
|
|
Serial.println(avg, 6);
|
|
|
|
Serial.println("EXPECT:\t~1");
|
|
|
|
Serial.println();
|
|
|
|
}
|
|
|
|
|
2021-10-18 15:44:20 -04:00
|
|
|
|
2021-01-29 06:31:58 -05:00
|
|
|
void test7()
|
2017-12-09 12:23:18 -05:00
|
|
|
{
|
|
|
|
AverageAngle AA(AverageAngle::DEGREES);
|
|
|
|
AverageAngle BB(AverageAngle::RADIANS);
|
2021-10-18 15:44:20 -04:00
|
|
|
AverageAngle CC(AverageAngle::GRADIANS);
|
|
|
|
|
2017-12-09 12:23:18 -05:00
|
|
|
Serial.println(__FUNCTION__);
|
|
|
|
Serial.print("AA:\t");
|
|
|
|
Serial.println(AA.type());
|
|
|
|
Serial.print("BB:\t");
|
|
|
|
Serial.println(BB.type());
|
2021-10-18 15:44:20 -04:00
|
|
|
Serial.println("CC:\t");
|
|
|
|
Serial.println(CC.type());
|
|
|
|
Serial.println("EXPECT:\tAA=0 BB=1 CC=2");
|
2017-12-09 12:23:18 -05:00
|
|
|
Serial.println();
|
|
|
|
}
|
2021-01-29 06:31:58 -05:00
|
|
|
|
|
|
|
// -- END OF FILE --
|