50 lines
1.8 KiB
Markdown
Raw Normal View History

2021-01-29 12:31:58 +01:00
[![Arduino CI](https://github.com/RobTillaart/MultiMap/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/MultiMap/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/RobTillaart/MultiMap.svg?maxAge=3600)](https://github.com/RobTillaart/MultiMap/releases)
2020-11-27 11:20:37 +01:00
# MultiMap
Arduino library for fast non-linear mapping or interpolation of values
2021-05-28 13:39:42 +02:00
2020-11-27 11:20:37 +01:00
## Description
In Arduino applications often the value of a sensor is mapped upon a more
usable value. E.g. the value of analogRead() is mapped onto 0 .. 5.0 Volt.
This is done by the map function which does a linear interpolation. This means
2021-01-29 12:31:58 +01:00
```cpp
2020-11-27 11:20:37 +01:00
output = C1 + input * C2
```
2021-01-29 12:31:58 +01:00
2020-11-27 11:20:37 +01:00
As C1 and C2 are to be calculated Arduino has the **map()** that calculates the
two variables runtime from two given mappings.
2021-01-29 12:31:58 +01:00
```cpp
2020-11-27 11:20:37 +01:00
output = map(input, I1, I2, O1, O2):
```
2021-01-29 12:31:58 +01:00
In many cases when there is no linear mapping possible, as the 'points' are not on a single line.
One needs non-linear math to calculate the output, **Multimap()** just does that.
2020-11-27 11:20:37 +01:00
2021-01-29 12:31:58 +01:00
**out = Multimap(value, input, output, size)** needs two equal sized arrays of reference 'points', **input\[\]** and **output\[\]**, it looks up the
2020-11-27 11:20:37 +01:00
input value in the input\[\] array and if needed it linear interpolates between two
points of the output\[\] array.
2021-01-29 12:31:58 +01:00
- The **input\[\]** array must have increasing values,
2020-11-27 11:20:37 +01:00
there is no such restriction for the **output\[\]** array.
2021-01-29 12:31:58 +01:00
- **Multimap()** automatically constrains the output to the first and last value in the **output\[\]** array.
2020-11-27 11:20:37 +01:00
2021-05-28 13:39:42 +02:00
2020-11-27 11:20:37 +01:00
## Operation
See examples
Please note the fail example as this shows that in the intern math overflow can happen.
2021-05-28 13:39:42 +02:00
2020-11-27 11:20:37 +01:00
## TODO
Investigate class implementation for performance.