Avoid inner-loop allocations in longest_path#1577
Open
jakelishman wants to merge 1 commit intoQiskit:mainfrom
Open
Avoid inner-loop allocations in longest_path#1577jakelishman wants to merge 1 commit intoQiskit:mainfrom
longest_path#1577jakelishman wants to merge 1 commit intoQiskit:mainfrom
Conversation
7d885a7 to
1600fc9
Compare
The only use of the per-node `Vec` is to consume it immediately into a `max_by` iterator. Rewriting the allocating loop as a single `try_fold` removes the unnecessary allocation. On a test 1.6 million gate circuit over on Qiskit, this sped up our use of `longest_path` from 150ms to 100ms, and there's further follow-on improvements available by changing the interfaces to allow path-length calculation without constructing the path itself.
7d81b85 to
f08f2ad
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
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.
The only use of the per-node
Vecis to consume it immediately into amax_byiterator. Rewriting the allocating loop as a singletry_foldremoves the unnecessary allocation.On a test 1.6 million gate circuit over on Qiskit, this sped up our use of
longest_pathfrom 150ms to 50ms, so a 3x improvement.