⚡️ Speed up method Color.as_hex
by 10%
#48
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
📄 10% (0.10x) speedup for
Color.as_hex
inpydantic/color.py
⏱️ Runtime :
20.9 microseconds
→19.0 microseconds
(best of115
runs)📝 Explanation and details
To optimize the given Python program for faster execution, we can make a few improvements.
float_to_255
in each iteration of the list comprehension, move it outside the loop when possible.Here is the optimized version of the provided code.
Explanation:
alpha
value is directly accessed and then added to thevalues
list if it exists, reducing duplicated list slicing.repeat_vehicle
check: Use slicing directly inside join.✅ Correctness verification report:
⚙️ Existing Unit Tests Details
📢 Feedback on this optimization?