Skip to main content

Device Communication via WAMP for HiPerCAM

Project description

hcam_devices

https://img.shields.io/pypi/v/hcam_devices.svg https://img.shields.io/travis/StuartLittlefair/hcam_devices.svg Documentation Status Updates

Hardware Communication for HiPERCAM

The HiPERCAM project necessitates communicating between numerous hardware components, distributed over a network. hcam_devices provides a set of tools to allow devices on the network to run and communicate with each other.

The architecture uses a central WAMP server (e.g. crossbar) to handle communication over websockets. Devices on the network publish telemetry regularly to the WAMP server, and any interested party can subcribe to the telemetry topic to receive updates.

Devices can expose Remote Procedure Calls (RPCs) so that they may be controlled over the network, and also subscribe to topics, so that settable attributes (e.g the temperature setpoint of a CCD) can be cpontrolled by publishing to those topics.

Installation

Install with the usual:

pip install .

or if you don’t have root access:

pip install --user .

Usage

First of all, you will need a running WAMP server. I recommend crossbar. A config file for a crossbar instance is included with this package in the data directory. Once you have your WAMP server up and running, there are several scripts that you can run.

hwserver

This program runs the HiPERCAM peripheral hardware (e.g the CCD peltier controllers, focal plane slide, flow sensors etc). Running this script will connect these devices to the WAMP server and allow monitoring and control

hwlogger

So that the devices (especially the CCD heads) can be monitored off-site, this script subscribes to the CCD telemetry and saves the hardware state to a persistent off-site Influx database. That database can be used with third party tools like grafana to enable neat dashboards for device monitoring.

hserver

The NGC CCD controller is responsible for driving the CCDs, saving exposures etc. For maximum reliability and speed, this device is connected to the WAMP server and controlled via it’s own custom script, hserver.

gtcserver

Finally, the external GTC environment (Electronics racks, rotator, telescope offsets etc) are all connected to the WAMP server using this script.

Control within python

Once these scripts are running, devices can be controlled in Python. This can be done using a WAMP library like autobahn. Alternatively, the WAMP server config included provides a simple HTTP interface that can be used as follows:

from hcam_devices.wamp.utils import call, publish

# call RPCs
ngc_status = call('hipercam.NGC.rpc.summary')
call('hipercam.GTC.rpc.do_offset', raoff=0.05, decoff=0.001)

# publish to a topic
publish('hipercam.FocalPlaneSlide.target_position', -50)

Subscribing to device telemetry must be done using a WAMP library for now.

Optional package dependencies

hcam_devices supports several other tools, such as the finding chart tool hfinder and the instrument control GUI hdriver. Most users will need no extra modules installed. However, If you want to be able to run hdriver, and you want full communication with the telescope whilst running at the GTC, you need to install the CORBA implementation omniORBpy.

Full install instructions are found at the omniORB project homepage. Be sure to install both omniORB and omniORBpy. Also, the omniORBpy module and the lib64 variant must both be in the PYTHONPATH. Finally, communicating with the GTC requires the installation of Interface Definition Language (IDL) files, and the python modules compiled from them. Contact S. Littlefair for these files, which must also be in the PYTHONPATH.

  • Free software: MIT license

History

0.1.0 (2020-06-05)

  • First release on PyPI.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hcam_devices-1.6.1.tar.gz (66.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hcam_devices-1.6.1-py2.py3-none-any.whl (81.9 kB view details)

Uploaded Python 2Python 3

File details

Details for the file hcam_devices-1.6.1.tar.gz.

File metadata

  • Download URL: hcam_devices-1.6.1.tar.gz
  • Upload date:
  • Size: 66.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for hcam_devices-1.6.1.tar.gz
Algorithm Hash digest
SHA256 4fb846ac2eab9cfaf291aa0f8fa8b218e6811bfde886f774e32d0694f5f5b808
MD5 cf3f30648ce24548b30c7e197822b457
BLAKE2b-256 440840dbe95838e015f61c3d556b47b24c4bd758ae68131a63595fcc8e051039

See more details on using hashes here.

File details

Details for the file hcam_devices-1.6.1-py2.py3-none-any.whl.

File metadata

  • Download URL: hcam_devices-1.6.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 81.9 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.5

File hashes

Hashes for hcam_devices-1.6.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b635b6ac6ab41c89ff44d9ea41a27c8f6b7d77f8951a25fb267ebaae984b7bf2
MD5 4e66a4dc5c3ff3131bea5b3cfac6a103
BLAKE2b-256 3f0f0780198132f11284f38c38ddebf9e928a1b2d34bd96a371121b6f6382681

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page