Skip to content

miguelriosocampo/openMASTER_ResMod

 
 

Repository files navigation

The open-source Model for the Analysis of SusTainable Energy Roadmaps (openMASTER)

The openMASTER model has been developed at the Instituto de Investigación Tecnológica (IIT) of the Universidad Pontificia Comillas.

Developers

Member Username Tasks
Antonio F. Rodríguez Matas @afrmatas Developer
Manuel Pérez Bravo @mperezbravo Developer

Table of Contents

Description

openMASTER is a Pyomo-based model designed for sustainable energy policy analysis. It operates as a dynamic, bottom-up, partial equilibrium, linear programming (LP) model, with the primary objective of meeting externally-given energy services demand across various sectors. It achieves this by adhering to technical and policy constraints while minimizing a comprehensive objective function. This function encompasses the total economic costs of energy supply, the social costs associated with greenhouse gas emissions and pollutant releases, as well as intangible costs such as discomfort.

It is structured according to a scheme of processes and flows, which encompasses the entire energy sector, including the import and domestic consumption of primary energy, energy conversion and storage technologies for final energy production, energy services supply technologies, and the exogenous demand for energy services from various sectors of the economy.

It determines optimal roadmaps that satisfy simultaneously several attributes. Its main contributions are:

  • Dynamic planning: the scope of the model corresponds to several periods (years) at a long-term horizon, 2030 to 2050 for example.

  • Technological granularity: the model considers the vintage of end-use technologies. This approach facilitates the representation of technological innovation, including learning curves for efficiency improvements and emissions reductions. Consequently, improvements in vehicle emission standards or household appliance efficiency, among others, can be incorporated along with a detailed definition of technology decommissioning over their lifecycle.

  • Exogenous demand of energy services: the model introduces all exogenous demand in the form of energy services, allowing for the implementation of energy efficiency measures and emissions reduction through the investment and operation of end-use technologies. In this regard, it also enables modal shifts in transportation, a crucial aspect for effective decarbonization of this sector.

  • Endogenous behavioural changes: the model introduces behavioural changes in an endogenous and linear manner. This approach allows the model to determine optimal agent behaviour considering intangible costs such as discomfort, as well as to assess trade-offs, as occurs in the case of remote work, where mobility demand is reduced at the cost of an increase in domestic energy consumption.

  • Non-energy raw material consumption and circular economy in the industrial sector: the industrial sector is also represented, like all other sectors, on the basis of the demand for energy services (in this case, production of tons of materials). This not only facilitates modelling the reduction in material consumption through recycling but also energy and emissions savings through less energy-intensive processes.

The objective function, which represents the costs of the energy sector, includes:

  1. the domestic consumption and import of primary energy (PE)
  2. fixed and variable O&M costs of conversion technologies (CE)
  3. the cost of raw materials (RM) consumed by industrial supply technologies (ST)
  4. fixed and variable O&M costs of supply technologies (ST)
  5. the investment cost of new conversion technology capacity (CE)
  6. the cost of reactivating hibernated capacity of conversion technologies (CE)
  7. the investment cost of new supply technology capacity (ST)
  8. the penalty cost of slack variables, which include unsupplied energy services (ESNS), as well as exceeding emission caps and carbon budget constraints
  9. the cost of agents’ behavioural measures, including both economic costs (such as housing insulation) and intangible costs (such as discomfort).

The model formulates an optimization problem including investment (installation/decommission capacity), operation (generation and storage) and behavioural decisions. The model considers electricity generation reliability constraints, technological and modal choice constraints, and emission caps and carbon budget constraints.

The main results of the model can be structured in these topics:

  • Investment: installation and decommission decisions on the capacity for Conversion Energy Technologies (CE) and Supply Technologies (ST); hibernation and reactivation decisions on the capacity for Conversion Energy Technologies (CE)
  • Operation: primary energy consumption (imports and domestic consumption), final energy generation and storage, energy services supplied, ESNS, etc.
  • Emissions: CO2 and pollutants (NOx, SOx and PM 2.5) emissions
  • Behavioural changes: change in energy services demand due to agents' behavioural changes
  • Economic: investment, operation and behavioural changes costs

Results are shown in CSV files and graphical plots. An interactive Dashboard is available, as well as a Sankey Diagram generator tool.

A careful implementation has been done to avoid numerical problems by scaling parameters, variables and equations of the optimization problem allowing the model to be used for large-scale cases.

The mathematical formulation can be found in this document, and an overview of the model structure is captured in this diagram.

Installation

openMASTER package can be installed from its GitHub repository following these steps:

  1. Clone the openMASTER repository, which includes the folder structure and all necessary functions to run the model.
  2. Launch the command prompt (Windows: Win+R, type "cmd", Enter).
  3. Set up the path to where the repository was cloned, using cd "C:\Users<username>...\openMASTER".
  4. Create a virtual environment using conda or another tool like the built-in package venv or virtualenv. This option is not mandatory but highly recommended so you don't mess things up with the Python on your system. You can skip this part if you already have one for this project. Notice that the minimum Python version tested to use openMASTER is 3.10.
python -m venv .venv
  1. Activate your virtual environment (Skip this step if you decide to skip step 4).
.venv\Scripts\activate
  1. Install openMASTER via pip by pip install .. The openMASTER package is contained in this repository, locally. Please note that the openMASTER package has optional dependencies for the graphic tools included to visualize results. To install these optional dependencies, it can also be done via pip by pip install .[graphicTool]. Additionally, it's essential to have Jupyter Notebook installed as it is required for running the notebooks. If you don't have it installed already, you will need to install it via pip install notebook.
  2. Be aware the openMASTER_Data.xlsx file has to be downloaded using git-lfs or directly with this link.

Solvers

GLPK As an easy option for installation, we have the free and open-source GLPK solver. However, it takes too much time for large-scale problems. It can be installed using: conda install -c conda-forge glpk.

CBC The CBC solver is our recommendation if you want a free and open-source solver. For Windows users, the effective way to install the CBC solver is downloading the binaries from this link, copy and paste the cbc.exe file to the PATH that is the "bin" directory of the Anaconda or Miniconda environment. It can be installed using: conda install -c conda-forge coincbc.

Gurobi Another recommendation is the use of Gurobi solver. However, it is a commercial solver but more powerful than GPLK and CBC for large-scale problems. As a commercial solver, it needs a license that is free of charge for academic usage by signing up on Gurobi webpage. It can be installed using: conda install -c gurobi gurobi and then ask for an academic or commercial license. Activate the license on your computer using the grbgetkey command (you need to be in the university domain if you are installing an academic license).

Mosek Another alternative is the Mosek solver. Note that it is a commercial solver and you need a license for it. Mosek is a good alternative to deal with QPs, SOCPs, and SDPs problems. You only need to use conda install -c mosek mosek for installation and request a license (academic or commercial). To request the academic one, you can request here. Moreover, Mosek brings a license guide. But if you request an academic license, you will receive the license by email, and you only need to locate it in the following path C:\Users\(your user)\mosek in your computer.

Get started

By forking and cloning the openMASTER repository, you can create branches and propose pull-requests. Any help will be very appreciated. We suggest the use of Gurobi (for Academics and Researchers) as a solver to deal with LP problems instead of GLPK.

Quickstart guide

The openMASTER repository provides a quickstart guide (in the form of a Jupyter notebook) for new users to run their first case with the model. This quickstart guide is under the notebooks folder, named quickstart_openMASTER.ipnyb. Before running the cells in this notebook, it is advisable to:

  1. Create and activate a virtual environment in the system command prompt on which the dependencies will be installed. To do so, please follow the instructions detailed in the Python Documentation. This virtual Python environment will not affect the Python version or packages installed in the machine being used and will avoid incompatibilities between versions of packages being used in openMASTER.
  2. Install the openMASTER packages following the instructions hereby detailed.
  3. Please follow the order of cells in this notebook to create the abstract model, load a DataPortal, solve the instance, and save the model results.

Scenarios management

The user can create scenarios using the functionality provided by openMASTER. A scenario is defined in openMASTER as a set of inputs which will create a specific output. To help the user keep track of different runs of the model, this functionality creates a new folder within the /scenarios folder in the local clone of the repository. This folder contains a copy of the code used to run the scenario, as well as all the inputs and outputs for future use and development. To use this functionality of the model, please follow the notebook scenarios_from_results.ipynb.

Visualization of results

openMASTER also provides the user with visualization tools for the results obtained with the model, among which:

  • Visualization of results in a Dashboard: openMASTER facilitates the visualization of the main results by means of a dashboard in which several charts are presented. In this dashboard tool, the user can interact with the results by selecting different scenarios, zooming into the timeframes of interest, etc. The data for these charts are imported from the scenarios created by the user, for that reason it is important to first create a result scenario after each run (see above). The steps to follow are:

    1. Run the model and create a scenario (see Scenarios management) after every run.
    2. Run the index.py file within the folder Dashboard\app.
    3. A local server will be raised, and its localhost address will be shown on the command prompt window. Please follow this address on your explorer to visualize these results dashboard.
  • Creation of charts from templates: Within the folder Charts, the user will find Python functions to create basic charts (pie, bar, and area charts), as well as Sankey diagrams of energy flows resulting from the model. Although the functions to create these charts are available in separate Python files, two Jupyter notebooks are also provided to facilitate their use. The notebook scenario_charts.ipnynb guides the creation of the more basic charts from different variables within the model, such as pie charts of primary energy use, bar charts of renewable power installed, etc. On the other hand, the notebook scenario_sankey.ipynb guides the creation of Sankey diagrams, which implies the intermediate step of creating nodes and flows in a .json file.

Expected results

Alt text

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 67.4%
  • Jupyter Notebook 32.6%