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

Issue 3361 - Improve print_parameter_info functionality #3584

Merged
merged 18 commits into from
Dec 16, 2023
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
18 commits
Select commit Hold shift + click to select a range
562815b
Added "parameter_info" and modified "print_parameter_info"
cringeyburger Nov 29, 2023
d9a1d94
Added docstrings and exception handling to parameter_info and print_p…
cringeyburger Dec 3, 2023
b86f58c
Added Issue 3361 to features' section of CHANGELOG.md
cringeyburger Dec 3, 2023
e2f8a43
Implemented "get_parameter_info" to return a dictionary of parameters…
cringeyburger Dec 5, 2023
d38a8b5
Improved readability
cringeyburger Dec 5, 2023
6bcc50c
Added docstrings and modified "get_parameter_info" to store the entir…
cringeyburger Dec 6, 2023
5fb4ed2
Implemented a parameter table to print parameter info, from"print_par…
cringeyburger Dec 6, 2023
01723a5
parameter table size optimisation and code formatting
cringeyburger Dec 7, 2023
292086d
Made the parameter table dynamic and modified docstrings of "get_para…
cringeyburger Dec 7, 2023
3ab36c0
Added "get_parameter_info" and modified information about "print_para…
cringeyburger Dec 7, 2023
9c46caf
Merge branch 'develop' into issue-3361-improve-print_parameter_info-f…
cringeyburger Dec 7, 2023
0da48b2
Update pybamm/models/base_model.py
valentinsulzer Dec 7, 2023
af26526
Modified "get_parameter_info" and "print_parameter_info" to store and…
cringeyburger Dec 10, 2023
1618199
Merge remote-tracking branch 'origin/issue-3361-improve-print_paramet…
cringeyburger Dec 10, 2023
5ccd185
Modified "get_parameter_info" and "print_parameter_info" to store and…
cringeyburger Dec 10, 2023
d365023
Updated all instances of "_parameter_info" with "get_parameter_info" …
cringeyburger Dec 10, 2023
53bedfd
Merge branch 'develop' into issue-3361-improve-print_parameter_info-f…
cringeyburger Dec 10, 2023
55a70da
Style and docstring modifications
cringeyburger Dec 12, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
## Features

- Serialisation added so models can be written to/read from JSON ([#3397](https://github.com/pybamm-team/PyBaMM/pull/3397))

- Created "parameter_info" method and modified "print_parameter_info" to extract all parameters and print out required ones. ([#3361](https://github.com/pybamm-team/PyBaMM/issues/3361))
cringeyburger marked this conversation as resolved.
Show resolved Hide resolved
## Bug fixes

- Fixed a bug where simulations using the CasADi-based solvers would fail randomly with the half-cell model ([#3494](https://github.com/pybamm-team/PyBaMM/pull/3494))
Expand Down
33 changes: 17 additions & 16 deletions pybamm/models/base_model.py
Original file line number Diff line number Diff line change
Expand Up @@ -421,30 +421,31 @@ def input_parameters(self):
self._input_parameters = self._find_symbols(pybamm.InputParameter)
return self._input_parameters

def print_parameter_info(self):
self._parameter_info = ""
def get_parameter_info(self):
cringeyburger marked this conversation as resolved.
Show resolved Hide resolved
parameter_info = []
parameters = self._find_symbols(pybamm.Parameter)
for param in parameters:
self._parameter_info += f"{param.name} (Parameter)\n"
parameter_info.append((param.name, "Parameter"))
cringeyburger marked this conversation as resolved.
Show resolved Hide resolved

input_parameters = self._find_symbols(pybamm.InputParameter)
for input_param in input_parameters:
if input_param.domain == []:
self._parameter_info += f"{input_param.name} (InputParameter)\n"
if not input_param.domain:
parameter_info.append((input_param.name, "InputParameter"))
else:
self._parameter_info += (
f"{input_param.name} (InputParameter in {input_param.domain})\n"
)
parameter_info.append((input_param.name, f"InputParameter in {input_param.domain}"))

function_parameters = self._find_symbols(pybamm.FunctionParameter)
for func_param in function_parameters:
# don't double count function parameters
if func_param.name not in self._parameter_info:
input_names = "'" + "', '".join(func_param.input_names) + "'"
self._parameter_info += (
f"{func_param.name} (FunctionParameter "
f"with input(s) {input_names})\n"
)
if func_param.name not in [name for name, _ in parameter_info]:
input_names = "', '".join(func_param.input_names)
parameter_info.append((func_param.name, f"FunctionParameter with inputs(s) '{input_names}'"))

return parameter_info

print(self._parameter_info)
def print_parameter_info(self):
cringeyburger marked this conversation as resolved.
Show resolved Hide resolved
info = self.get_parameter_info()
for param, param_type in info:
print(f"{param} ({param_type})")

def _find_symbols(self, typ):
"""Find all the instances of `typ` in the model"""
Expand Down