2021-01-29 12:31:58 +01:00
|
|
|
//
|
|
|
|
// FILE: Interval.cpp
|
|
|
|
// AUTHOR: Rob Tillaart
|
|
|
|
// DATE: 2020-07-21
|
2021-05-28 13:35:27 +02:00
|
|
|
// VERSION: 0.1.1
|
2021-01-29 12:31:58 +01:00
|
|
|
// PURPOSE: Arduino library for Interval datatype
|
|
|
|
// URL: https://github.com/RobTillaart/Interval
|
|
|
|
//
|
|
|
|
// 0.0.1 2020-07-20 initial version (not complete)
|
|
|
|
// 0.1.0 2020-12-30 arduino-ci, unit tests, setRange()
|
2021-05-28 13:35:27 +02:00
|
|
|
// 0.1.1 2021-05-27 arduino-lint
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
#include "Interval.h"
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval::Interval(float lo, float hi)
|
|
|
|
{
|
|
|
|
if (lo <= hi)
|
|
|
|
{
|
|
|
|
_lo = lo;
|
|
|
|
_hi = hi;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
_lo = hi;
|
|
|
|
_hi = lo;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval::Interval(float f)
|
|
|
|
{
|
|
|
|
_lo = f;
|
|
|
|
_hi = f;
|
|
|
|
};
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval::Interval()
|
|
|
|
{
|
|
|
|
_lo = 0;
|
|
|
|
_hi = 0;
|
|
|
|
};
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
float Interval::relAccuracy()
|
|
|
|
{
|
|
|
|
if (value() == 0.0) return -1;
|
|
|
|
return abs(range() / value()); // TODO /2 ?
|
|
|
|
}
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
void Interval::setRange(float r)
|
|
|
|
{
|
|
|
|
float f = value();
|
|
|
|
_lo = f - r / 2;
|
|
|
|
_hi = f + r / 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// PRINTABLE
|
|
|
|
size_t Interval::printTo(Print& p) const
|
|
|
|
{
|
|
|
|
size_t n = 0;
|
|
|
|
n += p.print('[');
|
|
|
|
n += p.print(_lo, _decimals);
|
|
|
|
n += p.print(", ");
|
|
|
|
n += p.print(_hi, _decimals);
|
|
|
|
n += p.print(']');
|
|
|
|
return n;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// MATH BASIC OPERATIONS
|
|
|
|
//
|
|
|
|
Interval Interval::operator + (const Interval &in)
|
|
|
|
{
|
|
|
|
return Interval(_lo + in._lo, _hi + in._hi);
|
|
|
|
}
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval Interval::operator - (const Interval &in)
|
|
|
|
{
|
|
|
|
return Interval(_lo - in._hi, _hi - in._lo);
|
|
|
|
}
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval Interval::operator * (const Interval &in)
|
|
|
|
{
|
|
|
|
return Interval(_lo * in._lo, _hi * in._hi);
|
|
|
|
}
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval Interval::operator / (const Interval &in)
|
|
|
|
{
|
|
|
|
return Interval(_lo / in._hi, _hi / in._lo);
|
|
|
|
}
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval Interval::operator += (const Interval &in)
|
|
|
|
{
|
|
|
|
_lo += in._lo;
|
|
|
|
_hi += in._hi;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval Interval::operator -= (const Interval &in)
|
|
|
|
{
|
|
|
|
_lo -= in._hi;
|
|
|
|
_hi -= in._lo;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval Interval::operator *= (const Interval &in)
|
|
|
|
{
|
|
|
|
_lo *= in._lo;
|
|
|
|
_hi *= in._hi;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
Interval Interval::operator /= (const Interval &in)
|
|
|
|
{
|
|
|
|
_lo /= in._hi;
|
|
|
|
_hi /= in._lo;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// COMPARISON OPERATIONS
|
|
|
|
//
|
|
|
|
|
|
|
|
bool Interval::operator == (const Interval &in)
|
|
|
|
{
|
|
|
|
return ((_lo == in._lo) && (_hi == in._hi));
|
|
|
|
}
|
|
|
|
|
2021-05-28 13:35:27 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
bool Interval::operator != (const Interval &in)
|
|
|
|
{
|
|
|
|
return ((_lo != in._lo) || (_hi != in._hi));
|
|
|
|
}
|
|
|
|
|
|
|
|
// VALUE FOR NOW...
|
|
|
|
// bool Interval::operator > (const Interval &in)
|
|
|
|
// {
|
|
|
|
// return this->value() > in.value();
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// bool Interval::operator >= (const Interval &in)
|
|
|
|
// {
|
|
|
|
// return this->value() >= in.value();
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// bool Interval::operator < (const Interval &in)
|
|
|
|
// {
|
|
|
|
// return this->value() < in.value();
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// bool Interval::operator <= (const Interval &in)
|
|
|
|
// {
|
|
|
|
// return this->value() <= in.value();
|
|
|
|
// }
|
|
|
|
|
|
|
|
|
|
|
|
// -- END OF FILE --
|
|
|
|
|