Python3 AsyncIO HP3478A driver. This library requires Python asyncio and AsyncIO library for the GPIB adapter. It also supports several undocumented functions for reading status registers and reading, modifying and writing the calibration memory.
The library is fully type-hinted.
Device | Supported | Tested | Comments |
---|---|---|---|
AsyncIO Prologix GPIB library | ✔️ | ✔️ | |
AsyncIO linux-gpib wrapper | ✔️ | ✔️ |
Tested using Linux, should work for Mac OSX, Windows and any OS with Python support.
The full documentation can be found on GitHub Pages: https://patrickbaus.github.io/pyAsyncHP3478A/. I use the Numpydoc style for documentation and Sphinx for compiling it.
To install the library in a virtual environment (always use venvs with every project):
python3 -m venv env # virtual environment, optional
source env/bin/activate # only if the virtual environment is used
pip install hp3478a-async
All examples assume that a GPIB library is installed as well. Either run
pip install prologix-gpib-async # or alternatively
# pip install async-gpib
The library uses an asynchronous context manager to make cleanup easier. You can use either the context manager syntax or invoke the calls manually:
async with HP_3478A(connection=gpib_device) as hp3478a:
# Add your code here
...
try:
hp3478a = HP_3478A(connection=gpib_device)
await hp3478a.connect()
# your code
finally:
await hp3478a.disconnect()
A more complete example for reading voltages:
import asyncio
import logging
from hp3478a_async import HP_3478A, FunctionType, TriggerType, Range
from pyAsyncPrologixGpib import AsyncPrologixGpibEthernetController, EosMode
# The default GPIB address is 27. The ip address of the prologix controller needs to be changed.
ip_address = "127.0.0.1"
gpib_device = AsyncPrologixGpibEthernetController(ip_address, pad=27, timeout=1000, eos_mode=EosMode.APPEND_NONE)
async def main():
"""This example will print voltage data to the console"""
try:
# No need to explicitly bring up the GPIB connection. This will be done by the instrument.
async with HP_3478A(connection=gpib_device) as hp3478a:
await asyncio.gather(
hp3478a.set_function(FunctionType.DCV), # Set to 4-wire ohm
hp3478a.set_range(Range.RANGE_30), # Set to 30 kOhm range
hp3478a.set_trigger(TriggerType.INTERNAL), # Enable free running trigger
hp3478a.set_autozero(True), # Enable Autozero
hp3478a.set_number_of_digits(6), # Set the resolution to 5.5 digits
hp3478a.connection.timeout(700), # The maximum reading rate @ 50 Hz line freq. is 1.9 rds/s
)
# Take the measurements until Ctrl+C is pressed
async for result in hp3478a.read_all():
print(result)
except (ConnectionError, ConnectionRefusedError):
logging.getLogger(__name__).error(
"Could not connect to remote target. Connection refused. Is the device connected?"
)
try:
asyncio.run(main(), debug=False)
except KeyboardInterrupt:
# The loop will be canceled on a KeyboardInterrupt by the run() method, we just want to suppress the exception
pass
See examples/ for more working examples.
There are unit tests available for the calram encoder and decoder.
source env/bin/activate # only if the virtual environment is used
pytest
Special thanks goes to fenugrec and Steve Matos for their work on deciphering the calram function.
I use SemVer for versioning. For the versions available, see the tags on this repository.
- Patrick Baus - Initial work - PatrickBaus
This project is licensed under the GPL v3 license - see the LICENSE file for details