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

using _all_channels to update efficiently #34

Merged
merged 2 commits into from
Dec 23, 2023
Merged

Conversation

garyk10
Copy link
Contributor

@garyk10 garyk10 commented Apr 6, 2023

When not changing between low and high, the channel#_data was not being updated. Also, the clear and nir data is available when _low_channels_configured, so no need to change to high.

When not changing between low and high, the _channel_#_data was not being updated.  Also, the clear and nir data is available when _low_channels_configured, so no need to change to high.
@tekktrik
Copy link
Member

Do you need to "get" _all_channels? The CI is angry since it thinks it's a "pointless statement". You may need to assign the result to underscore (e.g. _ = self._all_channels) or disable the pylint warning for it in that case.

@FoamyGuy
Copy link
Contributor

I pushed a commit to catch the return from all_channels into _ as mentioned.

The specifics of this change are a bit over my head. Hoping we can have someone with more knowledge weigh in, or at least with hardware to try it out.

@garyk10
Copy link
Contributor Author

garyk10 commented Apr 17, 2023

Thanks for the change. The only hardware I have tried is with a Raspberry Pi Zero and a Raspberry Pi 3B connected to the AS7341 via SDA/SCL pins, using Python 3.9 or 3.10. I haven't tried any microcontrollers using MicroPython to do this.

@jedgarpark
Copy link

I've experienced a similar issue in CircuitPython running on a Feather RP2040 and attempting to read only the clear channel. It does not update unless i am also reading other channels.

Copy link
Contributor

@FoamyGuy FoamyGuy left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks good to me.

Thank you @garyk10 for this improvement!

I tested this successfully on on a Feather S3 TFT. Confirmed the currently released version does not update clear reading unless other readings are taken too. And this PR version does successfully update clear readings even if no other readings are taken.

@FoamyGuy FoamyGuy merged commit 26697ad into adafruit:main Dec 23, 2023
adafruit-adabot added a commit to adafruit/Adafruit_CircuitPython_Bundle that referenced this pull request Dec 24, 2023
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

Successfully merging this pull request may close these issues.

4 participants