Skip to main content

Multi-regional Assessment of Technologies, Energy and Resources

Project description

MATER

Metabolic Analysis for Transdisciplinary Ecological Research

[TOC]

📋 Requirements

  • Python 3.12 or higher

We recommend using one virtual environment per Python project to manage dependencies and maintain isolation. You can use a package manager like uv to help you with library dependencies and virtual environments.

Quick start

Use init-mater-project (recommended).
It provides a complete project structure, CLI tools, and data pipeline in minutes.

💡 Direct MATER usage is only recommended for:

  • Custom integrations in existing codebases
  • Advanced users building specialized tools
  • Contributing to the MATER framework itself

Direct MATER usage

Install the mater package in your project via UV (recommended) or pip:

uv add mater
# Or
pip install mater

Example: Run a Simulation with an Excel file

Create a Python script in your working directory to run simulations. Ensure the required Excel input file (chose a compatible version) is located in the root of your working directory.

Create a file named simulate.py (or any name you prefer) with the following content:

"""
MATER simulation script.
"""

from mater import Mater

# === CONFIGURATION ===
INPUT_FILE = "your_file.xlsx"  # Name of your Excel input file
OUTPUT_FOLDER = "run0"  # Name of the folder where outputs are stored
START_TIME = 1901  # Initial time step
END_TIME = 2100  # Final time step
TIME_FREQUENCY = "YS"  # Time frequency
# === END CONFIGURATION ===


def main():
    """Run MATER simulation."""
    model = Mater()
    model.run_from_excel(
        OUTPUT_FOLDER,
        INPUT_FILE,
        simulation_start_time=START_TIME,
        simulation_end_time=END_TIME,
        time_frequency=TIME_FREQUENCY,
    )


if __name__ == "__main__":
    main()

To run your simulation:

  1. Edit the configuration values at the top of the script

  2. Save the file

  3. Execute the script:

uv run simulate.py

Output variables description

Output variable Unit Definition Example
control_flow <object_unit>/time Object footprint demand before trade between locations Number of cars consumed in China (included the imported ones)
extraneous_flow <object_unit>/time Object consumption or coproduction C02 coproduced (+ value) and coal consumed (- value) by the electricity production process of a coal power plant
in_use_stock <object_unit> Object in use stock Number of cars in use
old_stock <object_unit> Object stock in landfill Number of end of life cars unrecycled
process <process_unit>/time Number of process made by an object Transportation process (km/year) made by cars
recycling_flow <object_unit>/time Quantity of recycled objects Recycled end of life cars
reference_intensity_of_use <process_unit>/<object_unit>/time Intensity of use Number of km per year made by a car
reference_stock <object_unit> How many objects should be in the in use stock Installed power plant capacity to fulfill the electricity demand
secondary_production <object_unit>/time Coproduction due to recycling processes Quantity of steel recycled (coproduce by recycling) in a year
self_disposal_flow <object_unit>/time End of life flow Number of cars that cannot work anymore
traded_control_flow <object_unit>/time Object supply after trade between locations Number of cars produced in China (included the exported ones)

Accessing the Results from a Python Script

Below is an example Python script using pandas and matplotlib to plot specific simulation results. Each folder in the output directory corresponds to a variable that can be loaded with pandas.

# Import the MATER package and matplotlib.pyplot
import matplotlib.pyplot as plt
from mater import Mater

# Create a Mater instance
model = Mater()

# Select the output directory where the run results are stored
model.set_output_dir()  # Defaults to the working directory

# Set the run directory name
model.set_run_name("run0")

# Get a variable
in_use_stock = model.get("in_use_stock")

# Transform the dataframe and plot the results
in_use_stock.groupby(level=["location", "object"]).sum().T.plot()
plt.show()

This example demonstrates how to access and plot variables from simulation outputs. Adjust the code to fit your analysis needs.

🤝 Contributing

We welcome contributions to the MATER project! To get started, please refer to the CONTRIBUTING file for detailed guidelines.

📚 Online Documentation

For more information, refer to the official MATER documentation.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mater-0.14.2.tar.gz (705.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mater-0.14.2-py3-none-any.whl (40.0 kB view details)

Uploaded Python 3

File details

Details for the file mater-0.14.2.tar.gz.

File metadata

  • Download URL: mater-0.14.2.tar.gz
  • Upload date:
  • Size: 705.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.11 {"installer":{"name":"uv","version":"0.9.11"},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mater-0.14.2.tar.gz
Algorithm Hash digest
SHA256 31de579b2f9c4a43458896754472270c3a2b7a06d8a2dc6f2b08762c111fb1b7
MD5 7c217c88814a5f8c2caa5a6dd82a934b
BLAKE2b-256 7792ed39ce88fb40caf78cbfdac5fbaf0058b6b9bb818a72ef5593763894b95c

See more details on using hashes here.

File details

Details for the file mater-0.14.2-py3-none-any.whl.

File metadata

  • Download URL: mater-0.14.2-py3-none-any.whl
  • Upload date:
  • Size: 40.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.11 {"installer":{"name":"uv","version":"0.9.11"},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mater-0.14.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1e3a0d08527ca30749dc9a9bf96e2f1159eb788926196d154a5779bd4d0ad73a
MD5 2e6b7429f1ff4f8062ce4b5bbb7eab0e
BLAKE2b-256 bd71da60beeffec8cfc4916a0d3228a280125eb2d8ab5184379c4da7d125002c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page