[![pylint](../../actions/workflows/pylint.yml/badge.svg)](../../actions/workflows/pylint.yml)
[![PyPI](https://img.shields.io/pypi/v/ug-gpib)](https://pypi.org/project/ug-gpib/)
![PyPI - Python Version](https://img.shields.io/pypi/pyversions/ug-gpib)
![PyPI - Status](https://img.shields.io/pypi/status/ug-gpib)
[![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](LICENSE)
[![code style](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
# ug_gpib
A Python3 pyUSB driver for the LQ Electronics Corp UGPlus USB to GPIB Controller.
Tested using Linux, should work for Mac OSX, Windows and any OS with Python [pyUSB](https://github.com/pyusb/pyusb)
support.
:warning: **The device must be IEEE 488.1 compliant. It must assert the EOI line to signal the end of a line. If this is
not the case, the controller cannot be used. Older devices, typically only send CR, LF, or CR-LF.**
The [UGPlus](http://lqelectronics.com/Products/USBUG/UGPlus/UGPlus.html) is a fairly cheap controller, that supports
simple GPIB read and write operations only. It does not support advanced GPIB features like serial polling for example,
and it does not have line drivers to support long cables and lots of devices on the bus.
The UGPlus does have several firmware bugs, I have tried to mitigate them to the best of my knowledge. See
[below](#firmware-bugs) for details.
If you are looking for advanced features I suggest buying either a Prologix GPIB adapter or one of the NI USB adapters.
I can recommend the following libraries for both
[Prologix GPIB adapter](https://github.com/PatrickBaus/pyAsyncPrologixGpib) and
[Linux GPIB](https://github.com/PatrickBaus/pyAsyncGpib).
The library is fully type-hinted.
## Setup
To install the library in a virtual environment (always use venvs with every project):
```bash
virtualenv env # virtual environment, optional
source env/bin/activate
pip install ug-gpib
```
### Linux
To access the raw usb port in Linux, root privileges are required. It is possible to use udev to change ownership of the
usb port on creation. This can be done via a rules file.
```bash
sudo cp 98-ugsimple.rules /etc/udev/rules.d/.
sudo udevadm control --reload-rules
```
## Usage
Initialize UGSimpleGPIB
```python
from ug_gpib import UGPlusGpib
gpib_controller = UGPlusGpib()
```
Writing "*IDN?" a command to address 0x02. Do note the GPIB commands must be byte strings.
```python
gpib_controller.write(2, b"*IDN?\n")
```
Reading from address 0x02 and decoding the byte string to a unicode string.
```python
data = gpib_controller.read(2)
print(data.decode())
```
See [examples/](examples/) for more working examples. Including an example that shows how to use the library from the
command line.
## Firmware Bugs
There are several bugs in the firmware of the UGPlus most of those are off-by-one errors and consequently out-of-bounds
reads. I documented them
[here](https://github.com/PatrickBaus/pyUgGpib/blob/f1bb0d2244304b3e3f9776606918eaa270d0e9dc/ug_gpib/ug_gpib.py#L152).
Some of these bugs are also evident when using the software supplied by the manufacturer.
The most obvious ones are the following:
* Out-of-bounds read when reading the firmware version. The controller sends one more byte than requested.
* Out-of-bounds read when discovering GPIB devices. The controller sends one more byte than requested.
* Out-of-bounds read when the GPIB device does not return any data. The controller sends one more byte than requested.
## Versioning
I use [SemVer](http://semver.org/) for versioning. For the versions available, see the [tags on this repository](../../tags).
## Documentation
I use the [Numpydoc](https://numpydoc.readthedocs.io/en/latest/format.html) style for documentation.
## Authors
* **Jacob Alexander** - *Initial work for the UGSimple* [Jacob Alexander](https://github.com/haata)
* **Patrick Baus** - *Complete rewrite for the UGPlus* - [PatrickBaus](https://github.com/PatrickBaus)
## License
This project is licensed under the GPL v3 license - see the [LICENSE](LICENSE) file for details
Raw data
{
"_id": null,
"home_page": null,
"name": "ug-gpib",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.7",
"maintainer_email": null,
"keywords": "UGPlus, GPIB, API",
"author": null,
"author_email": "Patrick Baus <patrick.baus@physik.tu-darmstadt.de>, Jacob Alexander <haata@kiibohd.com>",
"download_url": "https://files.pythonhosted.org/packages/f2/6c/641fa528fc78c5b0f77f388201dc0803fd6a4737ae7d9ba0edef4515cce8/ug_gpib-1.2.2.tar.gz",
"platform": null,
"description": "[![pylint](../../actions/workflows/pylint.yml/badge.svg)](../../actions/workflows/pylint.yml)\n[![PyPI](https://img.shields.io/pypi/v/ug-gpib)](https://pypi.org/project/ug-gpib/)\n![PyPI - Python Version](https://img.shields.io/pypi/pyversions/ug-gpib)\n![PyPI - Status](https://img.shields.io/pypi/status/ug-gpib)\n[![License: GPL v3](https://img.shields.io/badge/License-GPL%20v3-blue.svg)](LICENSE)\n[![code style](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)\n# ug_gpib\nA Python3 pyUSB driver for the LQ Electronics Corp UGPlus USB to GPIB Controller.\n\nTested using Linux, should work for Mac OSX, Windows and any OS with Python [pyUSB](https://github.com/pyusb/pyusb)\nsupport.\n\n:warning: **The device must be IEEE 488.1 compliant. It must assert the EOI line to signal the end of a line. If this is\nnot the case, the controller cannot be used. Older devices, typically only send CR, LF, or CR-LF.**\n\nThe [UGPlus](http://lqelectronics.com/Products/USBUG/UGPlus/UGPlus.html) is a fairly cheap controller, that supports\nsimple GPIB read and write operations only. It does not support advanced GPIB features like serial polling for example,\nand it does not have line drivers to support long cables and lots of devices on the bus.\n\nThe UGPlus does have several firmware bugs, I have tried to mitigate them to the best of my knowledge. See\n[below](#firmware-bugs) for details.\n\nIf you are looking for advanced features I suggest buying either a Prologix GPIB adapter or one of the NI USB adapters.\nI can recommend the following libraries for both\n[Prologix GPIB adapter](https://github.com/PatrickBaus/pyAsyncPrologixGpib) and\n[Linux GPIB](https://github.com/PatrickBaus/pyAsyncGpib).\n\nThe library is fully type-hinted.\n\n## Setup\n\nTo install the library in a virtual environment (always use venvs with every project):\n\n```bash\nvirtualenv env # virtual environment, optional\nsource env/bin/activate\npip install ug-gpib\n```\n\n### Linux\nTo access the raw usb port in Linux, root privileges are required. It is possible to use udev to change ownership of the\nusb port on creation. This can be done via a rules file.\n\n```bash\nsudo cp 98-ugsimple.rules /etc/udev/rules.d/.\nsudo udevadm control --reload-rules\n```\n\n## Usage\n\nInitialize UGSimpleGPIB\n\n```python\nfrom ug_gpib import UGPlusGpib\n\ngpib_controller = UGPlusGpib()\n```\n\nWriting \"*IDN?\" a command to address 0x02. Do note the GPIB commands must be byte strings.\n```python\ngpib_controller.write(2, b\"*IDN?\\n\")\n```\n\nReading from address 0x02 and decoding the byte string to a unicode string.\n```python\ndata = gpib_controller.read(2)\nprint(data.decode())\n```\n\nSee [examples/](examples/) for more working examples. Including an example that shows how to use the library from the\ncommand line.\n\n## Firmware Bugs\nThere are several bugs in the firmware of the UGPlus most of those are off-by-one errors and consequently out-of-bounds\nreads. I documented them\n[here](https://github.com/PatrickBaus/pyUgGpib/blob/f1bb0d2244304b3e3f9776606918eaa270d0e9dc/ug_gpib/ug_gpib.py#L152).\nSome of these bugs are also evident when using the software supplied by the manufacturer.\nThe most obvious ones are the following:\n\n* Out-of-bounds read when reading the firmware version. The controller sends one more byte than requested.\n* Out-of-bounds read when discovering GPIB devices. The controller sends one more byte than requested.\n* Out-of-bounds read when the GPIB device does not return any data. The controller sends one more byte than requested.\n\n## Versioning\n\nI use [SemVer](http://semver.org/) for versioning. For the versions available, see the [tags on this repository](../../tags).\n\n## Documentation\nI use the [Numpydoc](https://numpydoc.readthedocs.io/en/latest/format.html) style for documentation.\n\n## Authors\n\n* **Jacob Alexander** - *Initial work for the UGSimple* [Jacob Alexander](https://github.com/haata)\n* **Patrick Baus** - *Complete rewrite for the UGPlus* - [PatrickBaus](https://github.com/PatrickBaus)\n\n## License\n\n\nThis project is licensed under the GPL v3 license - see the [LICENSE](LICENSE) file for details\n",
"bugtrack_url": null,
"license": "GNU General Public License v3 (GPLv3)",
"summary": "A Python3 pyUSB library for the LQ Electronics Corp. UGPlus USB to GPIB Controller.",
"version": "1.2.2",
"project_urls": {
"Bug Tracker": "https://github.com/PatrickBaus/pyUgGpib/issues",
"Download": "https://github.com/PatrickBaus/pyUgGpib/releases",
"Homepage": "https://github.com/PatrickBaus/pyUgGpib"
},
"split_keywords": [
"ugplus",
" gpib",
" api"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "07df865b80ce03ff60963a639df4c17313ba5984b1ce2e1fe51c372a5ea3f81a",
"md5": "a65656b8f4c15657a16517a1ea4c4ffd",
"sha256": "434008a04d92dc0198fe294b44fe3fa4a12e3f13a2d30d33341d6ba3fa83eb57"
},
"downloads": -1,
"filename": "ug_gpib-1.2.2-py3-none-any.whl",
"has_sig": false,
"md5_digest": "a65656b8f4c15657a16517a1ea4c4ffd",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.7",
"size": 21481,
"upload_time": "2024-06-22T13:45:42",
"upload_time_iso_8601": "2024-06-22T13:45:42.985910Z",
"url": "https://files.pythonhosted.org/packages/07/df/865b80ce03ff60963a639df4c17313ba5984b1ce2e1fe51c372a5ea3f81a/ug_gpib-1.2.2-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "f26c641fa528fc78c5b0f77f388201dc0803fd6a4737ae7d9ba0edef4515cce8",
"md5": "c986a5563e9223b30de9f59a15bc034f",
"sha256": "d919d12c430286e7d952813f15eebcfb1a95e64504699b988ddae2c010da6b0f"
},
"downloads": -1,
"filename": "ug_gpib-1.2.2.tar.gz",
"has_sig": false,
"md5_digest": "c986a5563e9223b30de9f59a15bc034f",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.7",
"size": 23251,
"upload_time": "2024-06-22T13:45:44",
"upload_time_iso_8601": "2024-06-22T13:45:44.679829Z",
"url": "https://files.pythonhosted.org/packages/f2/6c/641fa528fc78c5b0f77f388201dc0803fd6a4737ae7d9ba0edef4515cce8/ug_gpib-1.2.2.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-06-22 13:45:44",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "PatrickBaus",
"github_project": "pyUgGpib",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "pyusb",
"specs": [
[
"~=",
"1.2.1"
]
]
}
],
"lcname": "ug-gpib"
}