diff --git a/doc/api/util.rst b/doc/api/util.rst index cc5cca3759..e4662a4048 100644 --- a/doc/api/util.rst +++ b/doc/api/util.rst @@ -101,9 +101,9 @@ Commonly used: A Context instance always has the following members: - 1. :attr:`core``: an instance of :class:`message_ix_models.Config`. - 2. :attr:`model``: an instance of :class:`message_ix_models.model.Config`. - 3. :attr:`report``: an instance of :class:`message_ix_models.report.Config`. + 1. :attr:`core`: an instance of :class:`message_ix_models.Config`. + 2. :attr:`model`: an instance of :class:`message_ix_models.model.Config`. + 3. :attr:`report`: an instance of :class:`message_ix_models.report.Config`. Attributes of (1) and (2) **may** be accessed by shorthand/aliases. For instance, :py:`context.regions` is an alias for :py:`context.model.regions`. @@ -215,3 +215,11 @@ Commonly used: .. automodule:: message_ix_models.util.sdmx :members: + +:mod:`.types` +============= + +.. currentmodule:: message_ix_models.types + +.. automodule:: message_ix_models.types + :members: diff --git a/doc/pkg-data/codelists.rst b/doc/pkg-data/codelists.rst index 831ac89808..bde8998d54 100644 --- a/doc/pkg-data/codelists.rst +++ b/doc/pkg-data/codelists.rst @@ -25,6 +25,8 @@ These codes have the following annotations: .. literalinclude:: ../../message_ix_models/data/commodity.yaml :language: yaml +.. _emission-yaml: + Emission species (:file:`emission.yaml`) ======================================== diff --git a/doc/whatsnew.rst b/doc/whatsnew.rst index 2ad9f7cc4c..ceb66beb71 100644 --- a/doc/whatsnew.rst +++ b/doc/whatsnew.rst @@ -7,6 +7,7 @@ Next release - :mod:`message_ix_models` is tested and compatible with `Python 3.13 `__ (:pull:`250`). - Support for Python 3.8 is dropped (:pull:`250`), as it has reached end-of-life. - Expand :doc:`repro` with sections on :ref:`repro-doc` and :ref:`versioning`, including :ref:`a list of external model names and ‘versions’ ` like “MESSAGEix-GLOBIOM 2.0” (:issue:`224`, :pull:`226`). +- New code list :ref:`emission-yaml` (:pull:`225`). By topic: @@ -23,7 +24,23 @@ Materials Transport --------- -- Update :doc:`/transport/index` (:pull:`213`). +- Update :doc:`/transport/index` (:pull:`213`, :pull:`225`). +- Rework :mod:`~.transport.freight`, :mod:`~.transport.ldv`, and :mod:`~.transport.non_ldv` to use :mod:`genno` consistently. +- Adopt consistent terms "F RAIL" and "F ROAD" for freight service/modes. +- New technologies: "f rail {electr,lightoil}", "f road electr". +- Extend unit annotations to all transport commodities. +- New input :doc:`files ` :file:`pdt-cap.csv` and :file:`load-factor-ldv.csv`. +- Add :program:`mix-models ssp transport` CLI command to postprocess aviation emissions data. +- New SDMX Codelist ``IIASA:CL_TRANSPORT_SCENARIO`` to distinguish “Low energy demand (LED)” and :doc:`/project/edits` scenarios from :doc:`/project/ssp` baseline scenarios. +- Adjust R12 baseline settings: + + - :file:`mode-share/default.csv`: adjust ``R12_NAM`` values for AIR and LDV. + - :file:`pdt-cap-ref.csv`: adjust ``R12_NAM`` value. +- Implement LED scenarios via :file:`load-factor-ldv.csv` and :file:`pdt-cap.csv`. +- Use y=2019 data from IEA EWEB 2024 edition to align MESSAGEix-Transport with base model calibration. +- New :mod:`genno` operators: :func:`~.transport.operator.broadcast`, :func:`~.transport.operator.broadcast_wildcard`, :func:`~.transport.operator.broadcast_t_c_l`, :func:`~.transport.operator.freight_usage_output`. +- New utility methods :func:`~.transport.config.get_cl_scenario`, :func:`~.transport.util.wildcard`. +- Replace :class:`DataSourceConfig.LDV <.transport.config.DataSourceConfig>` setting with :attr:`Config.dummy_LDV <.transport.config.Config.dummy_LDV>`. Water/Nexus ----------- @@ -50,6 +67,39 @@ Others - Add "LED", "SSP4", and "SSP5" as values for the :program:`--ssp=…` option in :func:`.common_params` (:pull:`233`). - Add :doc:`/project/circeular` project code and documentation (:pull:`232`). +- :mod:`.iea.web` handles the 2024 edition and fixed-width file format published by the IEA directly (:pull:`225`). + + - Code lists for the ``COUNTRY``, ``FLOW``, and ``PRODUCT`` concepts are included with :mod:`message_ix_models`. + - Add :data:`~.iea.web.COUNTRY_NAME` to map particular labels appearing in these data. + - Fuzzed data and tests for this functionality. + +- Add :any:`.types.ParameterData` and :any:`.types.MutableParameterData` to type the common internal data structure in which a :class:`dict` maps from MESSAGE parameter names to :mod:`message_ix`-structured :class:`pandas.DataFrame` (:pull:`225`). +- :class:`message_ix_models.Config`—the “core” configuration class—gains methods specific to its settings (:pull:`225`). + These were formerly on :class:`.Context`. +- :class:`.Context` is no longer a subclass of :class:`dict` (:pull:`225`). + This avoids its mishandling by :mod:`dask` version 2024.11.0 or later when Context is used with :class:`ixmp.Reporter`. + + - Add :data:`.MODULE_WITH_CONFIG_DATACLASS`; + add attributes such as :attr:`.Context.model` that are typed to the respective class such as :class:`.model.Config`. + - Add :meth:`.Context.asdict` for serialization. + - Former methods such as :meth:`.Context.get_scenario` are aliased to their new locations, e.g. :meth:`.Config.get_scenario`. + +- Improve :class:`.ScenarioInfo` (:pull:`225`): + + - Implement the :py:`|` (logical OR/union) operator: `si_a | si_b` is a new ScenarioInfo instance with the union of the contents of the operands. + - New method :meth:`.substitute_codes` to replace string codes (for instance, determined from a Scenario object) with Codes from the corresponding code list, including all annotations. + +- :class:`.MappingAdapter` skips missing labels in the input data without raising an exception (:pull:`225`). +- :meth:`.Workflow.visualize` displays in left-to-right rank direction by default (:pull:`225`). +- :func:`.convert_units` can handle MESSAGE-scheme :class:`pandas.DataFrame` (:pull:`225`). +- :func:`.util.sdmx.make_enum` uses :class:`.URNLookupEnum` by default (:pull:`225`). + This allows to call, for instance, :py:`SSP_2024.by_urn("…Code=ICONICS:SSP(2024).2")` to retrieve an enumeration number. +- :func:`.make_matched_dfs` accepts :class:`dict` for its :py:`par_value` arg, allowing replacement of values for particular dimensions of output data frames (:pull:`225`). +- New reporting operator :func:`.quantity_from_iamc` (:pull:`225`). +- :func:`.same_node` and :func:`.same_time` can handle :any:`.ParameterData` (:pull:`225`). +- :func:`.report.register` becomes :meth:`.report.Config.register` which populates :attr:`.report.Config.callback` (:pull:`225`). + The set of callback functions used to configure a class:`.Reporter` instance is thus now particular to a :class:`.report.Config` instance attached to a :class:`.Context` instance. + This allows better isolation of code/tests that use different sets of callbacks. v2024.8.6 ========= diff --git a/message_ix_models/project/ssp/structure.py b/message_ix_models/project/ssp/structure.py index 0119f3f410..966038c8c5 100644 --- a/message_ix_models/project/ssp/structure.py +++ b/message_ix_models/project/ssp/structure.py @@ -183,5 +183,8 @@ def generate(context: "Context", base_dir: Optional["PathLike"] = None): write(cl, base_dir) +#: Enumeration of codes for SSP 2017 edition. SSP = SSP_2017 = make_enum("ICONICS:SSP(2017)") + +#: Enumeration of codes for SSP 2024 edition. SSP_2024 = make_enum("ICONICS:SSP(2024)") diff --git a/message_ix_models/report/config.py b/message_ix_models/report/config.py index 569ae80e6f..cbc8aedcaf 100644 --- a/message_ix_models/report/config.py +++ b/message_ix_models/report/config.py @@ -59,13 +59,13 @@ class Config(ConfigHelper): #: #: from message_ix.report import Reporter #: from message_ix_models import Context - #: from message_ix_models.report import register #: #: def cb(rep: Reporter, ctx: Context) -> None: #: # Modify `rep` by calling its methods ... #: pass #: - #: context.report.register(cb) + #: # Register this callback on an existing Context instance + #: context.report.register(cb) callback: list[Callback] = field(default_factory=_default_callbacks) #: Path to write reporting outputs when invoked from the command line. diff --git a/message_ix_models/report/operator.py b/message_ix_models/report/operator.py index afaf6a4004..653bad0cfb 100644 --- a/message_ix_models/report/operator.py +++ b/message_ix_models/report/operator.py @@ -38,6 +38,7 @@ "make_output_path", "model_periods", "nodes_ex_world", + "quantity_from_iamc", "remove_ts", "share_curtailment", ] diff --git a/message_ix_models/util/context.py b/message_ix_models/util/context.py index f47ad19ab1..ee8e223b5b 100644 --- a/message_ix_models/util/context.py +++ b/message_ix_models/util/context.py @@ -180,14 +180,17 @@ def set(self, key: str, value: Any) -> None: # These SHOULD include all the keys from MODULE_WITH_CONFIG_DATACLASS @property def core(self) -> "message_ix_models.util.config.Config": + """An instance of :class:`.util.config.Config`.""" return self._values["core"] @property def model(self) -> "message_ix_models.model.config.Config": + """An instance of :class:`.model.config.Config`.""" return self._values["model"] @property def report(self) -> "message_ix_models.report.config.Config": + """An instance of :class:`.report.config.Config`.""" return self._values["report"] # Dict-like behaviour