GY-63_MS5611/libraries/AverageAngle/AverageAngle.h
2022-12-07 20:30:13 +01:00

53 lines
1.0 KiB
C++

#pragma once
//
// FILE: AverageAngle.h
// AUTHOR: Rob Tillaart
// VERSION: 0.1.9
// DATE: 2017-11-21
// PURPOSE: class for averaging angles.
#include "math.h"
#include "Arduino.h"
#define AVERAGE_ANGLE_LIB_VERSION (F("0.1.9"))
#define GRAD_TO_RAD (PI / 200.0)
#define RAD_TO_GRAD (200.0 / PI)
class AverageAngle
{
public:
enum AngleType { DEGREES = 0, RADIANS = 1, GRADIANS = 2 };
AverageAngle(const enum AngleType type = DEGREES);
uint32_t add(float alpha, float length = 1.0);
void reset();
uint32_t count();
// if there are no angles added (count == 0) or
// if the sum == (0,0) there is a singularity ==> no angle. NAN
float getAverage();
// if count == 0 total length == 0.
float getTotalLength();
// if count == 0 average length == 0.
float getAverageLength();
AngleType type();
bool setType(AngleType type);
private:
AngleType _type;
float _sumx;
float _sumy;
uint32_t _count;
};
// -- END OF FILE --