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

Defining the CoreComponents, LayerStructure and ModelTiming classes #374

Merged
merged 40 commits into from
Feb 5, 2024
Merged
Changes from 1 commit
Commits
Show all changes
40 commits
Select commit Hold shift + click to select a range
685e42b
Draft implementation of CoreComponents
davidorme Jan 24, 2024
f5f6a20
Doc fixes
davidorme Jan 24, 2024
4a70211
Forgot to add new tests file
davidorme Jan 24, 2024
01fc628
Extending and fixing tests
davidorme Jan 24, 2024
9513801
Updating callable signatures to use CoreComponents - not unpacked yet.
davidorme Jan 25, 2024
45ac49a
Updating main to use CoreComponents
davidorme Jan 25, 2024
9a76bba
Unpacking core components into new BaseModel attributes
davidorme Jan 25, 2024
548c849
Revising docstrings
davidorme Jan 25, 2024
adaf95b
MoarRevising docstrings
davidorme Jan 25, 2024
b96e68e
Updating Plants Model
davidorme Jan 25, 2024
be73d57
Updating soils model
davidorme Jan 25, 2024
9f2c892
Updating litter model
davidorme Jan 25, 2024
42d8bbc
Updated hydrology_model
davidorme Jan 25, 2024
53153fd
Updated abiotic_simple_model
davidorme Jan 25, 2024
a5cd8bd
Added n_layers to LayerStructure
davidorme Jan 25, 2024
4359c6e
Use n_layers in models
davidorme Jan 25, 2024
03b5a81
Updated animal model
davidorme Jan 25, 2024
e17e368
Converted layer_roles from tuple to list - incompatible with xarray c…
davidorme Jan 25, 2024
f862264
AnimalModel loads wrong constants
davidorme Jan 25, 2024
b02d14a
Added Config and CoreComponents fixtures, updated fixtures using prev…
davidorme Jan 25, 2024
242fe2f
Removing test for deprecated extract_timing_details
davidorme Jan 25, 2024
e3c33a7
Updating plants tests to new BaseModel structure
davidorme Jan 25, 2024
086e53f
Potential solution to BaseModel._repr issue
davidorme Jan 25, 2024
a705be0
Updating soil tests
davidorme Jan 25, 2024
5d55541
Update litter model tests
davidorme Jan 25, 2024
388fc9f
Updating hydrology model tests
davidorme Jan 26, 2024
86c4c93
Updated abiotic_simple model tests
davidorme Jan 26, 2024
cb048e8
Restored BaseModel._check_update_speed functionality
davidorme Jan 26, 2024
e3181e9
Fixing core tests, log message tweaks
davidorme Jan 26, 2024
663d3c4
Deprecated input file location in tests
davidorme Jan 26, 2024
ce3396b
Updating animal model tests
davidorme Jan 26, 2024
127423e
Last test fixes
davidorme Jan 26, 2024
b1c9339
Cleaner start_time setting
davidorme Jan 26, 2024
53d820f
add _validate_canopy_layer function
davidorme Jan 26, 2024
849e651
add _validate_soil_layers function
davidorme Jan 26, 2024
162daa4
Updating core_component.py validators and adding unit tests for valid…
davidorme Jan 26, 2024
20fe796
Merge pull request #375 from ImperialCollegeLondon/369-adopting-new-core
davidorme Feb 2, 2024
42bd787
Indenting issue in RST
davidorme Feb 2, 2024
7443127
Fixing docstring issues
davidorme Feb 5, 2024
b4fb178
Merge branch 'develop' into 369-simplifying-the-model-creation-setup
davidorme Feb 5, 2024
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
Prev Previous commit
Next Next commit
Revising docstrings
  • Loading branch information
davidorme committed Jan 25, 2024
commit 548c8499ba47d2e8e6d209831dcd8aa1cdcfc6a2
63 changes: 30 additions & 33 deletions virtual_rainforest/core/base_model.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,20 +21,14 @@
and :meth:`~virtual_rainforest.core.base_model.BaseModel.__str__` special methods.

The :class:`~virtual_rainforest.core.base_model.BaseModel` has four class attributes
that must be defined in subclasses:

* The :attr:`~virtual_rainforest.core.base_model.BaseModel.model_name` attribute and
* The :attr:`~virtual_rainforest.core.base_model.BaseModel.required_init_vars`
attribute.
* The :attr:`~virtual_rainforest.core.base_model.BaseModel.model_update_bounds`
attribute
* The :attr:`~virtual_rainforest.core.base_model.BaseModel.vars_updated`
attribute


that must be specified as arguments to the subclass definition:
:attr:`~virtual_rainforest.core.base_model.BaseModel.model_name`,
:attr:`~virtual_rainforest.core.base_model.BaseModel.required_init_vars`,
:attr:`~virtual_rainforest.core.base_model.BaseModel.model_update_bounds` and
:attr:`~virtual_rainforest.core.base_model.BaseModel.vars_updated`.
The usage of these four attributes is described in their docstrings and each is
validated when a new subclass is create using the following private
methods of the class:
validated when a new subclass is created using the following private methods of the
class:
:meth:`~virtual_rainforest.core.base_model.BaseModel._check_model_name`,
:meth:`~virtual_rainforest.core.base_model.BaseModel._check_required_init_vars`,
:meth:`~virtual_rainforest.core.base_model.BaseModel._check_model_update_bounds` and
Expand All @@ -51,26 +45,32 @@
The ``BaseModel.__init__`` method
----------------------------------

The ``__init__`` method for subclasses **must** call the ``BaseModel``
:meth:`~virtual_rainforest.core.base_model.BaseModel.__init__` method as shown below.
This method carries out some core initialisation steps: see the method description for
details.
Each model subclass will include an ``__init__`` method that validates and populates
model specific attributes. That ``__init__`` method **must** call the ``BaseModel``
:meth:`~virtual_rainforest.core.base_model.BaseModel.__init__` method, as this populates
core shared model attrributes - see the linked method description for details.

.. code-block:: python

super().__init__(data, update_interval, start_time, **kwargs)
super().__init__(data, core_components)


The ``from_config`` factory method
----------------------------------

The ABC also defines the abstract class method
:func:`~virtual_rainforest.core.base_model.BaseModel.from_config`. This method must be
defined by subclasses and must be a factory method that takes a
:class:`~virtual_rainforest.core.data.Data` instance and a model specific configuration
dictionary and returns an instance of the subclass. For any given model, the method
should provide any code to validate the configuration and then use the configuration to
initialise and return a new instance of the class.
defined by subclasses and must be a factory method that returns an instance of the model
subclass. The method must follow the signature of that method, providing:

* ``data`` as an instance of :class:`~virtual_rainforest.core.data.Data`.
* ``core_components`` as an instance of
:class:`~virtual_rainforest.core.core_components.CoreComponents`.
* ``config`` as an instance of
:class:`~virtual_rainforest.core.config.Config`.

The method should provide any code to validate the configuration for that model and then
use the configuration to initialise and return a new instance of the class.

Model registration
------------------
Expand Down Expand Up @@ -170,16 +170,13 @@ def __init__(
):
"""Performs core initialisation for BaseModel subclasses.

This method should be called by the ``__init__`` method of all subclasses and
performs the following core steps:

* It populates the shared instance attributes
:attr:`~virtual_rainforest.core.base_model.BaseModel.data` and
:attr:`~virtual_rainforest.core.base_model.BaseModel.update_interval`.
* It uses the
:meth:`~virtual_rainforest.core.base_model.BaseModel.check_init_data`
to confirm that the required variables for the model are present in the
:attr:`~virtual_rainforest.core.base_model.BaseModel.data` attribute.
This method should be called by the ``__init__`` method of all subclasses. It
populates a set of core model attributes from the provided
:class:`~virtual_rainforest.core.core_components.CoreComponents` instance and
then uses the
:meth:`~virtual_rainforest.core.base_model.BaseModel.check_init_data` to
confirm that the required variables for the model are present in the provided
:attr:`~virtual_rainforest.core.base_model.BaseModel.data` attribute.
"""
self.data: Data = data
"""A Data instance providing access to the shared simulation data."""
Expand Down