sparkfun / SparkFun_VL53L1X_Arduino_Library

A library for the laser based VL53L1X Time Of Flight distance sensor capable of detecting a target 4m away!
MIT License
88 stars 50 forks source link

Synchronise getDistance and getRangeStatus #43

Open hb020 opened 3 years ago

hb020 commented 3 years ago

getDistance and getRangeStatus go together. No use reading getDistance if one does not know the range status, as the status will tell if the distance read is valid or not. However, in the SDK they are 2 separate calls. When in continuous mode, therefore, it is not always clear if the values that are read pertain to the same sampling. This can be tested easily:

s1 = ds->getRangeStatus();
d = ds->getDistance();
s2 = ds->getRangeStatus();
if (s1 != s2) { .. signal error or ignore... }

When continuous mode is enabled, over time, you will get this error, especially if the reading conditions are bad. It is not uncommon to have the following sequential readings distance X, status 2 distance Y, status 0 distance Z, status 2

where X,Y and Z are each totally different from each other In that case, with the present lib configuration, it is possible to read distance X or Z, status 0, what would be wrong.

It is best to read the related registers all at the same time from the device, as can be found in some of the other VL53L1X libs, as in the reference implementation STSW-IMG007.

jimtng commented 2 years ago

@hb020 could you point me to the other libs which implemented reading the related registers at the same time?

hb020 commented 2 years ago

In the end I went with the "VL53L1X" pololu lib. It has less functionality as far as I remember, but does read correctly (see VL53L1X::readResults). I guess some others also can do the job.