Skip to main content

simulating distributed energy appliances in a virtual power plant

Project description

Introduction to the VPPlib structure

Installation

You can install vpplib using pip:

pip install vpplib

Or install directly from the repository:

git clone https://github.com/Pyosch/vpplib.git
cd vpplib
pip install -e .

Dependencies

VPPlib requires the following main dependencies:

  • windpowerlib
  • pvlib
  • pandas
  • numpy
  • pandapower
  • simbench
  • simses
  • polars
  • requests
  • lxml
  • pytz
  • tqdm
  • NREL-PySAM

Testing

Tests use pytest and require internet access (DWD API). All tests are marked @pytest.mark.integration.

# Install dev dependencies
pip install -e .

# Run all integration tests
pytest -m integration

# Run tests with verbose output
pytest -v

Overview

For the simulation of the virtual power plant a basic data structure is developed. It consists of multiple classes to design a virtual power plant, build models of the components and operate it in a distribution grid.

The "Environment" class describes the overall environment, in which the vpp is being operated. It contains all time- and weather-related information and data. The class "UserProfile" contains information, which is specific for a certain house or housing unit, like heat demand or usage times of an electric vehicle.

The "Component" classes can then compose the Environment and UserProfile, to access their information for simulating the single components. To aggregate the components, the "VirtualPowerPlant" class composes the components.

To be able to mirror the behavior of the components to the distribution grid, a pandapower net object is created, containing loads, storages and generation units, which correspond to the components in the VirtualPowerPlant. The net object along with the VirtualPowerPlant are then passed on to the "Operator" class. In this class, operation strategies as well as optimizations can be implemented, considering restrictions which arise from the components as well as the grid.

Besides the technical issues, time series from markets can also be included to analyze the financial aspects of the virtual power plant at hand.

Component

The Component class represents a component within the virtual power plant. This can be, for example, a photovoltaik system or a combined heat and power plant. In addition to the generators, consumers and electrical storage devices can also be stored in this way. The different generators, consumers and storages are derived from the Component superclass. The superclass is used to provide general functionality for the accounting of the power flows within the virtual power plant. Therefore, it does not matter whether an electricity storage device or a photovoltaik system is to be balanced afterwards. However, you can create derivations from this object so that you can still represent the special features of the individual components.

Virtual power plant

The second superordinate element is the VirtualPowerPlant object. This represents a combination of different components. Individual components can be added and removed for the simulation. By this encapsulation of the individual components, different topologies of the virtual power plant can be simulated.

Operator

The Operator object receives a reference to a VirtualPowerPlant object and controls this according to the implemented logic. This element can also be used as a basis to achieve different goals. By deriving this class one Operator can, for example, aim to maximize the share of renewable energies. Another Operator could maximize the monetary profit.

Environment

The Environment class is an encapsulation of every environmental impact on the system. In addition to basic weather and time related data, it is also possible to store regulatory framework conditions for the operation of a virtual power plant. The Environment can be passed to any Component in the constructor. Depending on the component, individual data is accessed.

UserProfile

The UserProfile class is similar to the Environment class. However, this contains information on the respective usage behaviour of different types of users.

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

vpplib-0.0.6.tar.gz (8.8 MB view details)

Uploaded Source

Built Distribution

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

vpplib-0.0.6-py3-none-any.whl (9.2 MB view details)

Uploaded Python 3

File details

Details for the file vpplib-0.0.6.tar.gz.

File metadata

  • Download URL: vpplib-0.0.6.tar.gz
  • Upload date:
  • Size: 8.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.5

File hashes

Hashes for vpplib-0.0.6.tar.gz
Algorithm Hash digest
SHA256 039462c550c1d2b91d84c5e3e826c7b98f8ddbd3ef6b0c1d84c3b65b2aa9cdb2
MD5 e5e75ca1e24beae57f345ca8568e120a
BLAKE2b-256 84b920afc2d09e4bc295d81b0f068288d0fdb4b3bb3a9a7214d7bba8ea426107

See more details on using hashes here.

File details

Details for the file vpplib-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: vpplib-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 9.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.5

File hashes

Hashes for vpplib-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 f155a6aa4e7c5a77e5e6f2ec71d3d4911bef39f4d09b8f63a03172d67c32e3f3
MD5 49beff480162240ca170540fbeab9bd3
BLAKE2b-256 4a842e9cd5452948f6d1a74bb507c3755825b6af97e5264b166e1b69766de2eb

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