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

Update entity cloning benchmarks #17084

Merged
merged 9 commits into from
Jan 2, 2025

Conversation

BD103
Copy link
Member

@BD103 BD103 commented Jan 2, 2025

Objective

Solution

  • Merge entity_cloning into the rest of the ECS benchmarks.
  • Apply the bench! macro to all benchmark names.\
  • Reorganize benchmarks and their helper functions, with more comments than before.
  • Remove all the extra component definitions (C2, C3, etc.), and just leave one. Now all entities have exactly one component.

Testing

# List all entity cloning benchmarks, to verify their names have updated.
cargo bench -p benches --bench ecs entity_cloning -- --list

# Test benchmarks by running them once.
cargo test -p benches --bench ecs entity_cloning

# Run all benchmarks (takes about a minute).
cargo bench -p benches --bench ecs entity_cloning

Showcase

image

Interestingly, using Clone instead of Reflect appears to be 2-2.5 times faster. Furthermore, there were noticeable jumps in time when running the benchmarks:

image

I theorize this is because the World is allocating more space for all the entities, but I don't know for certain. Neat!

In doing so, I've also renamed all the benchmarks and moved them under benchmark groups.
- Add lots of comments
- Move functions specific to reflection coding behind the `if` gate
- Fix `black_box()` being used incorrectly
Now they're grouped based on what kind of hierarchy they are, not whether they use `Clone` or `Reflect`. I also deleted all the extra structure definitions, so now each entity has one component of 64 bytes.
@BD103 BD103 added A-ECS Entities, components, systems, and events C-Code-Quality A section of code that is hard to understand or change C-Benchmarks Stress tests and benchmarks used to measure how fast things are D-Modest A "normal" level of difficulty; suitable for simple features or challenging fixes S-Needs-Review Needs reviewer attention (from anyone!) to move forward labels Jan 2, 2025
@BD103
Copy link
Member Author

BD103 commented Jan 2, 2025

@eugineerd if you have the time, I would appreciate your review! Since you originally created entity cloning and its benchmarks, you can catch any mistakes that I made or things that I left out. Thanks!

Copy link
Contributor

@eugineerd eugineerd left a comment

Choose a reason for hiding this comment

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

This is a nice cleanup. I created this benchmark just to test the changes in #16717 and didn't put too much effort into making it right (not to mention this is my first time using criterion in general), so this is certainly an improvement.

My only concern is that 1 component per entity is not really representative of the average workload for this command. I would expect entities to have at least a couple different components in real-world scenario. If you look at the table in #16717 , you can see that the 1 component benchmarks actually regressed a bit, even though multiple components gained a big perf boost. I'd say that just having benchmark work for multiple components should be enough as 1 component isn't as common.

benches/benches/bevy_ecs/entity_cloning.rs Outdated Show resolved Hide resolved
- Reintroduce `ComplexBundle`, `C2`, `C3`, `C4`, etc.
- Make `single()` and `hierarchy_many()` use `ComplexBundle`.
- Add documentation for which benchmarks use 1 or several components.
- Decrease the size of the tree in `hierarchy_many()` so it doesn't take 15 seconds.
- Remove the `#[reflect(Component)]` attribute from components, since it's not necessary to clone using `Reflect` anymore.
@BD103
Copy link
Member Author

BD103 commented Jan 2, 2025

My only concern is that 1 component per entity is not really representative of the average workload for this command. I would expect entities to have at least a couple different components in real-world scenario. If you look at the table in #16717 , you can see that the 1 component benchmarks actually regressed a bit, even though multiple components gained a big perf boost. I'd say that just having benchmark work for multiple components should be enough as 1 component isn't as common.

Thank you for the review, this was exactly the kind of thing I was hoping you'd catch! It should all be fixed now in e50ab98, but let me know if anything else needs changed. :)

Copy link
Contributor

@eugineerd eugineerd left a comment

Choose a reason for hiding this comment

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

Should be good now.

@BD103 BD103 added S-Ready-For-Final-Review This PR has been approved by the community. It's ready for a maintainer to consider merging it and removed S-Needs-Review Needs reviewer attention (from anyone!) to move forward labels Jan 2, 2025
@alice-i-cecile alice-i-cecile added this pull request to the merge queue Jan 2, 2025
Merged via the queue into bevyengine:main with commit 765166b Jan 2, 2025
33 checks passed
@BD103 BD103 deleted the entity-cloning-benches branch January 3, 2025 07:09
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
A-ECS Entities, components, systems, and events C-Benchmarks Stress tests and benchmarks used to measure how fast things are C-Code-Quality A section of code that is hard to understand or change D-Modest A "normal" level of difficulty; suitable for simple features or challenging fixes S-Ready-For-Final-Review This PR has been approved by the community. It's ready for a maintainer to consider merging it
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants