2022-07-18 15:54:11 +02:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/SparseArray/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/SparseArray/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/SparseArray/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/SparseArray/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/SparseArray/actions/workflows/jsoncheck.yml)
|
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/SparseArray/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/SparseArray.svg?maxAge=3600)](https://github.com/RobTillaart/SparseArray/releases)
|
|
|
|
|
|
|
|
|
|
|
|
# SparseArray
|
|
|
|
|
|
|
|
Arduino library for sparse arrays of floats.
|
|
|
|
|
|
|
|
|
|
|
|
## Description
|
|
|
|
|
|
|
|
SparseArray is an **experimental** library to implement a one
|
|
|
|
dimensional sparse array of floats (a.k.a. vector) on an Arduino.
|
2022-11-25 14:20:28 +01:00
|
|
|
A sparse array is an array with mostly zeros and a low percentage
|
2022-07-18 15:54:11 +02:00
|
|
|
non-zero values.
|
|
|
|
The purpose of this library is efficient storage in memory.
|
|
|
|
|
2022-11-25 14:20:28 +01:00
|
|
|
The maximum array size this library can represent is 65535 elements
|
|
|
|
with a theoretical maximum of 65535 non-zero elements.
|
2022-07-18 15:54:11 +02:00
|
|
|
(although that does not make sense due to overhead)
|
2022-11-25 14:20:28 +01:00
|
|
|
In practice the library limits the number of non-zero elements to 1000.
|
|
|
|
|
|
|
|
Note: 255 non-zero elements would fit in an UNO's 2K memory.
|
2022-07-18 15:54:11 +02:00
|
|
|
|
|
|
|
Relates to:
|
|
|
|
- https://github.com/RobTillaart/SparseMatrix
|
|
|
|
- https://github.com/RobTillaart/distanceTable
|
|
|
|
|
|
|
|
Note: this library is derived from SparseMatrix.
|
|
|
|
|
|
|
|
|
|
|
|
#### Implementation
|
|
|
|
|
2022-11-25 14:20:28 +01:00
|
|
|
The implementation is based on 2 arrays holding ```x, value```
|
2022-07-18 15:54:11 +02:00
|
|
|
where value is float, and x is an uint16_t.
|
|
|
|
That are 6 bytes per element.
|
2022-11-25 14:20:28 +01:00
|
|
|
The number of elements that the sparse array object can hold is
|
2022-07-18 15:54:11 +02:00
|
|
|
given as parameter to the constructor.
|
|
|
|
If the space cannot be allocated the size is set to zero.
|
|
|
|
|
|
|
|
In the future other data types should be possible.
|
|
|
|
|
2022-11-25 14:20:28 +01:00
|
|
|
Relates to https://github.com/RobTillaart/SET
|
|
|
|
|
2022-07-18 15:54:11 +02:00
|
|
|
|
|
|
|
#### Performance
|
|
|
|
|
|
|
|
The elements are not kept sorted or indexed so optimizations might be
|
|
|
|
possible but are not investigated yet.
|
|
|
|
There is however a test sketch to monitor the performance of
|
|
|
|
the most important functions.
|
|
|
|
|
|
|
|
Accessing elements internally is done with a linear search,
|
|
|
|
which becomes (much) slower if the number of elements is increasing.
|
|
|
|
This means that although in theory there can be 65535 elements,
|
|
|
|
in practice a few 100 can already become annoyingly slow.
|
|
|
|
To keep performance a bit the library has a limit build in.
|
|
|
|
Check the .h file for **SPARSEARRAY_MAX_SIZE 1000**
|
|
|
|
|
|
|
|
|
|
|
|
## Interface
|
|
|
|
|
|
|
|
```cpp
|
|
|
|
#include "SparseArray.h"
|
|
|
|
```
|
|
|
|
|
|
|
|
### Constructor + meta
|
|
|
|
|
|
|
|
- **SparseArray(uint16_t size)** constructor.
|
|
|
|
Parameter is the maximum number of elements in the sparse array.
|
|
|
|
Note this number is limited to **SPARSEARRAY_MAX_SIZE 1000**.
|
|
|
|
If the space requested cannot be allocated size will be set to 0.
|
|
|
|
- **uint16_t size()** maximum number of elements.
|
|
|
|
If this is zero, a problem occurred with allocation happened.
|
|
|
|
- **uint16_t count()** current number of elements in the array.
|
|
|
|
Should be between 0 and size.
|
|
|
|
- **float sum()** sum of all elements ( != 0 ) in the array.
|
|
|
|
- **void clear()** resets the array to all zero's again.
|
|
|
|
|
|
|
|
|
|
|
|
### Access
|
|
|
|
|
|
|
|
- **bool set(uint16_t x, float value)** gives an element in the array a value.
|
|
|
|
If the value is set to zero, it is removed from the internal store.
|
|
|
|
Returns false if the internal store is full, true otherwise.
|
|
|
|
- **float get(uint16_t x)** returns a value from the array.
|
|
|
|
- **bool add(uint16_t x, float value)** adds value to an element in the array.
|
|
|
|
If needed a new internal element is created.
|
|
|
|
If the sum is zero, the element is removed from the internal store.
|
|
|
|
Returns false if the internal store is full, true otherwise.
|
|
|
|
- **void boundingSegment(uint16_t &minX, uint16_t &maxX)**
|
|
|
|
Returns the bounding box in which all values != 0 are located.
|
|
|
|
This can be useful for printing or processing the non zero elements.
|
|
|
|
|
|
|
|
|
|
|
|
## Future
|
|
|
|
|
2022-11-25 14:20:28 +01:00
|
|
|
#### must
|
|
|
|
- improve documentation
|
|
|
|
|
|
|
|
#### should
|
|
|
|
- do test
|
|
|
|
- investigate optimizations
|
|
|
|
- derived sorted class ==> insertSort
|
2022-07-18 15:54:11 +02:00
|
|
|
- keep in sync with SparseMatrix where possible
|
2022-11-25 14:20:28 +01:00
|
|
|
- merge into one class hierarchy?
|
|
|
|
- Template class for the data type
|
|
|
|
- better than SparseArray64 SparseArray32 SparseArray16 SparseArray8 (signed / unsigned?)
|
|
|
|
|
|
|
|
#### could
|
2022-07-18 15:54:11 +02:00
|
|
|
- dump should be in the class?
|
|
|
|
- or as static function...
|
|
|
|
- stream as param dump(Stream str, ...
|
2022-11-25 14:20:28 +01:00
|
|
|
|
2022-07-18 15:54:11 +02:00
|
|
|
#### ideas
|
|
|
|
|
|
|
|
- array { uint32_t, float }; for logging millis/micros + measurement
|
|
|
|
delta coding of time stamp? if it fit in 16 bit?
|
|
|
|
=> sounds like a class on its own.
|
2022-11-25 14:20:28 +01:00
|
|
|
- investigate index \[\] operator for **get()** and **set()**
|
|
|
|
- would break with sparse matrix
|
2022-07-18 15:54:11 +02:00
|
|
|
|
|
|
|
|