Python interface for Hantek bench power supply
Project description
Hantek Power Supply Controller
This is an interface to the serial port on Hantek HDP1160V4S power supply. It should work with other HDP10000-series power supplies. buy
❗ATTENTION❗
USING THIS CODE MAY DAMAGE YOUR POWER SUPPLY OR CONNECTED DEVICES. USE AT YOUR OWN RISK.To communicate with the PSU I am using USB-to-RS232 adapter - does not require any drivers on debian linux.
Installation
pip install hantekpsu
Usage
from hantekpsu import PSU
p = PSU(port='/dev/ttyUSB0', baudrate=2400)
Methods
Method | Description | Return Type |
---|---|---|
turn_on() |
Turns on the power supply unit. | None |
turn_off() |
Turns off the power supply unit. | None |
ocp_on() |
Enables Over Current Protection (OCP). | None |
ocp_off() |
Disables Over Current Protection (OCP). | None |
ovp_on() |
Enables Over Voltage Protection (OVP). | None |
ovp_off() |
Disables Over Voltage Protection (OVP). | None |
get_model() |
Gets the model of the PSU. | str |
get_active_voltage() |
Gets the active output voltage of the PSU in volts. | float |
get_active_current() |
Gets the active output current of the PSU in milliamps. | int |
get_voltage_limit() |
Gets the voltage limit setting of the PSU in volts. | float |
get_current_limit() |
Gets the current limit setting of the PSU in milliamps. | int |
get_on_off_status() |
Returns the on/off status of the PSU. | bool |
set_output_voltage(v: float) |
Sets the output voltage of the PSU in volts. | None |
set_output_current(mA: int) |
Sets the output current of the PSU in milliamps. | None |
set_ovp_limit(v: float) |
Sets the Over Voltage Protection (OVP) limit in volts. | None |
set_ocp_limit(mA: int) |
Sets the Over Current Protection (OCP) limit in milliamps. | None |
Examples
Set voltage to 12V and turn on the power supply:
>>> from hantekpsu import PSU
>>> p = PSU()
>>> p.set_output_voltage(12.0)
>>> p.turn_on()
Development
Requirements
- python 3.10+
- poetry
Ensure the device is connected. If using usb-to-rs232 adapter, run lsusb
:
$ lsusb
Bus 001 Device 012: ID 0403:6001 Future Technology Devices International, Ltd FT232 Serial (UART) IC
You should also see something similar to /dev/ttyUSB0
in the /dev
folder.
To figure out which device it is, you can run ls /dev
before plugging in the adapter and after and compare the differences.
Installation
git clone https://github.com/builder555/hantek-controller
cd hantek-controller
poetry config virtualenvs.in-project true --local
poetry install
Unit Tests
When adding new features or modifying existing ones, make sure you add unit tests and run them:
$ poetry run pytest -v
test_psu.py::test_get_model_number PASSED [ 6%]
test_psu.py::test_get_active_voltage PASSED [ 12%]
test_psu.py::test_get_active_current_in_milliamps PASSED [ 18%]
test_psu.py::test_get_voltage_limit PASSED [ 25%]
test_psu.py::test_get_current_limit_in_milliamps PASSED [ 31%]
test_psu.py::test_get_on_off_status PASSED [ 37%]
test_psu.py::test_turn_on PASSED [ 43%]
test_psu.py::test_turn_off PASSED [ 50%]
test_psu.py::test_ocp_on PASSED [ 56%]
test_psu.py::test_ocp_off PASSED [ 62%]
test_psu.py::test_ovp_on PASSED [ 68%]
test_psu.py::test_ovp_off PASSED [ 75%]
test_psu.py::test_set_voltage PASSED [ 81%]
test_psu.py::test_set_current PASSED [ 87%]
test_psu.py::test_set_ovp PASSED [ 93%]
test_psu.py::test_set_ocp PASSED [100%]
========================= 16 passed in 0.03s =========================
You can also run pytest-watch while developing to run tests automatically on save:
poetry run ptw --runner 'pytest -v'
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
File details
Details for the file hantekpsu-1.0.2.tar.gz
.
File metadata
- Download URL: hantekpsu-1.0.2.tar.gz
- Upload date:
- Size: 3.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cc8e07d69ebcdaaa3fbf8d4387262fae7b3b44698019ae0dd8282d780b889bcd |
|
MD5 | 517018d313ed84ca3ac2574bde076481 |
|
BLAKE2b-256 | adcb8910a99e6eb5d3f9e5195355720b24c5fd0feeb8072e6d8c787180742f2c |
Provenance
The following attestation bundles were made for hantekpsu-1.0.2.tar.gz
:
Publisher:
ci.yml
on builder555/hantek-controller
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
hantekpsu-1.0.2.tar.gz
- Subject digest:
cc8e07d69ebcdaaa3fbf8d4387262fae7b3b44698019ae0dd8282d780b889bcd
- Sigstore transparency entry: 146309744
- Sigstore integration time:
- Predicate type:
File details
Details for the file hantekpsu-1.0.2-py3-none-any.whl
.
File metadata
- Download URL: hantekpsu-1.0.2-py3-none-any.whl
- Upload date:
- Size: 3.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 960716024de705dcdcdbfbc5e6b7ec70db5ed24ab45b0ec82d0be0964eedc724 |
|
MD5 | 6015eb8caaa147c2f89a543c12a15b3b |
|
BLAKE2b-256 | 6c81be529dc92f6d28f72657750f6add8bd7c01ea2d6f44f7bed02ce6d55aacb |
Provenance
The following attestation bundles were made for hantekpsu-1.0.2-py3-none-any.whl
:
Publisher:
ci.yml
on builder555/hantek-controller
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
hantekpsu-1.0.2-py3-none-any.whl
- Subject digest:
960716024de705dcdcdbfbc5e6b7ec70db5ed24ab45b0ec82d0be0964eedc724
- Sigstore transparency entry: 146309745
- Sigstore integration time:
- Predicate type: