Cross-platform GUI for Pulsim power electronics simulator
Project description
PulsimGui
Professional GUI for power electronics simulation with Pulsim.
Download latest release · Install from PyPI · Documentation · Report a bug
PulsimGui is a cross-platform desktop interface for Pulsim, focused on modeling and validating power converter topologies.
Key Features
- Schematic editor with drag-and-drop workflow.
- Component library focused on power electronics.
- Transient simulation with advanced solver controls.
- Advanced backend telemetry for convergence, fallback, and loss/thermal diagnostics.
- Integrated waveform viewer with signal measurements.
- Ready-to-run examples (
RC,buck,boost, and more).
Official Documentation
Full documentation is available at:
Main content includes:
- Installation and execution
- GUI guides and workflow
- Simulation and backend configuration
- Practical tutorials
- Technical reference for contributors
Installation
1. Release (Recommended)
Use installers from Releases.
2. Install via pip
python3 -m pip install --upgrade pip
python3 -m pip install pulsimgui
Run:
pulsimgui
The pulsimgui package is published to PyPI by the release pipeline (.github/workflows/release.yml) whenever a new tag v* is released.
3. Development setup (source code)
git clone https://github.com/lgili/PulsimGUI.git
cd PulsimGui
python3 -m venv .venv
source .venv/bin/activate
python3 -m pip install --upgrade pip
python3 -m pip install -e ".[dev]"
python3 -m pulsimgui
Recommended Backend
For reproducible behavior, use pulsim v0.7.9.
This is required for full advanced electrothermal support in GUI runtime:
- staged thermal networks (
single_rc,foster,cauer) - shared-sink coupling (
shared_sink_id,shared_sink_rth,shared_sink_cth) - datasheet switching-loss surfaces (
loss.model=datasheet)
Quick check:
python3 -c "import pulsim; print(pulsim.__version__)"
In the app: Preferences → Simulation → Backend Runtime.
Runtime Telemetry
With modern Pulsim backends, transient runs expose structured diagnostics in SimulationResult.statistics, including solver/backend telemetry and electrothermal summaries:
linear_solver_telemetrybackend_telemetryfallback_traceloss_summarythermal_summarycomponent_electrothermal
Development
Tests
pytest
Template Smoke Test (Pre-release)
PYTHONPATH=src python3 scripts/smoke_templates.py
Lint
ruff check src tests
Local docs build
python3 -m pip install -r docs/requirements.txt
mkdocs build --strict
mkdocs serve
GitHub Pages (Docs)
Documentation is published through:
.github/workflows/docs-pages.yml
Automatic deploy runs on main and workflow_dispatch.
Repository setting required: Settings → Pages → Source: GitHub Actions.
Contributing
- Open issues for bug reports and feature requests.
- For PRs, include context, validation steps, and evidence (logs/screenshots).
- Update docs whenever a user workflow or feature changes.
License
MIT — see LICENSE.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pulsimgui-0.7.4.tar.gz.
File metadata
- Download URL: pulsimgui-0.7.4.tar.gz
- Upload date:
- Size: 853.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1b6aa968deda2fe2ccb5225173ed343bb4352e5bc2387687d90d8329016cb153
|
|
| MD5 |
739c53ffcf4b8daf8388db5123bcc9c9
|
|
| BLAKE2b-256 |
9a1d5a75308f93bd4cc9583ede831cb6c9d130a60104ca37286206835563814f
|
Provenance
The following attestation bundles were made for pulsimgui-0.7.4.tar.gz:
Publisher:
release.yml on lgili/PulsimGUI
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pulsimgui-0.7.4.tar.gz -
Subject digest:
1b6aa968deda2fe2ccb5225173ed343bb4352e5bc2387687d90d8329016cb153 - Sigstore transparency entry: 1069568950
- Sigstore integration time:
-
Permalink:
lgili/PulsimGUI@9380e1263d93d12bcd43884e5425226485594ad5 -
Branch / Tag:
refs/tags/v0.7.4 - Owner: https://github.com/lgili
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@9380e1263d93d12bcd43884e5425226485594ad5 -
Trigger Event:
push
-
Statement type:
File details
Details for the file pulsimgui-0.7.4-py3-none-any.whl.
File metadata
- Download URL: pulsimgui-0.7.4-py3-none-any.whl
- Upload date:
- Size: 809.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
49decb5a02f2cc99409fdfbc6bf6e2565f77a66f9971829713153090536ed115
|
|
| MD5 |
34a5dbd0bd5cc517fbd010aa050d1378
|
|
| BLAKE2b-256 |
b755fce5f0ea2fb29a8c8a671aa458723a77dcfa2016a156893d6c100cc4d405
|
Provenance
The following attestation bundles were made for pulsimgui-0.7.4-py3-none-any.whl:
Publisher:
release.yml on lgili/PulsimGUI
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
pulsimgui-0.7.4-py3-none-any.whl -
Subject digest:
49decb5a02f2cc99409fdfbc6bf6e2565f77a66f9971829713153090536ed115 - Sigstore transparency entry: 1069569003
- Sigstore integration time:
-
Permalink:
lgili/PulsimGUI@9380e1263d93d12bcd43884e5425226485594ad5 -
Branch / Tag:
refs/tags/v0.7.4 - Owner: https://github.com/lgili
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@9380e1263d93d12bcd43884e5425226485594ad5 -
Trigger Event:
push
-
Statement type: