Serve interrupt only once per tick
Posted: Tue Nov 05, 2024 9:20 am
TL;DR
Add a checkbox to an interrupt that prevents its condition from passing twice in the same tick, globallyWhat?
The way it would work is that if this interrupt's condition became true for any train globally, it cannot become true again in the same tick. This way, multiple trains passing the condition would have to wait and serving the interrupt would be spread out over several ticks, potentially failing on subsequent ticks.Why?
These videos are the closest I found to implementing an LTN style train network in Vanilla 2.0https://www.youtube.com/watch?v=EggDldJVggM
https://www.youtube.com/watch?v=rRGAVDndFwk
The one annoying hurdle that couldn't be solved in this approach is that more than one train could be sent to service a request because the interrupt's condition became true for all trains at once. It was solved with a global clock, assigning a unique Id to each station and then only passing the condition if the clock's signal equals the station's id (the O signal in the condition). However, the more stations you add, the longer it takes to wrap around. And you also need to ensure that station Ids are unique which makes stamping down blueprints more of a hassle.
Once the interrupt has been served, the provider's train limit increases immediately, so next tick the interrupt might no longer pass (which is what we want). So if we had a way to say that a given interrupt should only be served once per tick, this would be quite a simple solution towards a truly generic LTN.
Thanks for considering!