-
Notifications
You must be signed in to change notification settings - Fork 147
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
Add a push_light method and use likely/unlikely intrinsics #134
Conversation
} | ||
|
||
#[cfg(not(feature = "push_light"))] | ||
fn push_light(&mut self, _: T) {} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't understand why this is defined if the feature is missing, and why it does nothing.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's to ensure things still compile
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It compiles sure, but it doesn't do the right thing, why should it be a noop if the feature is missing? Sounds like a way to have silent bugs.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's not meaningful to benchmark a feature if it's disabled
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Oh ok sorry I didn't notice this was an implementation for benchmarks.
|
||
trait Vector<T>: for<'a> From<&'a [T]> + Extend<T> + ExtendFromSlice<T> { | ||
fn new() -> Self; | ||
fn push(&mut self, val: T); | ||
fn push_light(&mut self, val: T); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
IMO this should either not exist when the feature is not enabled, or delegate to push
in the default implementation.
So the speedup when the vector isn't spilled is more than 2x (both with and without inlining, I added benchmarks to test it without the |
It probably does make sense to make it the default behavior. |
Additionally, I would mark this function |
☔ The latest upstream changes (presumably #169) made this pull request unmergeable. Please resolve the merge conflicts. |
Was this ever made the default behaviour? It seems like an easy win. |
We can't make this the default as written, because even without the |
I pushed a rebased version of this PR plus a commit to make At a glance, it looks like this is still a win for |
You can always have a |
Yes, the branch I linked above keeps the unstable intrinsics behind an optional feature. |
This adds a
push_light
alternative topush
which is optimized for inlining and for vectors which fit inside the fixed size.This change isdata:image/s3,"s3://crabby-images/d0bb7/d0bb7f7625ca5bf5c3cf7a2b7a514cf841ab8395" alt="Reviewable"