1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 09:52:45 +01:00
RIOT/tests/unittests/tests-phydat
Marian Buschsieweke fe46cae00d
sys/phydat: New phydat_fit API
The current phydat_fit implementation the following limitations:
- The API is way more complicated to use than needed
- It doesn't perform any rounding
- It uses `long` in a place where actual width (or better range) of the type
  is pretty important.

This commit addresses these limitations and uses lookup-tables to reduce the
number of divisions required.

Before this commit code using it looked like this:
``` C
long values[] = { 100000, 2000000, 30000000 };
phydat_t dat = { .scale = 42, .unit = UNIT_V };
phydat_fit(&dat, values[0], 0, phydat_fit(&dat, values[1], 1, phydat_fit(&dat, values[2], 2, 0)));
```

Now it can be used like this:
``` C
int32_t values[] = { 100000, 2000000, 30000000 };
phydat_t dat = { .unit = UNIT_V, .scale = 42 };
phydat_fit(&dat, values, 3);
```
2018-10-24 13:05:51 +02:00
..
Makefile unittests: Add test for phydat (phydat_fit) 2018-03-22 15:21:01 +01:00
Makefile.include unittests: Add test for phydat (phydat_fit) 2018-03-22 15:21:01 +01:00
tests-phydat.c sys/phydat: New phydat_fit API 2018-10-24 13:05:51 +02:00
tests-phydat.h unittests: Add test for phydat (phydat_fit) 2018-03-22 15:21:01 +01:00