GY-63_MS5611/libraries/AverageAngle/examples/AverageAngle1/AverageAngle1.ino

212 lines
3.4 KiB
Arduino
Raw Normal View History

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 --