An unofficial Python package 🐍📦 to interface with CAEN high voltage power supplies
Project description
HVPS
🤔 What is this?
This is a Python package for controlling high voltage power supplies (HVPS) over serial port. The aim is to provide a unified pythonic interface for different HVPS models.
Along with the Python package, a minimal set of bindings for Node.js is also provided. A nodered node is also available. They both rely on the Python package to be installed in order to work.
Currently only CAEN and iseg brands are supported.
⚙️ Installation
Installation via pip
is supported.
To install the latest published version, run:
pip install hvps
To install the package from source, including development dependencies, clone the repository and run:
pip install .[dev]
👨💻 Usage
There is a hierarchy of objects that represent the HVPS and its components:
HVPS
: represents the HVPS itself and handles the connection to the serial portModule
: represents a module of the HVPS. Some HVPS support multiple modules over the same connectionChannel
: represents a channel of the HVPS
Connection
from hvps import Caen, Iseg
import logging
# connection interface is common to all HVPS
# if no serial port is specified, the first available port will be used
# if no baudrate is specified, the default baudrate will be used
# if connect=False, the connection will not be established (useful for testing)
# if logging_level is specified, the logger will be configured accordingly
hvps = Caen(port="/dev/ttyUSB0", baudrate=115200, connect=True, logging_level=logging.DEBUG)
# connection settings can be accessed
print(f"port: {hvps.port}")
print(f"baudrate: {hvps.baudrate}")
Module
from hvps import Caen
# default connection settings
caen = Caen()
module = caen.module() # get the first module (module 0)
# if multiple modules are present, they can be accessed by index e.g. caen.module(1)
# get the module's name
print(f"module name: {module.name}")
Channel
from hvps import Caen
caen = Caen()
module = caen.module(0)
print(f"number of channels: {module.number_of_channels}")
channel = module.channel(2) # get channel number 2
# get monitoring parameters
print(f"vmon: {channel.vmon}")
print(f"vset: {channel.vset}")
# set values (remote mode must be enabled)
# turn on channel
channel.turn_on()
channel.vset = 300.0 # 300 V
⚠️ Disclaimer
The development of this package is mostly based on documentation with access to only a few models of HVPS.
If you use this package, it is very possible you find a bug or some oversight. You are encouraged to make a pull request or to create an issue to report a bug, to request additional features or to suggest improvements.
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 hvps-0.0.28.tar.gz
.
File metadata
- Download URL: hvps-0.0.28.tar.gz
- Upload date:
- Size: 35.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d6fea9aff91683219e784efdcba19a4cdc76651e0f63e1eb403328f1505ab827 |
|
MD5 | 5ce13c7fbc4bfe9187479f0b82cb63b6 |
|
BLAKE2b-256 | ac213cbfd1cbc85f43f64d4e3c862bfa04afd735d8992f266a78b263fe6d0800 |
File details
Details for the file hvps-0.0.28-py3-none-any.whl
.
File metadata
- Download URL: hvps-0.0.28-py3-none-any.whl
- Upload date:
- Size: 33.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.11.4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a946a205c672bdcbb1f8d855d6eec4ea22e248cec3cebc8fe2212558f3eee5da |
|
MD5 | 7223820fd81d063bd5fa816199f0a6e1 |
|
BLAKE2b-256 | cd805c4d372347d1537b85901553d1bc063d49b31819768e6759eef5e4cf028f |