-
Notifications
You must be signed in to change notification settings - Fork 929
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
Model properties and/or model parameters as arguments for VisualisationElements #1216
Comments
This is possible if this part of self.js_code = []
for element in self.visualization_elements:
for include_file in element.package_includes:
self.package_includes.add(include_file)
for include_file in element.local_includes:
self.local_includes.add(include_file)
self.js_code.append(element.js_code) is moved to be inside Would be great if you can describe the use case you're facing, so that I can understand the context better. |
This part of the code: mesa/mesa/visualization/ModularVisualization.py Lines 268 to 274 in 2228b3c
|
Thanks @rht! Use case: Analysing impact of grid size (here: fire evacuation model) via GUI slider. Therefore, the grid extent is changed on reset. However, currently the canvas does not adapt: for smaller extents than initially, the grid covers only part of the canvas, for higher extents only part of the grid is displayed. canvas.new_element = "new CanvasModule({}, {}, {}, {})".format(
canvas.canvas_width, canvas.canvas_height, floor_size, floor_size
)
canvas.js_code = "elements.push(" + canvas.new_element + ");"
canvas.render(self) to |
Do you have a sample repo that I can build on to do some experimentation? |
The model I used to test grid resize is https://github.com/UniK-INES/MesaSimpleEvacuation. |
OK, thank you! It looks like you have also improved the boid_flockers example. Looking forward to the PR. And also, I think you can also help review the discrepancy in the Mesa/Agents.jl/MASON/NetLogo implementation of the boid_flockers, in this thread JuliaDynamics/Agents.jl#394 (comment). |
This would be extremely useful, but it looks like it has been quiet for 2 years. I assume we aren't going to get a pull request from @Holzhauer on this specific issue? If so, would a PR from me be considered instead, if I replicated the changes in a new fork? |
@stephenfmann is your comment about the boid_flockers example or about the grid size update? The former I can push next week after minor reviews, the latter I think is not relevant anymore as the new solara framework supports resizing. |
Ah, I meant the latter, in which case I'll check out solara -- I've only used tornado in the past. Thanks. |
Somewhat related: #2176 |
with the current solara front end this is largely resolved. |
Currently, visualisation element parameters such as CanvasGrid's width and heights parameters need to be hard-coded more or less, and it seems not possible to initialise the grid with other dimensions than initially defined, when resetting the model.
It would be great to allow functions as arguments which are called with the model or model parameter objects.
The text was updated successfully, but these errors were encountered: