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.73.tar.gz (108.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.73-py3-none-any.whl (66.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: lofar_stingray-0.0.73.tar.gz
  • Upload date:
  • Size: 108.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.12

File hashes

Hashes for lofar_stingray-0.0.73.tar.gz
Algorithm Hash digest
SHA256 83c77dd0dba52c279e3e93cb60445dce28d0e0cd70e4352667b7dd8a9e0a63b5
MD5 b8c2105eb35ea74c1f1b5a537580d854
BLAKE2b-256 512bfc6b42e706fdc4cb053bbb17ac31ef11020801efb890dfc749fa482f79bc

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for lofar_stingray-0.0.73-py3-none-any.whl
Algorithm Hash digest
SHA256 67792cab03f435d406a1087179a7b91a1267bcaf8da66665f9588ac78ae421bb
MD5 953cc4a093d34480235c13ccd4f1b216
BLAKE2b-256 16badf83fc9bf13b8dd32347bfee119ef7536899416dc7d6c8f16801d7749363

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