Skip to main content

Open-source Distributed Energy Resources (DER) Model that represents IEEE Standard 1547-2018 requirements for steady-state and dynamic analyses

Project description

Open-source Distributed Energy Resources (OpenDER) Model

EPRI’s OpenDER model aims to accurately represent steady-state and dynamic behaviors of inverter-based distributed energy resources (DERs). The model follows interconnection standards or grid-codes and is informed by the observed behaviors of commercial products. Currently, model version 2.0 includes photovoltaic (PV) and battery energy storage system (BESS) DER behaviors according to the capabilities and functionalities required by the IEEE standard 1547-2018. This first-of-its-kind model can be used to run snapshot, Quasi-Static Time Series (QSTS), and a variety of dynamic analyses to study the impacts of DERs on distribution operations and planning.

This project is licensed under the terms of the BSD-3 clause license.

Resources

OpenDER is under active development. Use the following resources to get involved.

  • EPRI OpenDER homepage (link)

  • Model specification: IEEE 1547-2018 OpenDER Model: Version 2.0, EPRI, Palo Alto, CA: 2022. 3002025583 (link)

Development Objective

  • Harmonize accurate interpretations of the IEEE Std 1547-2018 DER interconnection standard among all the stakeholders, including utilities, distribution analysis tool developers, and original equipment manufacturers (OEMs).

  • Build consensus through an open-to-all DER Model User’s Group (DERMUG), which will utilize EPRI developed model specifications and codes and provide feedback for continuous improvement of the OpenDER model.

  • Help the industry properly model the DERs that are (or to be) grid interconnected and evaluate the associated impacts on distribution circuits accurately.

Overall Block Diagram

https://raw.githubusercontent.com/epri-dev/OpenDER/develop_req_SQA/docs/blockdiagram.png

Dependencies

Python >= 3.7

numpy

pandas

matplotlib

Dependencies of the package are auto-installed by pip command below.

Installation

pip install opender

Example of Using the DER Model

Example script: main.py

This example generate DER output power in a dynamic simulation to demonstrate DER trip and enter service behavior. The grid voltage is set to be alternating between 1 and 1.11 per unit every ~10 minutes. DER should be observed to enter service and trip periodically.

Other examples can be found in the Examples directory. Click the .ipynb files to see example scripts and execution results.

Unit tests

Dependency: pytest

Execution command: pytest path-to-package\tests

Changelog

2.1.3 (2023-12-05)

  • Add a property for SoC of BESS DER using .bess_soc

  • Automatically update the reactive capability curve if nameplate parameter is modified (when user defined curve is not provided)

2.1.2 (2023-08-23)

  • Fixed an issue for BESS parameter initialization

2.1.1 (2023-08-18)

  • Fixed an issue on voltage source output when zero sequence voltage is present

  • Corrected single phase DER voltage measurement

2.1.0 (2023-05-29)

  • Updated interaction between enter service ramp and ride-through. Now DER returns to enter service ramp after ride-through

  • Added an optional charge/discharge ramp rate limit for BESS DER

  • Added resets for all grid-support functions when DER is tripped

2.0.3 (2023-04-14)

  • Fixed the option to update BESS DER parameter when creating the object.

  • Fixed a bug when initializing a BESS DER during abnormal frequency condition.

2.0.2 (2023-04-03)

  • Fixed a bug abnormal operation category (NP_ABNORMAL_OP_CAT) only accepts uppercase values

  • Updated ride-through performance to better represent actual inverter’s behavior

  • Added an option to update DER parameter when creating the object.

2.0.1 (2023-03-21)

  • Fixed a bug where enter service randomized enter delay does not behave as expected

  • Fixed a bug where momentary cessation does not behave as expected

2.0.0 (2023-03-20)

  • Changed all units of nameplate rating to the base unit Watt/var/VA, from kW/kvar/kVA in Version 1.0.

  • Added one time delay feature to represent the DER active and reactive grid support functions’ reaction time, and a first order lag for in applicable voltage measurement.

  • Added Battery Energy Storage System (BESS) DER specific functions including State-of-Charge (SOC) calculation, and their corresponding model input parameters.

  • Updated applicable smart inverter functions to consider BESS DER behaviors, including volt-watt, active power limit, and watt-var functions.

  • Changed the DER operation status from ON/OFF to “Continuous Operation”, “Mandatory Operation”, “Momentary Cessation”, “Trip”, etc., to better capture the DER ride-through status, and its performance in different ride-through modes.

  • Added DER ride-through performance module, which includes the DER performance under different ride-through modes, including Momentary Cessation, etc.

  • Added DER model output options as current source and voltage source behind impedance.

1.0.2 (2022-07-18)

  • Improve model input validity check process

1.0.1 (2022-06-17)

  • Include parameter csv files into the PyPI release

1.0.0 (2022-05-17)

  • First release

  • Model for photovoltaic (PV) DERs, including all smart inverter functions defined in IEEE Standard 1547-2018, as well as trip and enter service behaviors

  • Output active and reactive power (P, Q) for power flow analysis

  • Suitable for both steady-state, quasi-static time series (QSTS) and dynamic simulations

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

opender-2.1.3.tar.gz (59.1 kB view details)

Uploaded Source

Built Distribution

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

opender-2.1.3-py3-none-any.whl (88.7 kB view details)

Uploaded Python 3

File details

Details for the file opender-2.1.3.tar.gz.

File metadata

  • Download URL: opender-2.1.3.tar.gz
  • Upload date:
  • Size: 59.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for opender-2.1.3.tar.gz
Algorithm Hash digest
SHA256 eebaba4610c012ae6359796843dcc6f35ab184e03d7f1895c492087bdd36b186
MD5 d12e5cb0dab317981daf5c853dfd464f
BLAKE2b-256 c0f1d68a56379af93098485cefea5bc4e05441ce4cccc1e770cef05f9bb93141

See more details on using hashes here.

File details

Details for the file opender-2.1.3-py3-none-any.whl.

File metadata

  • Download URL: opender-2.1.3-py3-none-any.whl
  • Upload date:
  • Size: 88.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for opender-2.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 199dc4d12f45788ca8b36a94cb65187a1d36dc43e5170b7c0d4bd45c4b242221
MD5 f0bc10fff274d5b98c0d97eee55c63b7
BLAKE2b-256 45cfd97a8c2ae75f99e0385533ee192528a96540947689e0a0f7dd610a26e282

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