Skip to main content

A simulator for pandapower grids.

Project description

MIDAS Powergrid Simulator

Description

This package contains a MIDAS module providing a pandapower simulator and a number of custom powergrids.

Although this package is intended to be used with MIDAS, it does not depend from anything MIDAS-related except for the midas-util package. You can use in any mosaik simulation scenario.

Installation

This package will usually installed automatically together with midas-mosaik. It is available on pypi, so you can install it manually with

pip install midas-powergrid

Usage

The complete documentation is available at https://midas-mosaik.gitlab.io/midas.

Inside of MIDAS

To use the powergrid inside of MIDAS, just add powergrid to your modules

my_scenario:
  modules:
    - powergrid
    - ...

and configure it with (gridfile is required, everything else is optional and can be left out if the default values, shown below, are used):

  powergrid_params:
    my_grid_scope:
      gridfile: midasmv
      grid_params: {}
      step_size: 900
      plotting: False
      plot_path: _plots # Output path defined in runtime config
      save_grid_json: False

All simulators that want to connect to this grid, will have to use my_grid_scope as their grid_name value. Activating the plotting will results in a considerably longer execution time. Activate it only if you really need this feature.

The gridfile can be either a path to a .json or .xlsx file, a simbench grid code, one of cigre_hv, cigre_mv, cigre_lv, midasmv, midaslv, or bhv, or an import path to a function or class that either returns a valid pandapower grid or is a pandapower grid itself. The grid_params can be used to pass keywork arguments to custom grids.

Any mosaik scenario

If you don't use MIDAS, you can add the powergrid manually to your mosaik scenario file. First, the entry in the sim_config:

sim_config = {
    "Powergrid": {"python": "midas_powergrid.simulator:PandapowerSimulator"},
    # ...
}

Next, you need to start the simulator (assuming a step_size of 900):

powergrid_sim = world.start("Powergrid", step_size=900, plotting=False, plot_path="path/to/store/plots")

Finally, the model needs to be started:

powergrid = powergrid_sim.Grid(gridfile="midasmv", grid_params={})

To connect the output of the grids' buses to another model, you have to get the list of bus models from the powergrids' children like

bus_models = [e for e in powergrid.children if "bus" in e.eid]

and then connect those models either individually or in a loop, e.g.,

for bus in bus_models:
    world.connect(bus, other_entity, "vm_pu", "va_degree", "p_mw", "q_mvar")

The inputs are generally handled in the same way. Have a look at powergrid.children to get the required entity eids.

License

This software is released under the GNU Lesser General Public License (LGPL). See the license file for more information about the details.

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

midas_powergrid-2.0.0a5.tar.gz (42.0 kB view details)

Uploaded Source

Built Distribution

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

midas_powergrid-2.0.0a5-py3-none-any.whl (48.4 kB view details)

Uploaded Python 3

File details

Details for the file midas_powergrid-2.0.0a5.tar.gz.

File metadata

  • Download URL: midas_powergrid-2.0.0a5.tar.gz
  • Upload date:
  • Size: 42.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.9

File hashes

Hashes for midas_powergrid-2.0.0a5.tar.gz
Algorithm Hash digest
SHA256 b0a44c2d003244e7a6e7caec2598921497973314bb0e0f6c0557844fab857caa
MD5 df9418fbe912c7a98be4e4687b02de26
BLAKE2b-256 53acd4bc8ff695bd017738b69d0f2cefc9ffc6621767ad585abe629e85f40b5e

See more details on using hashes here.

File details

Details for the file midas_powergrid-2.0.0a5-py3-none-any.whl.

File metadata

File hashes

Hashes for midas_powergrid-2.0.0a5-py3-none-any.whl
Algorithm Hash digest
SHA256 f8ec90fdc8829fe49f2e2a3b39b1c0b58568cb30fd773a503105a6c057d37b20
MD5 9a6ee0222cc355412c25552f5d41217f
BLAKE2b-256 57789e2023f17420daa1e49138b86a1d839274ee82315432f88e45906fe32cc3

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