mirror of
https://github.com/RobTillaart/Arduino.git
synced 2024-10-03 18:09:02 -04:00
131 lines
3.6 KiB
Markdown
131 lines
3.6 KiB
Markdown
|
|
||
|
[![Arduino CI](https://github.com/RobTillaart/Interval/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
||
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/Interval/blob/master/LICENSE)
|
||
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/Interval.svg?maxAge=3600)](https://github.com/RobTillaart/Interval/releases)
|
||
|
|
||
|
|
||
|
# Interval
|
||
|
|
||
|
Arduino library for the Interval datatype. **Experimental**
|
||
|
|
||
|
|
||
|
## Description
|
||
|
|
||
|
This experimental library provides basic math when you do not know a quantity.
|
||
|
The only thing you do know is the value is in a certain interval.
|
||
|
After doing some math you want to know the interval of possible outcomes.
|
||
|
|
||
|
An interval exist of a pair of floats, low and high, the borders of the interval.
|
||
|
|
||
|
**footnote:**
|
||
|
The datatype Interval was created to do some experiments.
|
||
|
It was inspired by the frink language which has an interval datatype.
|
||
|
Frink itself is not investigated, so semantics are not necessary similar.
|
||
|
|
||
|
|
||
|
|
||
|
## Interface
|
||
|
|
||
|
The Interval class implements the public interface of Printable.
|
||
|
This allows you to print an Interval in human readable form.
|
||
|
|
||
|
```cpp
|
||
|
Interval x(3, 4);
|
||
|
x.setDecimals(2);
|
||
|
Serial.println(x); // will print [3.00, 4.00]
|
||
|
```
|
||
|
|
||
|
|
||
|
### Constructors
|
||
|
|
||
|
- **Interval()** zero = interval \[0, 0]
|
||
|
- **Interval(float lo, float hi)** interval \[lo, hi]
|
||
|
- **Interval(float f)** interval \[f, f]
|
||
|
|
||
|
|
||
|
### Basic functions
|
||
|
|
||
|
The basic functions are used to get and set some core attributes.
|
||
|
|
||
|
- **setDecimals()** set nr of decimals for printing.
|
||
|
- **value()** is the middle of the interval (as we do not know distribution)
|
||
|
- **range()** = high() - low()
|
||
|
- **high()** idem
|
||
|
- **low()** idem
|
||
|
- **relAccuracy()** = range() / value()
|
||
|
- **setRange(float r)** adjust range around value() =- r/2
|
||
|
|
||
|
|
||
|
### Math Operators
|
||
|
|
||
|
Math operators
|
||
|
|
||
|
- **addition + +=**
|
||
|
- **subtraction - -=**
|
||
|
- **multiplication \* \*=**
|
||
|
- **quotient \/ \/=**
|
||
|
|
||
|
|
||
|
### Functions
|
||
|
|
||
|
Functions are not implemented yet as these need **to be investigated**.
|
||
|
For a monotonous function it is relative easy
|
||
|
|
||
|
```
|
||
|
Interval v = F( [a, b] ); ==> [ F(a), F(b)]
|
||
|
e.g.
|
||
|
Interval f = exp( [a, b]); ==> [exp(a), exp(b)]
|
||
|
Interval g = log( [a, b]); ==> [log(a), log(b)] a > 0!!
|
||
|
```
|
||
|
The math for non monotonous functions is more complex
|
||
|
as one cannot use the function values as above.
|
||
|
|
||
|
```
|
||
|
Interval p = sin( [0, PI] ); ==> [0, 1]
|
||
|
Interval q = sin( [0, -PI] ); ==> [-1, 0]
|
||
|
Interval r = sin( [0, 10 * PI] ); ==> [-1, 1]
|
||
|
|
||
|
Interval s = sqr( [-5, -3] ) ; ==> [9, 25]
|
||
|
Interval t = sqr( [-5, 3] ) ; ==> [0, 25]
|
||
|
|
||
|
```
|
||
|
|
||
|
- change range while keeping value.
|
||
|
|
||
|
|
||
|
### Comparison operators
|
||
|
|
||
|
**To be investigated**. The semantics make at least a difference between when
|
||
|
an interval is Certainly Less Equal or Probably Less or Equal.
|
||
|
The Certainly group will be boolean math as we know it.
|
||
|
The Probably group will be more like fuzzy logic so a float between 0..100%.
|
||
|
|
||
|
- **bool == **
|
||
|
- **bool != **
|
||
|
- **bool > **
|
||
|
- **bool >= **
|
||
|
- **bool < **
|
||
|
- **bool <= **
|
||
|
|
||
|
### Set operators
|
||
|
|
||
|
**To be investigated** include:
|
||
|
- If you have two or more intervals, what is the 'super interval' that includes all?
|
||
|
- How to subtract elements of an interval from another Interval?
|
||
|
This is different than the subtraction above,
|
||
|
think of it as " I know the number I look for is in \[1, 4] but it is not in \[3, 5]
|
||
|
so it is in \[1,3]
|
||
|
|
||
|
|
||
|
### Other
|
||
|
|
||
|
- a known problem is difference between border inclusive \[ \] and
|
||
|
border exclusive \< \>. How to deal with that?
|
||
|
- 1/\[-1, 1\] ==> ?? singularity for 0?
|
||
|
- infinity as border? In math we have \[0, \->> for all positive floats.
|
||
|
|
||
|
|
||
|
## Operation
|
||
|
|
||
|
See example
|