SparkFun_VL53L1X_Arduino_Library icon indicating copy to clipboard operation
SparkFun_VL53L1X_Arduino_Library copied to clipboard

Synchronise getDistance and getRangeStatus

Open hb020 opened this issue 3 years ago • 2 comments

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.

hb020 avatar Dec 26 '20 18:12 hb020

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

jimtng avatar Feb 01 '22 01:02 jimtng

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.

hb020 avatar Feb 01 '22 06:02 hb020