-
Notifications
You must be signed in to change notification settings - Fork 100
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
tuple rgb value reported to be slower than list #52
Comments
This should be re-tested with _pixelbuf. |
@dhalbert Have you had a chance to test this with the recent updates to see if it is still an issue? |
I tested this on a CPX with v6.0.0-alpha.1 using this code: import time
import board
import neopixel
pixel_pin = board.NEOPIXEL
num_pixels = 10
pixels = neopixel.NeoPixel(pixel_pin, num_pixels, brightness=0.3, auto_write=True)
before_time = time.monotonic_ns()
pixels[0] = (10,10,10)
after_time = time.monotonic_ns()
print("tuple took: {}ns".format(after_time - before_time))
before_time = time.monotonic_ns()
pixels[0] = [10,10,10]
after_time = time.monotonic_ns()
print("list took: {}ns".format(after_time - before_time)) As far as I can tell there is not a major difference in the time it takes to set a tuple vs. setting a list. The does seem consistently a bit faster, but only slightly so, not multiple times faster. Here is an example of the output from this test:
I've run it several times the specific values differ slightly from run to run, but the overall theme remains the same tuple is slightly slower than list, but not slower by multiple times. |
Maybe I spoke too soon, or else there is a little bit more at play in the context of this issue... I just ran essentially the same test on an Edge Badge with v6.0.0-alpha.1 and the latest neopixel.mpy out of the current bundle. With that setup I am seeing a decently sized difference in the time it took to set the neopixel. However in this case the list seems to be slower than the tuple:
|
Poking around at issues, I'm curious if this is still the case in 9.0.0. |
FlakShim in discord #help-with-circuitpython on Sept 25 reports that
pixels[i] = (10,10,10)
is 4x slower thanpixels[i] = [10,10,10]
. Confirm and investigate. No obvious issue noted in NeoPixel code; might be CircuitPython related.The text was updated successfully, but these errors were encountered: