104 lines
3.3 KiB
Markdown
Raw Normal View History

2022-10-21 12:17:48 +02:00
[![Arduino CI](https://github.com/RobTillaart/moduloMap/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
[![Arduino-lint](https://github.com/RobTillaart/moduloMap/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/moduloMap/actions/workflows/arduino-lint.yml)
[![JSON check](https://github.com/RobTillaart/moduloMap/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/moduloMap/actions/workflows/jsoncheck.yml)
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/moduloMap/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/RobTillaart/moduloMap.svg?maxAge=3600)](https://github.com/RobTillaart/moduloMap/releases)
# moduloMap
Arduino library for the moduloMap class.
## Description
The moduloMap is an experimental library that optimizes modular mapping.
2022-10-23 10:36:41 +02:00
How do I define modular mapping?
2022-10-21 12:17:48 +02:00
Imagine the mapping of all real numbers on a subset in a modular way.
2022-10-23 10:36:41 +02:00
Imagine the real number line rolled around a defined circle with a minimum and maximum value.
After one rotation the numbers mapped to start over again.
2022-10-21 12:17:48 +02:00
2022-10-23 10:36:41 +02:00
E.g. moduloMap(7, 13) maps all the real numbers to the interval \[7; 13> modulo 6.
2022-10-21 12:17:48 +02:00
2022-10-23 10:36:41 +02:00
So the numbers 7..13 do not change as they are already within the range 7-13.
The number 6 is mapped on 12, 5 on 11, 4 on 10, .. 1 on 7, 0 on 12 -1 on 11 etc.
Similar the numbers in between e.g 5.5 is mapped on 11.5
Note: there is no scaling.
2022-10-21 12:17:48 +02:00
2022-10-23 10:36:41 +02:00
Other name might be circular mapping, although it might be any shape.
(for now circles is complex enough)
2022-10-21 12:17:48 +02:00
2022-10-23 10:36:41 +02:00
### Applications
2022-10-21 12:17:48 +02:00
2022-10-23 10:36:41 +02:00
- modular mapping of rotations to angles.
This can be on 0-360 degrees or 0-2PI radians or -180-180 degrees
or even -90..270 degrees.
- hoist math
Imagine a hoist, that needs to roll up / roll off a long rope around a cylinder.
- wire cutter
Determine the length of a wire for a wire cutter by moving it between two
wheels with known circumference.
- math fun
2022-10-21 12:17:48 +02:00
## Interface
- **moduloMap()** constructor.
2022-10-23 10:36:41 +02:00
- **bool begin(float minimum, float maximum)** define the range the numbers should be mapped to.
Returns true if minimum < maximum, false otherwise.
- **float map(float value)** actual mapping of a value to a number within the range.
- **float rotations(float value)** how many ranges (maximum - minimum) fit in a given length.
Think of it as how many rotations must a hoist must make to "free" a rope of given length.
Or how many rotations a hoist has to make to roll up a rope of given length.
This includes the minimum that already has rolled off / should stay rolled off.
Get internal parameters (for debug)
- **float getMinimum()** idem.
- **float getMaximum()** idem.
- **float getRange()** idem.
## Performance
Tested with moduloMap_performance.ino on AVR.
| version | 1000 x map |
|:---------:|:------------:|
| 0.1.0 | 44120 us |
| 0.1.1 | 36340 us |
2022-10-21 12:17:48 +02:00
## Operation
The examples show the basic working of the functions.
## Future
2022-10-23 10:36:41 +02:00
#### must
2022-10-21 12:17:48 +02:00
- elaborate documentation
- add examples
2022-10-23 10:36:41 +02:00
#### should
2022-10-21 12:17:48 +02:00
- move code to .cpp file
2022-10-23 10:36:41 +02:00
#### could
2022-10-21 12:17:48 +02:00
- are there other than circular modulos
2022-10-23 10:36:41 +02:00
- triangular, square, pentagram, fractal?
- increasing length per rotation (complex)
2022-10-21 12:17:48 +02:00
- add link to related libraries
- angles + fastmap?
2022-10-23 10:36:41 +02:00
- add **begin(float radius)**
- assumes circle from 0..max
#### wont
2022-10-21 12:17:48 +02:00