2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/FLE/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2022-12-08 17:29:26 +01:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/FLE/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/FLE/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/FLE/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/FLE/actions/workflows/jsoncheck.yml)
|
2023-10-30 15:37:30 +01:00
|
|
|
[![GitHub issues](https://img.shields.io/github/issues/RobTillaart/FLE.svg)](https://github.com/RobTillaart/FLE/issues)
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/FLE/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/FLE.svg?maxAge=3600)](https://github.com/RobTillaart/FLE/releases)
|
2023-10-30 15:37:30 +01:00
|
|
|
[![PlatformIO Registry](https://badges.registry.platformio.org/packages/robtillaart/library/FLE.svg)](https://registry.platformio.org/libraries/robtillaart/FLE)
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-12-08 17:29:26 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
# FLE
|
|
|
|
|
2023-10-30 15:37:30 +01:00
|
|
|
Arduino library for Arduino library for float with error data type
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-05-28 13:27:47 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Description
|
|
|
|
|
2023-10-30 15:37:30 +01:00
|
|
|
This **experimental** library provides basic math when have a quantity with a certain
|
2021-01-29 12:31:58 +01:00
|
|
|
error margin. E.g. when you approximate PI as 22/7 it is not exact. By doing the
|
|
|
|
math with FLE's one can see how much error adds up in an calculation.
|
|
|
|
|
2023-10-30 15:37:30 +01:00
|
|
|
Note: This library is experimental and only usable for educational purposes.
|
|
|
|
There is no active development.
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
## Interface
|
|
|
|
|
2023-10-30 15:37:30 +01:00
|
|
|
```cpp
|
|
|
|
#include "FLE.h"
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
### Printable
|
|
|
|
|
|
|
|
The FLE class implements the public interface of Printable.
|
|
|
|
This allows you to print an FLE in human readable form.
|
|
|
|
|
|
|
|
```cpp
|
|
|
|
FLE x(3.14, 0.002);
|
|
|
|
x.setDecimals(4);
|
|
|
|
Serial.println(x); // will print 3.1400 ± 0.0020
|
|
|
|
Serial.println(x.setDecimals(2)); // will print 3.14 ± 0.00
|
|
|
|
Serial.println(x.value()); // will print 3.14
|
|
|
|
```
|
|
|
|
|
|
|
|
When the ± char does not print correctly, one could change the font.
|
|
|
|
|
2021-05-28 13:27:47 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
### Functions
|
|
|
|
|
|
|
|
- **FLE(val = 0, err = 0)** constructor, with default value and error set to 0.
|
2022-12-08 17:29:26 +01:00
|
|
|
- **PrintTo(Print& p)** printable interface, define a stream to print to.
|
|
|
|
Format is "value ± error" see above (plus-minus ± = char(0177))
|
|
|
|
- **setDecimals(n)** will print the FLE both value and error with n decimals.
|
2021-01-29 12:31:58 +01:00
|
|
|
- **setSeparator(char c)** overrules the standard ± char. (0177)
|
2022-12-08 17:29:26 +01:00
|
|
|
- **value()** returns value part.
|
|
|
|
- **error()** return error part.
|
|
|
|
- **relError()** returns relative error, except when value == 0.
|
|
|
|
Then the function returns 0. Q: should this be "NaN" ?
|
|
|
|
- **high()** returns value + error margin (= max real value).
|
|
|
|
- **low()** returns value - error margin (= min real value).
|
|
|
|
|
|
|
|
Furthermore the basic math is implemented, "+, -, \*, /, +=, -=, \*=, /="
|
|
|
|
|
|
|
|
|
|
|
|
#### Set like functions
|
|
|
|
|
|
|
|
- **bool in(FLE y)** x.in(y) returns true if x lies completely in y (range is a subset)
|
|
|
|
- **FLE shared(FLE y)** returns the overlapping range.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-12-08 17:29:26 +01:00
|
|
|
|
|
|
|
#### Weak propositions
|
|
|
|
|
|
|
|
Experimental.
|
|
|
|
|
|
|
|
- **bool peq(FLE &y)** possible equal.
|
|
|
|
- **bool pne(FLE &y)** possible not equal.
|
|
|
|
- **bool plt(FLE &y)** possible less than.
|
|
|
|
- **bool ple(FLE &y)** possible less equal.
|
|
|
|
- **bool pgt(FLE &y)** possible greater than.
|
|
|
|
- **bool pge(FLE &y)** possible greater equal.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-05-28 13:27:47 +02:00
|
|
|
|
2023-10-30 15:37:30 +01:00
|
|
|
## Operation
|
|
|
|
|
|
|
|
- negative numbers not tested yet
|
|
|
|
|
|
|
|
See example
|
|
|
|
|
|
|
|
|
|
|
|
## Future
|
|
|
|
|
|
|
|
#### Must
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-12-08 17:29:26 +01:00
|
|
|
- update documentation
|
2023-10-30 15:37:30 +01:00
|
|
|
|
|
|
|
#### Should
|
|
|
|
|
|
|
|
#### Could
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
- comparison (investigate, what means equal or less than ..)
|
|
|
|
- functions log, exp,
|
|
|
|
- functions sqr, sqrt, pow
|
|
|
|
- functions sin, cos, tan (+ inverse + hyp)
|
|
|
|
- test ad infinitum
|
|
|
|
- option to set the ± char for platforms that cannot print it.
|
|
|
|
- test negative numbers
|
|
|
|
- test large / small numbers.
|
|
|
|
- test other separator
|
|
|
|
- more demo sketches...
|
|
|
|
|
2023-10-30 15:37:30 +01:00
|
|
|
#### Wont
|
2021-05-28 13:27:47 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2023-10-30 15:37:30 +01:00
|
|
|
## Support
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2023-10-30 15:37:30 +01:00
|
|
|
If you appreciate my libraries, you can support the development and maintenance.
|
|
|
|
Improve the quality of the libraries by providing issues and Pull Requests, or
|
|
|
|
donate through PayPal or GitHub sponsors.
|
|
|
|
|
|
|
|
Thank you,
|
2022-12-08 17:29:26 +01:00
|
|
|
|