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

Run some systems at different tickrate #1806

Closed
sojuz151 opened this issue Apr 2, 2021 · 2 comments
Closed

Run some systems at different tickrate #1806

sojuz151 opened this issue Apr 2, 2021 · 2 comments
Labels
C-Feature A new feature, making something new possible

Comments

@sojuz151
Copy link

sojuz151 commented Apr 2, 2021

What problem does this solve or what need does it fill?

In some games such as Minecraft and Factorio some systems run once per tick, with a usual tick rate being 10Hz. Additionally, in some multiplayer games, physics and the netcode also run at a constant tickrate, independent from the frame-rate. In the former case such computation could be performance intensive so you want to avoid doing everything on a single frame.

What solution would you like?

A way to separate systems into physics and render part of your game. You could mark systems as belonging to either of those categories. From the render part you could start computation of the next tick, check progress or apply already computed tick. Until you apply, all render systems would see components from the last tick. Ability to save and load full state of physical part would be nice for rollback netcode and access components from the last tick.

What alternative(s) have you considered?

Do it all manually.

Additional

Coping required for this previous tick access would not have a big performance impact. The memory footprint could be limited by marking system that require this. Additionally, if the coping was performed when the first &mut is required, all the coping would take place inside CPU cache.

@alice-i-cecile alice-i-cecile added core C-Feature A new feature, making something new possible labels Apr 2, 2021
@alice-i-cecile
Copy link
Member

See also #1343 :)

@james7132
Copy link
Member

As of schedule v3, FixedUpdate exists now, and it should be possible to insert your own FixedUpdate-like schedule that run at their own cadence. Having another schedule run independently of the main schedule will likely either be unsound or require world separation like the render world. Closing this issue out for now.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
C-Feature A new feature, making something new possible
Projects
None yet
Development

No branches or pull requests

3 participants