This repository contains software to control and monitor a Phantom HV crate via Ethernet. The Phantom HV hardware is a modular 3-RU system that combines high-voltage supplies and high-frequency pulse pick-off circuits to operate photomultiplier tubes (PMTs). It has been designed for the SWGO and lab applications.
You can find the newest packaged release of this library on PyPi. Untagged versions are released on TestPyPi as well.
Install via pip install phantom-hv
.
Upgrade to the newest release with pip install -U phantom-hv
.
- Python 3 for the core library and command-line interface
- nicegui, pywebview, plotly and numpy for the Web UI (install via conda/mamba
or pip)
- note that pywebview (which is only needed for displaying the UI in a native
application window) may require additional GUI framework components with
Python extensions, especially on an otherwise headless server (e.g. by
installing
pywebview[qt]
, see the documentation)
- note that pywebview (which is only needed for displaying the UI in a native
application window) may require additional GUI framework components with
Python extensions, especially on an otherwise headless server (e.g. by
installing
If installed via pip this library provides two tools:
phantomhv-ctl
is a command-line interface to control and monitor a Phantom HV modulephantomhv-webui
provides a web interface with realtime plotting
usage: phantomhv-ctl [-h] {boot,reset,flash,unlock-hv,lock-hv,enable-hv,disable-hv,set,monitor} ...
Low-level control and monitoring command-line tool for Phantom HV modules.
positional arguments:
{boot,reset,flash,unlock-hv,lock-hv,enable-hv,disable-hv,set,monitor}
boot boot application slot
reset reset into bootloader
flash flash binary firmware image into application slot
unlock-hv enable HV
lock-hv disable HV
enable-hv enable HV channel
disable-hv disable HV channel
set set hardware registers
monitor continuously read and print slave states
options:
-h, --help show this help message and exit
usage: phantomhv-webui [-h] [--address ip:port] [--num-slots {1,2,3,4,5,6,7,8}] [--show | --bind hostname:port]
Web UI to monitor and control a Phantom HV crate.
options:
-h, --help show this help message and exit
--address ip:port IP address or hostname of the device (default: 192.168.1.115:512)
--num-slots {1,2,3,4,5,6,7,8}
number of modules to display (default: 1)
--show open UI in native window
--bind hostname:port bind web server to a specific network interface/port (default: 127.0.0.1:8080; use 0.0.0.0 to bind to all interfaces)