-
Notifications
You must be signed in to change notification settings - Fork 0
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
Slider to update playback speed #108
Conversation
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.
Conceptually I think that this is a good idea and the implementation looks sensible, although my experience with Dash is limited, so I'm approving the PR.
BUT, when working with data produced by the models live, there might be issues if requesting data too fast as there might not be new data. I seem to remember that the agents model produces data and pushes it to Gridlington precisely every 7 seconds, and that's where that number is coming from. I am not entirely sure how this changes in the visualisation side of things will get along with slow data ingestion in the data hub.
If the model has a fixed interval of 7 seconds then it probably makes sense to hide the slider when using the live model, as it won't really do anything apart from changing how quickly the plots update. If the model interval is something that can be configured, then we could get the controller to send signals to the model to update the interval (similar to what I'm doing in #109 for start/stop signals), but not sure if this is desired. Maybe something to discuss with Yue/Phil, but for now I think we should just hide the slider when using the live model and keep the interval fixed to 7 seconds. |
Description
Currently we have two
dcc.Interval
objects (data_interval
andfigure_interval
), in charge of updating the data and figures. The time-interval of these two objects is specified manually in the code, and fixed to 7 seconds for both. This way we get data and figure updates at the same rate, but the interval objects are not linked in any way so updates don't necessarily occur on the same cycle (i.e. the figures may wait several seconds after the data has updated before updating themselves). Also, since the time-interval is fixed in the code it can't be changed from the app.I have three main goals with this pull request:
The overall approach is fairly convoluted but the simplest I could come up with and seems to work. The main steps can be summarised as follows:
figure_interval
to adcc.Store
object which just contains a value and doesn't increment on its own. Theupdate_figure_interval
callback runs in the background and is responsible for synchronisingfigure_interval
withdata_interval
(via theN_INTERVALS_DATA
global variable).update_figures
callback on each of the figure pages then responds wheneverfigure_interval
changes and triggers the figures to updateupdate_data
callback will switch thedisabled
property ofdata_interval
toTrue
. This preventsdata_interval
from incrementing any further, therefore terminating data and figure updates.update_data_interval
) which updates theinterval
attribute ofdata_interval
.Note: When the live model is being used this will only change the rate at which the data is pulled in and the figures updated, it doesn't interact with the model in any way so won't change the speed of the simulation or anything like that. When using the pre-set data, we add one new timepoint each interval, so this does change the rate at which new data appears.
Control app:
Close #97
Type of change
Key checklist
python -m pytest
)pre-commit run --all-files
)