Skip to main content

Cross-platform GUI for Pulsim power electronics simulator

Project description

PulsimGui — Dark Theme

PulsimGui

Professional GUI for power electronics simulation with Pulsim.

Release PyPI Docs License: MIT Python 3.10+

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_telemetry
  • backend_telemetry
  • fallback_trace
  • loss_summary
  • thermal_summary
  • component_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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pulsimgui-0.9.0.tar.gz (947.5 kB view details)

Uploaded Source

Built Distribution

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

pulsimgui-0.9.0-py3-none-any.whl (893.1 kB view details)

Uploaded Python 3

File details

Details for the file pulsimgui-0.9.0.tar.gz.

File metadata

  • Download URL: pulsimgui-0.9.0.tar.gz
  • Upload date:
  • Size: 947.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pulsimgui-0.9.0.tar.gz
Algorithm Hash digest
SHA256 674582e44d550399b85fcd946391c7bed004c24daa60e570f198b9c828843945
MD5 c16375ba440dbe2bd9eb814b7b334bf6
BLAKE2b-256 46ee84eedaf5a1b679b1b7cd5a78d159afb4a8d6c030c23e7e67a4eac2f0d001

See more details on using hashes here.

Provenance

The following attestation bundles were made for pulsimgui-0.9.0.tar.gz:

Publisher: release.yml on lgili/PulsimGUI

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pulsimgui-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: pulsimgui-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 893.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pulsimgui-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f7116c43e31692f99a3d883ff8a06b31a2fde58f3a6a876d9a1fc49d42c146cc
MD5 b4eb0cd82e1c64f11498b0efbb38e0c7
BLAKE2b-256 2761cae142b69b245573ba86a5b2234842be6d9836d17c331e8bb9968858841f

See more details on using hashes here.

Provenance

The following attestation bundles were made for pulsimgui-0.9.0-py3-none-any.whl:

Publisher: release.yml on lgili/PulsimGUI

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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