This repository gathers the python resources developed to fetch and process the NordPool market data to prepare case file in Modelica, CIM 14, and PSS/E. The scripts in this repository have been used to generate case files for every hour of every day of 2015. The generated datasets are available at:
The dataset generation is documented in the paper below, see [Ref00].
We are happy to contribute with this repository, however, if you use any of the data or software provided, we will appreciate if you cite the following publications, as follows:
the raw and processed data files corresponding to the model are available as an open data set and documented in [Ref00]
.the model is first presented in [Ref01]
.[Ref00] L. Vanfretti, S.H. Olsen, V.S. Narasimham Arava, G. Laera, A. Bidadfar, T. Rabuzin, Sigurd H. Jakobsen, J. Lavenius, M. Baudette, F.J. Gómez-López, An open data repository and a data processing software toolset of an equivalent Nordic grid model matched to historical electricity market data, Data in Brief, Available online 13 February 2017, ISSN 2352-3409, [http://dx.doi.org/10.1016/j.dib.2017.02.021] (http://www.sciencedirect.com/science/article/pii/S2352340917300409). The final published article can be downloaded directly from the journal website, it is an open access journal.
[Ref01] L. Vanfretti, T. Rabuzin, M. Baudette, M. Murad, iTesla Power Systems Library (iPSL): A Modelica library for phasor time-domain simulations, SoftwareX, Available online 18 May 2016, ISSN 2352-7110, http://dx.doi.org/10.1016/j.softx.2016.05.001.
This work was originally developed in the context of the FP7 iTesla project, and further extended within the ITEA3 openCPS project.
The content of the repository can be installed using the following commands:
clone the repository:
git clone [email protected]:ALSETLab/Nordic44-Nordpool.git
install the scripts:
python setup.py install
The repository is organised as follows:
n44.py contains the Python class responsible for the mapping between Nord Pool data and the Nordic 44 PSS/E base case contained in the folder models
nordpool.py contains the Python class responsible for reading in Nord Pool market data to a dictionary. It supports to read in from both the ftp server and from excel files.
readraw.py contains the Python class responsible for reading in a Nordic 44 case from a raw file to Python dictionaries
torecord.py contains the Python class responsible for writing a Nordic 44 case contained in Python dictionaries to modelica records.
utilities.py contains utility functions. Most notibly is the function data_from_nordpool which can download market data from the Nord Pool ftp server and store it to, excel, raw files, and records.
PSSE_to_CIM14_batch.py is the Python script used for converting PSS/E files to CIM v14 files
data_set_from_excel.py example demonstrating how excel files can be read into Python and used to create raw PSS/E cases from the market data.
data_set_from_excel.py example demonstrating how one can download market data from the Nord Pool ftp server and construct PSSE/cases.
multiple_data_sets_from_nordpool.py example demonstrating how the utility function data_from_nordpool can be used to download multiple data sets from the ftp server and stored to both raw files and modelica records.
The scripts available in this repository are used in an ecosystem build by several software component developed / used at ALSETLab. The goal is to generate case files with the powerflow solution matching the data available from the electricity market dispatch.
Nordic44-Nordpool: A toolbox to extract powerflow data from Nordpool and prepare it for the ALSETLab N44 model.
Copyright (C) 2016 The authors:
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.