GY-63_MS5611/libraries/Histogram/histogram.h

84 lines
1.5 KiB
C
Raw Normal View History

2020-11-27 05:16:22 -05:00
#pragma once
//
// FILE: Histogram.h
// AUTHOR: Rob Tillaart
2022-11-09 04:42:12 -05:00
// VERSION: 0.3.2
// PURPOSE: Histogram library for Arduino
// DATE: 2012-11-10
//
2021-11-04 07:32:04 -04:00
#include "Arduino.h"
2022-11-09 04:42:12 -05:00
#define HISTOGRAM_LIB_VERSION (F("0.3.2"))
2021-11-04 07:32:04 -04:00
class Histogram
{
public:
2021-11-04 07:32:04 -04:00
Histogram(const uint16_t length, float *bounds);
~Histogram();
2021-11-04 07:32:04 -04:00
void clear(int32_t value = 0);
2022-11-09 04:42:12 -05:00
void setBucket(const uint16_t index, int32_t value = 0);
2021-11-04 07:32:04 -04:00
void add(const float value);
void sub(const float value);
2022-11-09 04:42:12 -05:00
// number of buckets
uint16_t size();
2022-11-09 04:42:12 -05:00
// number of values added to all buckets
uint32_t count();
2021-11-04 07:32:04 -04:00
2022-11-09 04:42:12 -05:00
// number of values added to single bucket
2021-11-04 07:32:04 -04:00
int32_t bucket(const uint16_t index);
float frequency(const uint16_t index);
float PMF(const float value);
float CDF(const float value);
float VAL(const float prob);
uint16_t find(const float value);
uint16_t findMin();
uint16_t findMax();
uint16_t countLevel(const int32_t level);
uint16_t countAbove(const int32_t level);
uint16_t countBelow(const int32_t level);
protected:
float * _bounds;
int32_t * _data;
2021-11-04 07:32:04 -04:00
uint16_t _length;
uint32_t _count;
};
//////////////////////////////////////////////////////////////
//
// DERIVED CLASS
//
class Histogram16 : public Histogram
{
public:
Histogram16(const uint16_t length, float *bounds);
~Histogram16();
protected:
int16_t * _data;
};
2021-11-04 07:32:04 -04:00
class Histogram8 : public Histogram
{
public:
Histogram8(const uint16_t length, float *bounds);
~Histogram8();
protected:
int8_t * _data;
};
2020-11-27 05:16:22 -05:00
// -- END OF FILE --
2021-11-04 07:32:04 -04:00