-
Notifications
You must be signed in to change notification settings - Fork 6
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
Allow for creating models from Python strings #156
Comments
If this is necessary to close issue #157 I should be able to do something quick in a few days - the existing functionality is probably nicer for a user though - it separates describing the model from writing the function call to parse the model. |
NB this can currently be done with e.g. model1 = mumot.parseModel("""
U -> A : g_1
U -> B : g_2
A -> U : a_1
B -> U : a_2
A + U -> A + A : r_1
B + U -> B + B : r_2
A + B -> A + U : s
A + B -> B + U : s
""".replace('\n', '\\n')) Some extra logic in |
You mean it already works as described @willfurnass (I'd be surprised unless you changed something) or it would be straightforward to make it work (I agree, was thinking the same, and could make the change quickly)? |
The snipped of code in #156 (comment) works for me. I tried something like this a while ago but think I was missing the |
Great, on reflection I can see why this would work - since this is a satisfactory workaround for testing purposes I can focus now on #158 |
Feel free to add some pre-processing to the input string within the |
Following on from #67 I I think it would be a very good thing if MuMoT models could be created and referenced in Notebooks without using Notebook cell execution numbers. At present the example Notebooks contain cells like:
then
This approach causes problems for the user if they want to re-run a given cell as then calls like
mumot.parseModel(In[X})
in subsequent cells won't work without manual editing of the cell execution number.I suggest that what's needed is a Python function to generate a model from a multi-line string:
This is almost as readable as the but should allow Notebooks to be run more flexibly and robustly. You'd loose the LaTeX rendering beneath the
%%model
magic cells but that seems redundant given thatMuMoTmodel.show()
produces a more attractive rendering of that information.Another advantage of allowing models to be generated by parsing a Python string is that it would make it easier to create models for unit testing outside Notebooks.
The text was updated successfully, but these errors were encountered: