Anonymous VOEvent client for receiving GCN/TAN notices in XML format
Project description
PyGCN
Anonymous VOEvent client for receiving GCN/TAN notices in XML format
The Gamma-ray Coordinates Network/Transient Astronomy Network (GCN/TAN) is a system for distributing astronomical alerts, largely focused on operations of and detections from high-energy satellite missions.
GCN/TAN disseminates both Notices (prompt, machine-readable alerts) and Circulars (human-readable correspondence) through a handful of delivery methods and formats.
This package implements a simple client that listens for VOEvent XML format notices over the custom TCP/IP VOEvent Transport Protocol. By default, it connects to one of the anonymous GCN/TAN server, so no sign-up or configuration is necessary to begin receiving alerts.
Installation
To install PyGCN, simply run:
$ pip install --user pygcn
Usage
PyGCN provides an example script called pygcn-listen
that will simply write
all VOEvents that it receives to files in the current directory. To try it out,
simply run:
$ pygcn-listen
and then type Control-C to quit.
Writing a custom GCN handler
You can also write your own handler that performs a custom action for every GCN
that is received. A handler function takes two arguments: payload
, the raw
content of the GCN, and root
, the root element of the XML document as parsed
by lxml.etree
. Here is a basic example:
#!/usr/bin/env python
import gcn
# Define your custom handler here.
def handler(payload, root):
# Get the IVORN, or unique VOEvent ID, and print it.
print(root.attrib['ivorn'])
# Print all of the event attributes.
for param in root.findall('./What/Param'):
name = param.attrib['name']
value = param.attrib['value']
print('{} = {}'.format(name, value))
# Listen for VOEvents until killed with Control-C.
gcn.listen(handler=handler)
Filtering
You can also filter events by notice type using
gcn.include_notice_types
or gcn.exclude_notice_types
.
Here is an example:
#!/usr/bin/env python
import gcn
# Define your custom handler here.
@gcn.include_notice_types(
gcn.notice_types.FERMI_GBM_FLT_POS, # Fermi GBM localization (flight)
gcn.notice_types.FERMI_GBM_GND_POS, # Fermi GBM localization (ground)
gcn.notice_types.FERMI_GBM_FIN_POS) # Fermi GBM localization (final)
def handler(payload, root):
# Look up right ascension, declination, and error radius fields.
pos2d = root.find('.//{*}Position2D')
ra = float(pos2d.find('.//{*}C1').text)
dec = float(pos2d.find('.//{*}C2').text)
radius = float(pos2d.find('.//{*}Error2Radius').text)
# Print.
print('ra = {:g}, dec={:g}, radius={:g}'.format(ra, dec, radius))
# Listen for VOEvents until killed with Control-C.
gcn.listen(handler=handler)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pygcn-1.1.3.tar.gz
.
File metadata
- Download URL: pygcn-1.1.3.tar.gz
- Upload date:
- Size: 30.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cc74d365e9b53bd909ec7c4c0d36badf327c848f1481909669f099526fde66dc |
|
MD5 | 41caf34d468680d049a6aaca2b5da501 |
|
BLAKE2b-256 | 27e957246fe197bb9478742d601398796224aefe509bc7f00f39c276dfb2be8f |
File details
Details for the file pygcn-1.1.3-py3-none-any.whl
.
File metadata
- Download URL: pygcn-1.1.3-py3-none-any.whl
- Upload date:
- Size: 30.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.13
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 732f4c45242fd5e631a6d302a6174bf3b3c9be91a9f2adaa25f4ffdd21e6a172 |
|
MD5 | 1c12d8f0186ecaaf997262402774467c |
|
BLAKE2b-256 | 8ad2f5b49358dd8b86b3476ba5ba8fdb77632a1a88d11ad799d56a2abbaaf82d |