Skip to main content

An application for controlling a Velleman LABPS3005D bench PSU and any compatible ones.

Project description

PSUcontrol

This is an application for controlling a Velleman LABPS3005D bench PSU and any compatible ones.

The project is still a work-in-progress and has only been tested with the aforementioned Velleman. That said, the basics do work fine for me.

PSUcontrol Example

CAVEATS

These PSUs tend to be buggy in multiple different ways and I have seen some mentions online about some of them just randomly having far longer delays in responding to commands than usual. The Velleman I have is missing e.g. the ability to control the audible beeps and the ability to lock/unlock the physical controls despite the protocol documentation saying otherwise. Without the ability to upgrade their firmwares this project is entirely YMMV and no guarantees are given.

INSTALLATION

The recommended approach:

pipx install psucontrol

(If you are not familiar with pipx, take a look here)

You can also grab one of the binary releases from the Releases-section but they are rather large because they bundle an entire Python-environment inside. Do also note that the Windows Defender is practically guaranteed to falsely flag the .exe-files as containing viruses -- this is a false positive but there is really not much I can do about it.

DEVELOPMENT

Install poetry. I, again, recommend pipx for this.

To modify the GUI:

git clone --recurse-submodules https://github.com/WereCatf/psucontrol
cd psucontrol
export PYSIDE_DESIGNER_PLUGINS="external/indicatorlabel;external/lcdlabel"
poetry install
poetry run pyside6-designer

If you have made any GUI or resource-file changes, you can rebuild the relevant files with:

cd psucontrol # If not already in there
poetry run pyside6-project build
# There is seemingly no way of making either pyside6-project or pyside6-uic to correctly generate the imports
# so we have to always fix the imports, or at least I have not found a way to do this automatically.
sed -i 's/^import rc_/import psucontrol.rc_/g' src/psucontrol/*.py

If you don't plan to touch the GUI-stuff, you can just do:

git clone --recurse-submodules https://github.com/WereCatf/psucontrol
cd psucontrol
poetry install

TODO

  • Fill out this README more
  • Implement the memory-buttons functionality
  • Add toggleable graphing
  • CLI-interface
  • TUI-interface
  • Maybe see about dumping the firmware (with Chipwhisperer?)
  • Add support for more PSUs?
  • Add support for multiple channels?

License

This project is licensed under the BSD 3-Clause License - see the LICENSE file for details. The project uses the Noto Sans-font - see the LICENSE file for details.

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

psucontrol-0.7.1.tar.gz (1.8 MB view details)

Uploaded Source

Built Distribution

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

psucontrol-0.7.1-py3-none-any.whl (1.9 MB view details)

Uploaded Python 3

File details

Details for the file psucontrol-0.7.1.tar.gz.

File metadata

  • Download URL: psucontrol-0.7.1.tar.gz
  • Upload date:
  • Size: 1.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for psucontrol-0.7.1.tar.gz
Algorithm Hash digest
SHA256 63fbeeb8046b5fa8bdfa157e576cad2076942217944ed4b8006121bc7f193419
MD5 38723545cbff9e2dea737d1e4d35a844
BLAKE2b-256 d3e28f73a152b959e47ffa6945bae18873eb2da98e4dcc8b75a6711563432b72

See more details on using hashes here.

Provenance

The following attestation bundles were made for psucontrol-0.7.1.tar.gz:

Publisher: buildandpublish.yaml on WereCatf/psucontrol

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

File details

Details for the file psucontrol-0.7.1-py3-none-any.whl.

File metadata

  • Download URL: psucontrol-0.7.1-py3-none-any.whl
  • Upload date:
  • Size: 1.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for psucontrol-0.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 16fbb4697e51b7e882986f3c63a903d64fd137aa0d27eff7c722b09a27ecf128
MD5 c3596685f5b7469da684c54804d20ab5
BLAKE2b-256 87e76cb38a4bb10c515fda9d0e0215fb7f4faec4210068443ca2e83384148ba1

See more details on using hashes here.

Provenance

The following attestation bundles were made for psucontrol-0.7.1-py3-none-any.whl:

Publisher: buildandpublish.yaml on WereCatf/psucontrol

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