Skip to main content

Framework to create partially automated networks made up of resistors and capacitors.

Project description

PyRC Logo


PyPI - Version PyPI - License DOI Typing

PyRC is a package to create and simulate resistance-capacity networks.

Installation

pip install pyrc

Notes:

  • PyRC started as research software, built from scientists for scientists. It was initiated at the IGTE at the University of Stuttgart by Joel Kimmich and Tim Jourdan.
  • PyRC becomes software in research.
  • PyRC was initiated at the IGTE at the University of Stuttgart from Joel Kimmich and Tim Jourdan. Its first application was to simulate a dynamic thermal system with a constant mass flow under boundary conditions resulting from weather conditions (sun radiation and ambient temperatures) over a whole year. Parameter studies were also
    conducted as part of this work. PyRC has therefore been tested in this regard. Additional functionality was added subsequently, and its performance was tested in individual cases. Nevertheless, more extensive testing is absolutely necessary.
  • PyRC brings the simplicity of Python. Some people may miss the speed of C code but appreciate the user-friendliness of Python. Python is widely spread across the scientific community and the automation of geometric thermal problems build in PyRC makes it a great tool to easily combine existing Python scripts with the accuracy of physics based dynamic models that can be represented in ODEs and solved efficiently by numeric algorithms.

When to use PyRC

  • When you have any thermal multidimensional dynamic problem
  • When modeling systems where time scales span nanoseconds to decades
  • When avoiding the complexity of CFD mesh generation
  • When the thermal network has an unstructured topology
  • When extending or customizing solvers directly in Python
  • When parameterizing large-scale RC-networks with up to thousands of elements are required
  • When parameterizing small-scale RC-networks with only a few elements
  • When working with time-dependent system matrices or boundary conditions
  • When creating networks to solve partial differential equations via lumped-parameter models
  • When creating geometric networks with visual aid of VPython
  • ...

Fun Facts

  • In principle, PyRC works not only for thermal problems but also for electrical ones. However, this has not yet been tested, and an Induction class modeling the behavior of an electrical coil is still missing. Contributions are welcome!
  • Even when not interested in solving the ODE you can use PyRC as tool to get the state-space system of even complex system with hundreds and thousands of capacities and resistors.

Publications

First publication:

Kimmich, J. & Jourdan, T.: "Python Package for Generating Dynamic Systems and Simulating Resistance-Capacitance Networks (PyRC)", DaRUS, 2026. https://dx.doi.org/10.18419/darus-5765

Poster presented at the 1st Stuttgart Research Software Day, 2026:

Kimmich, J. & Jourdan, T.: "PyRC", Zenodo, 2026. https://doi.org/10.5281/zenodo.18832971

Further publications are in progress.

Experiences with PyRC:

  • Network with weather data as boundary conditions and 280 radiation source terms; simulating one year with a maximum time step of 0.4 s on a single core at 3.2 GHz:
    • 3'302 capacities, 10'717 resistances
    • Pre-simulation to initialize: 2.5 hours (~7 simulated days)
    • Total simulation time: ~6.5 days
  • Smaller systems (~400 nodes) run 1'000 times faster than simulated time.

Contributing

See CONTRIBUTING.rst for how to contribute to PyRC.

License

See LICENSE.txt for the license.

Funding

Funded by the Federal Ministry for Economic Affairs and Energy (Bundesministerium für Wirtschaft und Energie), Germany.

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

pyrc-0.5.0.tar.gz (170.7 kB view details)

Uploaded Source

Built Distribution

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

pyrc-0.5.0-py3-none-any.whl (207.8 kB view details)

Uploaded Python 3

File details

Details for the file pyrc-0.5.0.tar.gz.

File metadata

  • Download URL: pyrc-0.5.0.tar.gz
  • Upload date:
  • Size: 170.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for pyrc-0.5.0.tar.gz
Algorithm Hash digest
SHA256 193c69722e7da40a2544e3b545921fdcdeb6214c5deb61dbddba111dd2e749d1
MD5 6ad4b759767e999ef38cd57b34a53fb5
BLAKE2b-256 b10546d540ae0a6cfe8bd77324aec811363d0be45076413d8b97dca3f3171933

See more details on using hashes here.

File details

Details for the file pyrc-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: pyrc-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 207.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for pyrc-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ceeb2913eb659bfc69ae3cb6fb3c7c35a3d5938dd1191949c309474010d9abc8
MD5 6577be709f693359cd5895b4ead5bb6f
BLAKE2b-256 f261409716efa9996ed9d160243adbbae2dcd8fca9cf4d5ed5aafa7c754b01ac

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