2021-01-29 12:31:58 +01:00
|
|
|
#pragma once
|
|
|
|
//
|
|
|
|
// FILE: FLE.h
|
|
|
|
// AUTHOR: Rob Tillaart
|
|
|
|
// DATE: 2020-07-21
|
2022-12-08 17:29:26 +01:00
|
|
|
// VERSION: 0.1.3
|
2021-01-29 12:31:58 +01:00
|
|
|
// PURPOSE: Arduino library for float with error datatype
|
|
|
|
// URL: https://github.com/RobTillaart/FLE
|
|
|
|
//
|
|
|
|
// HISTORY:
|
|
|
|
// see FLE.cpp file
|
|
|
|
|
|
|
|
|
|
|
|
#include "Arduino.h"
|
|
|
|
#include "math.h"
|
|
|
|
|
2022-12-08 17:29:26 +01:00
|
|
|
#define FLE_LIB_VERSION (F("0.1.3"))
|
2021-05-28 13:27:47 +02:00
|
|
|
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
class FLE: public Printable
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
// CONSTRUCTOR
|
|
|
|
FLE(float val = 0, float error = 0);
|
|
|
|
|
|
|
|
// PRINTABLE
|
|
|
|
size_t printTo(Print& p) const;
|
|
|
|
FLE setDecimals(uint8_t n) { _decimals = n; return *this; };
|
|
|
|
FLE setSeparator(char c) { _sep = c; return *this; };
|
|
|
|
|
|
|
|
// BASE FUNCTIONS
|
|
|
|
float value() const{ return _v; };
|
|
|
|
float error() const{ return _e; };
|
|
|
|
float relError() const{ return (_v == 0 ? 0 : abs(_e / _v)); };
|
|
|
|
float high() const{ return _v + _e; };
|
|
|
|
float low() const{ return _v - _e; };
|
|
|
|
|
|
|
|
// MATH OPERATORS
|
2021-06-16 13:32:34 +02:00
|
|
|
FLE operator - (); // negation c = -a;
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
FLE operator + (const FLE&);
|
2021-06-16 13:32:34 +02:00
|
|
|
FLE operator - (const FLE&); // minus c = a - b;
|
2021-01-29 12:31:58 +01:00
|
|
|
FLE operator * (const FLE&);
|
|
|
|
FLE operator / (const FLE&);
|
|
|
|
FLE operator += (const FLE&);
|
|
|
|
FLE operator -= (const FLE&);
|
|
|
|
FLE operator *= (const FLE&);
|
|
|
|
FLE operator /= (const FLE&);
|
|
|
|
|
2021-06-16 13:32:34 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
// BOOL OPERATORS
|
2021-06-16 13:32:34 +02:00
|
|
|
// for all value pairs of a and b
|
|
|
|
bool operator == (const FLE&);
|
2022-12-08 17:29:26 +01:00
|
|
|
// bool operator == (const FLE);
|
2021-06-16 13:32:34 +02:00
|
|
|
bool operator != (const FLE&);
|
|
|
|
bool operator > (const FLE&);
|
|
|
|
bool operator < (const FLE&);
|
|
|
|
|
|
|
|
|
|
|
|
// MISC OPERATORS
|
|
|
|
// FLE lies completely in range a
|
|
|
|
// meaning FLE is more precise than a => smaller error.
|
|
|
|
bool in(FLE a);
|
2022-12-08 17:29:26 +01:00
|
|
|
// returns overlap == common part, or FLE(NAN, NAN) otherwise
|
|
|
|
FLE shared(FLE a);
|
|
|
|
FLE lower(FLE a); // part of this lower than a;
|
|
|
|
FLE higher(FLE a); // part of this higher than a;
|
|
|
|
|
2021-06-16 13:32:34 +02:00
|
|
|
|
|
|
|
// EXPERIMENTAL - INVESTIGATE
|
|
|
|
// weak propositions.
|
2022-12-08 17:29:26 +01:00
|
|
|
bool peq (const FLE& a); // possible equal
|
|
|
|
bool pne (const FLE& a); // possible not equal
|
|
|
|
bool plt (const FLE& a); // possible less than
|
|
|
|
bool ple (const FLE& a); // possible less equal
|
|
|
|
bool pgt (const FLE& a); // possible greater than
|
|
|
|
bool pge (const FLE& a); // possible greater equal
|
2021-06-16 13:32:34 +02:00
|
|
|
|
|
|
|
|
|
|
|
// semantic meaning not 100% clear
|
|
|
|
// bool operator >= (const FLE&);
|
|
|
|
// bool operator <= (const FLE&);
|
|
|
|
|
|
|
|
|
|
|
|
// SET LIKE MATH
|
|
|
|
// FLE shared(FLE a, FLE b); // overlap.
|
|
|
|
// FLE lower(FLE a, FLE b); // part of a lower than b;
|
|
|
|
// FLE higher(FLE a, FLE b); // part of a higher than b;
|
|
|
|
|
|
|
|
// float both%(FLE a, FLE b); // overlap percentage
|
|
|
|
// float sub%(FLE a, FLE b); // part of a lower than b;
|
|
|
|
// float sup%(FLE a, FLE b); // part of a higher than b;
|
|
|
|
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// infinite ?
|
|
|
|
// NAN ?
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
float _v;
|
|
|
|
float _e;
|
|
|
|
uint8_t _decimals = 2;
|
2021-06-16 13:32:34 +02:00
|
|
|
char _sep = '~'; // _sep = '±'; // gives warning.
|
2021-01-29 12:31:58 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// -- END OF FILE --
|