Skip to main content

LOFAR station statistics gather and dump utility, writes station statistics continuously to the local S3 based object storage.

Project description

Stingray

Build status Test coverage

Station statistics gather and dump utility, writes station statistics contiously to the local S3 based object storage.

Installation

pip install .

Usage

To forward (copy) statistics packets, metadata, or matrices from one place to another, use the following command:

l2ss-stingray-forward <source> <destination> --datatype=packet|json

These locations are supported for source and destionation:

  • file:<path>: read/write from a file on disk,
  • tcp://<host>:<port>: receive from/write to a TCP server,
  • udp://<host>:<port>: receive on/write to a UDP server,
  • s3://<host>/<bucket>/<path>: write to an S3 store as JSON (destination only),
  • zmq+tcp://<host>:<port>/<topic>: subscribe to ZMQ server and topic (source only),

The packet datatype is used to process (binary) statistics packets from SDP, and the json datatype is used to process lines of JSON, the encoding used for metadata and matrices.

To convert statistics packets into matrices and publish those using ZMQ, use the following command:

l2ss-stingray-publish <station> <antennafield> <type> <source>

To extract a set of matrices from disk, annotate them with metadata, and write them as HDF5 files, use:

l2ss-stingray-extract <station> <antennafield> <type> <from> <to> <source> <destination>

Example

The following commands, when started in parallel in the order listed, will convert the XST packets in tests/xst-packets.bin to JSON matrices in xst-matrices.txt:

# start converter & publisher
l2ss-stingray-publish cs123 hba xst udp://0:5000

# catch output of publisher
l2ss-stingray-forward -d json 'zmq+tcp://localhost:6001/xst?content_type=application/json' file:xst-matrices.txt

# provide input to converter
l2ss-stingray-forward file:tests/xst-packets.bin udp://127.0.0.1:5000

Contributing

To contribute, please create a feature branch and a "Draft" merge request. Upon completion, the merge request should be marked as ready and a reviewer should be assigned.

Verify your changes locally and be sure to add tests. Verifying local changes is done through tox.

pip install tox

With tox the same jobs as run on the CI/CD pipeline can be run. These include unit tests and linting.

tox

To automatically apply most suggested linting changes execute:

tox -e format

License

This project is licensed under the Apache License Version 2.0

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

lofar_stingray-0.0.33.tar.gz (88.1 kB view details)

Uploaded Source

Built Distribution

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

lofar_stingray-0.0.33-py3-none-any.whl (39.6 kB view details)

Uploaded Python 3

File details

Details for the file lofar_stingray-0.0.33.tar.gz.

File metadata

  • Download URL: lofar_stingray-0.0.33.tar.gz
  • Upload date:
  • Size: 88.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for lofar_stingray-0.0.33.tar.gz
Algorithm Hash digest
SHA256 1b96ebbc85bb57ff2caef91b4460cfdbde15ebb4c7b989afbb61f124ba11a127
MD5 78504fa9105ef2a6bc00c3dcbdbcff8c
BLAKE2b-256 423e0722f951c6c1b3010fcd5a3ca0cf6322d8fcb63e1309d88ce858cab0bb94

See more details on using hashes here.

File details

Details for the file lofar_stingray-0.0.33-py3-none-any.whl.

File metadata

File hashes

Hashes for lofar_stingray-0.0.33-py3-none-any.whl
Algorithm Hash digest
SHA256 b249f22189fa79b8597d0b9207040dc7110323c5b13edc0cf1da4ccf6006261a
MD5 dcabf8597366fefd147a881b36bbea2d
BLAKE2b-256 a3660a8c449c78b03b82b61c4e10ff9edada89564f8d2a49b063de1c6c6c6380

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