Reusable TOMToolkit app to support gravitational wave superevent and other nonlocalized event EM follow-up observations.
Project description
GW Superevent (or GRB, Neutrino) EM follow-up
This reusable TOM Toolkit app provides support for gravitational wave (GW) superevent and other non-localized event electromagnetic (EM) follow up observations.
Requirements
This TOM plugin requires the use of a postgresql 14+ database backend, since it leverages some postgres specific stuff for MOC volume map lookups.
Installation
-
Install the package into your TOM environment:
pip install tom-nonlocalizedevents
-
In your project
settings.py, addtom_nonlocalizedeventsandwebpack_loaderto yourINSTALLED_APPSsetting:INSTALLED_APPS = [ 'webpack_loader', ... 'tom_nonlocalizedevents', ]
Also include the following Django-Webpack-Loader settings in your settings.py:
VUE_FRONTEND_DIR_TOM_NONLOCAL = os.path.join(STATIC_ROOT, 'tom_nonlocalizedevents/vue') WEBPACK_LOADER = { 'TOM_NONLOCALIZEDEVENTS': { 'CACHE': not DEBUG, 'BUNDLE_DIR_NAME': 'tom_nonlocalizedevents/vue/', # must end with slash 'STATS_FILE': os.path.join(VUE_FRONTEND_DIR_TOM_NONLOCAL, 'webpack-stats.json'), 'POLL_INTERVAL': 0.1, 'TIMEOUT': None, 'IGNORE': [r'.+\.hot-update.js', r'.+\.map'] } }
If
WEBPACK_LOADERis already defined in your settings, then integrate these values in to it.Also add the following to your settings if they are not already there, setting whatever default values you need for your setup. These point to your deployed TOM toolkit instance, and to a hermes instance:
TOM_API_URL = os.getenv('TOM_API_URL', 'http://127.0.0.1:8000') HERMES_API_URL = os.getenv('HERMES_API_URL', 'http://hermes-dev.lco.gtn')
-
Include the tom_nonlocalizedevent URLconf in your project
urls.py:urlpatterns = [ ... path('nonlocalizedevents/', include('tom_nonlocalizedevents.urls', namespace='nonlocalizedevents')), ]
-
Run
python manage.py migrateto create the tom_nonlocalizedevents models. -
Set environment variables below to configure different connections:
| Env variable | Description | Default |
|---|---|---|
SA_DB_CONNECTION_URL |
Location of your django postgres database used for sqlalchemy | by default, this uses Django default DB for the project |
CREDIBLE_REGION_PROBABILITIES |
JSON List of Credible Region probabilities to automatically check each candidate target for | '[0.25, 0.5, 0.75, 0.9, 0.95]' |
SAVE_TEST_ALERTS |
Boolean on if you want to save test nonlocalizedevents into your database (those with event_id beginning with 'M') | true |
-
In your TOM project, make sure to run
python manage.py collectstaticafter installing this app, to collect its Vue pages into yourstaticfilesdirectory. -
If you want to automatically ingest GW events into your TOM, you should also install the
tom_alertstreamsapp into your TOM and configure it to use the tom_nonlocalizedevents handler to ingest GW events. The preferred way is to use the hopigwn.gwalertstopic and set it to the handlertom_nonlocalizedevents.alertstream_handlers.igwn_event_handler.handle_igwn_message. This format has the newest Ligo O4 fields. There is legacy support for the gcn classic over kafka plaintext formatted LVC alerts using the handlertom_nonlocalizedevents.alertstream_handlers.gcn_event_handler.handle_message. There is also a handler to handle retractions via thehandle_retractionmethod in that package. For an example of what needs to be in your settings to configuretom_alertstreamsfor these streams, look here
Development
When any changes are made to this library, the vue files will need to be build and bundled and committed into the repo so that they can be bundled and deployed with the django package. This means that after making any vue changes, you must run npm run build within the tom_nonlocalizedevents_vue directory once, which will install the built files into tom_nonlocalizedevents/static/, and then those built files will need to be committed into the repo. This allows django projects using this library to get those files when running python manage.py collectstatic.
Running the tests
In order to run the tests, run the following in your virtualenv:
python manage.py test
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tom_nonlocalizedevents-0.7.2.tar.gz.
File metadata
- Download URL: tom_nonlocalizedevents-0.7.2.tar.gz
- Upload date:
- Size: 543.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/5.15.0-1036-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
738e5d3e0e4c17292a4e439a54d6fa44c9139bd1a6245e31c500882798143aeb
|
|
| MD5 |
ed251d3ab4c94ea76be6ffb57232f5a0
|
|
| BLAKE2b-256 |
4cf2e7ce52b73472647a90235fcf1698075f9b49201ec9f69f373e1c4259572e
|
File details
Details for the file tom_nonlocalizedevents-0.7.2-py3-none-any.whl.
File metadata
- Download URL: tom_nonlocalizedevents-0.7.2-py3-none-any.whl
- Upload date:
- Size: 560.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.2 CPython/3.11.3 Linux/5.15.0-1036-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cbb3952eb7f8d1ef88da5d4fc51bbb00dae0738910f1eee9c6fb282236ce5925
|
|
| MD5 |
81ae409760b929838470f80d1b597ab7
|
|
| BLAKE2b-256 |
d57f402e9e6932829696028f0f354197e927d3b780c5201d5f6d260f52801904
|