mirror of
https://github.com/RobTillaart/Arduino.git
synced 2024-10-03 18:09:02 -04:00
60 lines
1.3 KiB
C++
60 lines
1.3 KiB
C++
#pragma once
|
|
//
|
|
// FILE: AverageAngle.h
|
|
// AUTHOR: Rob Tillaart
|
|
// VERSION: 0.2.1
|
|
// DATE: 2017-11-21
|
|
// PURPOSE: Arduino library to calculate correctly the average of multiple angles.
|
|
|
|
|
|
#include "math.h"
|
|
#include "Arduino.h"
|
|
|
|
#define AVERAGE_ANGLE_LIB_VERSION (F("0.2.0"))
|
|
|
|
#define GRAD_TO_RAD (PI / 200.0)
|
|
#define RAD_TO_GRAD (200.0 / PI)
|
|
|
|
|
|
#define AVERAGE_ANGLE_OK 0
|
|
#define AVERAGE_ANGLE_OVERFLOW -10
|
|
#define AVERAGE_ANGLE_SINGULARITY -20
|
|
|
|
|
|
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);
|
|
|
|
int lastError();
|
|
|
|
private:
|
|
AngleType _type;
|
|
float _sumx;
|
|
float _sumy;
|
|
uint32_t _count;
|
|
int _error;
|
|
};
|
|
|
|
|
|
// -- END OF FILE --
|
|
|