Python common code base to control devices high voltage research devices, in particular, as used in Christian Franck's High Voltage Lab (HVL), D-ITET, ETH
Project description
HVL Common Code Base
Python common code base to control devices high voltage research devices, in particular, as used in Christian Franck’s High Voltage Lab (HVL), D-ITET, ETH.
Free software: GNU General Public License v3
- Documentation:
if you’re planning to develop start w/ reading “CONTRIBUTING.rst”, otherwise either
read HVL CCB documentation at RTD, or
install Sphinx and sphinx_rtd_theme Python packages and locally build docs on Windows in git-bash by running:
$ ./make.sh docs
from a shell with Make installed by running:
$ make docs
The target index HTML (“docs/_build/html/index.html”) will open automatically in your Web browser.
Features
Manage experiments with ExperimentManager
instance controlling one or more of
the following devices:
a MBW973 SF6 Analyzer / dew point mirror over a serial connection (COM-ports)
a LabJack (T7-PRO) device using a LabJack LJM Library for communication
a Schneider Electric ILS2T stepper motor drive over Modbus TCP
a Elektro-Automatik PSI9000 DC power supply using VISA over TCP for communication
a Rhode & Schwarz RTO 1024 oscilloscope using VISA interface over
TCP::INSTR
a state-of-the-art HVL in-house Supercube device variants using an OPC UA client
a Heinzinger Digital Interface I/II and a Heinzinger PNC power supply over a serial connection
a passively Q-switched Pulsed Laser and a laser attenuator from CryLas over a serial connection
a Newport SMC100PP single axis motion controller for 2-phase stepper motors over a serial connection
a Pfeiffer TPG controller (TPG 25x, TPG 26x and TPG 36x) for Compact pressure Gauges
Credits
This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.
History
0.3.5 (2020-02-18)
Fix issue with reading integers from LabJack LJM Library (device’s product ID, serial number etc.)
Fix development requirements specification (tox version).
0.3.4 (2019-12-20)
- New devices using serial connection:
Heinzinger Digital Interface I/II and a Heinzinger PNC power supply
Q-switched Pulsed Laser and a laser attenuator from CryLas
Newport SMC100PP single axis motion controller for 2-phase stepper motors
Pfeiffer TPG controller (TPG 25x, TPG 26x and TPG 36x) for Compact pressure Gauges
PEP 561 compatibility and related corrections for static type checking (now in CI)
- Refactorings:
Protected non-thread safe read and write in communication protocols
Device sequence mixin: start/stop, add/rm and lookup
.format() to f-strings
more enumerations and a quite some improvements of existing code
Improved error docstrings (
:raises:
annotations) and extended tests for errors.
0.3.3 (2019-05-08)
Use PyPI labjack-ljm (no external dependencies)
0.3.2 (2019-05-08)
INSTALLATION.rst with LJMPython prerequisite info
0.3.1 (2019-05-02)
readthedocs.org support
0.3 (2019-05-02)
Prevent an automatic close of VISA connection when not used.
Rhode & Schwarz RTO 1024 oscilloscope using VISA interface over TCP::INSTR.
Extended tests incl. messages sent to devices.
Added Supercube device using an OPC UA client
Added Supercube 2015 device using an OPC UA client (for interfacing with old system version)
0.2.1 (2019-04-01)
Fix issue with LJMPython not being installed automatically with setuptools.
0.2.0 (2019-03-31)
LabJack LJM Library communication wrapper and LabJack device.
Modbus TCP communication protocol.
Schneider Electric ILS2T stepper motor drive device.
Elektro-Automatik PSI9000 current source device and VISA communication wrapper.
Separate configuration classes for communication protocols and devices.
Simple experiment manager class.
0.1.0 (2019-02-06)
Communication protocol base and serial communication implementation.
Device base and MBW973 implementation.
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
Hashes for hvl_ccb-0.3.5-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1aed20d46550a80432cf988522c084b2321d4c02e85423451e3ee6eed5c05cbc |
|
MD5 | 3793a3a49bb296f75991745a30dd61bf |
|
BLAKE2b-256 | 88c347ab84b8cf1b14a5b41db6392a60c9f5b13faa359234664e42f18e3dd16c |