Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Missing data read flag #32

Open
riv-david opened this issue Jan 2, 2021 · 3 comments
Open

Missing data read flag #32

riv-david opened this issue Jan 2, 2021 · 3 comments

Comments

@riv-david
Copy link

Hi,

I've just started using the library and it was really easy to get up and running so good job there!

For my application (datalogger) it is important i read every single reading from the accel exactly once. It is also important if for some reason i miss a reading that I can tell if that has occured.

I think the easiest way to implement this would be to add a flag (or two? one for gyro, one for accel) to the class variables which can be checked before calling sensor.acceleration or sensor.gyro. Upon calling those functions the function would set the flag to 0 to indicate no values have changed since last read.

Within the function that gets the data over I2C or handles the update of that data it should update the flag each time adding +1 to it's value. This would mean if say 20 readings were missed the user could easily tell by looking at the flag values.

I considered trying to implement this by say checking values were consistant but this is not reliable as during static portions of my testing I will likely get the same values for a few readings.

I am happy to try help implement this if you think this is a viable route to go but as I am not the most proficient Python programmer I can't for the life of me work out where the function is that gets the raw values over I2C to increment the flag within?

@ladyada
Copy link
Member

ladyada commented Jan 3, 2021

i dont think we would take a counter addition, it isnt something that really makes sense in the scheme of the library - usually if you miss data points you know because time passed (since the accel is going at a fixed rate and you are timestamping with time.monotonic()), or you can set up the FIFO which is the 'proper' solution

if you want to add FIFO support we'd totally welcome a PR!

@riv-david
Copy link
Author

I read about the FIFO in the data sheet. It was what I was hoping to use but obviously saw it wasn't implemented.

Given that i can't work out where the I2C communication was happening or how the frequency that the communication is happening is controlled i don't think I have the ability to impement that. Will take a look but not overly optimistic hah!

@ladyada
Copy link
Member

ladyada commented Jan 4, 2021

the i2c system is kinda nifty it works with the register library so you just need to make the registers for the chip needed to enable the FIFO and then write the data ya need https://github.com/adafruit/Adafruit_CircuitPython_LSM6DS/blob/master/adafruit_lsm6ds/__init__.py#L175

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants