175 lines
2.7 KiB
C++
Raw Normal View History

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)
2021-12-20 16:47:55 +01:00
// 0.1.0 2020-12-30 Arduino-CI, unit tests, setRange()
// 0.1.1 2021-05-27 Arduino-lint
// 0.1.2 2021-12-20 update library.json, license, minor edits.
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 --