Rob Tillaart 66c685d652 0.1.4 FLE
2023-10-30 15:37:30 +01:00
..
2023-01-23 10:10:49 +01:00
2021-05-28 13:27:47 +02:00
2022-12-08 17:29:26 +01:00
2022-12-08 17:29:26 +01:00
2023-10-30 15:37:30 +01:00
2023-10-30 15:37:30 +01:00
2023-10-30 15:37:30 +01:00
2023-10-30 15:37:30 +01:00
2023-10-30 15:37:30 +01:00
2023-01-23 10:10:49 +01:00
2023-10-30 15:37:30 +01:00

Arduino CI Arduino-lint JSON check GitHub issues

License: MIT GitHub release PlatformIO Registry

FLE

Arduino library for Arduino library for float with error data type

Description

This experimental library provides basic math when have a quantity with a certain 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.

Note: This library is experimental and only usable for educational purposes. There is no active development.

Interface

#include "FLE.h"

Printable

The FLE class implements the public interface of Printable. This allows you to print an FLE in human readable form.

    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.

Functions

  • FLE(val = 0, err = 0) constructor, with default value and error set to 0.
  • 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.
  • setSeparator(char c) overrules the standard ± char. (0177)
  • 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.

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.

Operation

  • negative numbers not tested yet

See example

Future

Must

  • update documentation

Should

Could

  • 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...

Wont

Support

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,