Skip to main content

Parse MATPOWER case into pandas DataFrame.

Project description

MATPOWER Case Frames

PyPI version

Parse MATPOWER case into pandas DataFrame.

Unlike the tutorial on matpower-pip, this package supports parsing MATPOWER case using re instead of Oct2Py and Octave. After that, you can further parse the data into any format supported by your solver.

Installation

pip install matpowercaseframes

Usage

Read MATPOWER case by parsing file as string

The main utility of matpowercaseframes is to help read matpower data in user-friendly format as follows,

from matpowercaseframes import CaseFrames

case_path = 'case9.m'
cf = CaseFrames(case_path)

print(cf.gencost)

If you have matpower installed via pip install matpower (did not requires matpower[octave]), you can easily navigate matpower case using:

import os
from matpower import path_matpower # require `pip install matpower`
from matpowercaseframes import CaseFrames

case_name = 'case9.m'
case_path = os.path.join(path_matpower, 'data', case_name)
cf = CaseFrames(case_path)

print(cf.gencost)

Read MATPOWER case by running loadcase

In some cases, a case file may contain matlab code at the end of the file that needs to be executed. An example of such case is case69.m. To properly load this type of file, use the method recommended by matpower, which is using loadcase instead of parsing. To do this, use the load_case_engine parameter (requires matlab or octave), as demonstrated here:

from matpower import start_instance
from matpowercaseframes import CaseFrames

m = start_instance()

case_name = f"case69.m"
cf_lc = CaseFrames(case_name, load_case_engine=m)
cf_lc.branch  # see that the branch is already in p.u., converted by `loadcase`

Convert oct2py.io.Struct to CaseFrames

If you use matpower[octave], CaseFrames also support oct2py.io.Struct as input using:

from matpower import start_instance
from matpowercaseframes import CaseFrames

m = start_instance()

# support mpc before runpf
mpc = m.loadcase('case9', verbose=False)
cf = CaseFrames(mpc)
print(cf.gencost)

# support mpc after runpf
mpc = m.runpf(mpc, verbose=False)
cf = CaseFrames(mpc)
print(cf.gencost)

m.exit()

Convert CaseFrames to mpc

Furthermore, matpowercaseframes also support generating data that is acceptable by matpower via matpower-pip package (requires matlab or octave),

from matpower import start_instance
from matpowercaseframes import CaseFrames

case_path = 'case9.m'
cf = CaseFrames(case_path)
mpc = cf.to_mpc()  # identical with cf.to_dict()

m = start_instance()
m.runpf(mpc)

Add custom data

Sometimes, we want to expand matpower data containing custom field. For example, given an mpc.load as a dict, we can attach it to CaseFrames using,

from matpower import start_instance
from matpowercaseframes import CaseFrames

m = start_instance()

LOAD_COL = ["LD_ID", "LD_BUS", "LD_STATUS", "LD_PD", "LD_QD"]

mpc = m.loadcase('case9', verbose=False)
cf = CaseFrames(mpc)
cf.set_attribute_as_df('load', mpc.load, columns_template=LOAD_COL)

If data already in DataFrame, we can use setattr directly as follows,

from matpower import start_instance
from matpowercaseframes import CaseFrames

m = start_instance()

mpc = m.loadcase('case9', verbose=False)
cf = CaseFrames(mpc)
cf.set_attribute('load', df_load)

Export as xlsx

To save all DataFrame to a single xlsx file, use:

from matpowercaseframes import CaseFrames

case_path = 'case9.m'
cf = CaseFrames(case_path)

cf.to_excel('PATH/TO/DIR/case9.xlsx')

Acknowledgment

  1. This repository was supported by the Faculty of Engineering, Universitas Gadjah Mada under the supervision of Mr. Sarjiya. If you use this package for your research, we would be very glad if you cited any relevant publication under Mr. Sarjiya's name as thanks (but you are not responsible for citing). You can find his publications in the Semantic Scholar or IEEE.

  2. This repository is working flawlessly with matpower-pip. If you use matpower-pip, make sure to cite using the below citation:

    M. Yasirroni, Sarjiya, and L. M. Putranto, "matpower-pip: A Python Package for Easy Access to MATPOWER Power System Simulation Package," [Online]. Available: https://github.com/yasirroni/matpower-pip.

    M. Yasirroni, Sarjiya, and L. M. Putranto, "matpower-pip". Zenodo, Jun. 13, 2024. doi: 10.5281/zenodo.11626845.

    @misc{matpower-pip,
      author       = {Yasirroni, M. and Sarjiya and Putranto, L. M.},
      title        = {matpower-pip: A Python Package for Easy Access to MATPOWER Power System Simulation Package},
      year         = {2023},
      howpublished = {\url{https://github.com/yasirroni/matpower-pip}},
    }
    
    @software{yasirroni_2024_11626845,
      author       = {Yasirroni, Muhammad and
                        Sarjiya, Sarjiya and
                        Putranto, Lesnanto Multa},
      title        = {matpower-pip},
      month        = jun,
      year         = 2024,
      publisher    = {Zenodo},
      version      = {8.0.0.2.1.8},
      doi          = {10.5281/zenodo.11626845},
      url          = {\url{https://doi.org/10.5281/zenodo.11626845}},
    }
    
  3. This package is a fork and simplification from psst MATPOWER parser, thus we greatly thank psst developers and contributors.

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

matpowercaseframes-2.0.2.tar.gz (25.7 kB view details)

Uploaded Source

Built Distribution

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

matpowercaseframes-2.0.2-py3-none-any.whl (20.2 kB view details)

Uploaded Python 3

File details

Details for the file matpowercaseframes-2.0.2.tar.gz.

File metadata

  • Download URL: matpowercaseframes-2.0.2.tar.gz
  • Upload date:
  • Size: 25.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for matpowercaseframes-2.0.2.tar.gz
Algorithm Hash digest
SHA256 7b7749ed8721bcaa79a477f672eafd72bc3036a4a0699d8ab68694ad8383ad29
MD5 6e79ab70b13563fb46b338f528b28eea
BLAKE2b-256 c13f8a4fa17d291fdbd1e79ecac2bf767e0d3a1555e179deaaa25349ca56abb3

See more details on using hashes here.

File details

Details for the file matpowercaseframes-2.0.2-py3-none-any.whl.

File metadata

File hashes

Hashes for matpowercaseframes-2.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 4eebbb82659882c322d346d2acb38e047e401dba8c31ebd0040424eca977972c
MD5 b41799b5fa5a4f91b181c388a9d1544b
BLAKE2b-256 6446a2b6d645d44971db1173cafe6b8442b8f3794ff2b27bb46a2a6189c45f4d

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