Skip to main content

LIGO/Virgo/KAGRA Follow-up Advocate Tools

Project description

LIGO Follow-up Advocate Tools

This package provides tools for LIGO/Virgo/KAGRA follow-up advocates to assist in tasks such as drafting astronomical bulletins for gravitational-wave detections.

To install

The easiest way to install ligo-followup-advocate, is with pip:

pip install --user ligo-followup-advocate

To upgrade

Once you have installed the package, to check for and install updates, run the following command:

pip install --user --upgrade ligo-followup-advocate

Current templates

If you wish to just see examples of the current templates or submit these to be reviewed in P&P, you can find them here.

Example

ligo-followup-advocate provides a single command to draft a GCN Circular skeleton. Pass it the authors and the GraceDB ID as follows:

ligo-followup-advocate compose \
    'A. Einstein (IAS)' 'S. Hawking (Cambridge)' \
    'I. Newton (Cambridge)' 'Data (Starfleet)' \
    'S190407w'

Optionally, you can have the program open the draft in your default mail client by passing it the --mailto option.

For a list of other supported commands, run:

ligo-followup-advocate --help

For further options for composing circulars, run:

ligo-followup-advocate compose --help

You can also invoke most functions directly from a Python interpreter, like this:

>>> from ligo import followup_advocate
>>> text = followup_advocate.compose('S190407w')

To develop

To participate in development, clone the git repository:

git clone git@git.ligo.org:emfollow/ligo-followup-advocate.git

To release

The project is set up so that releases are automatically uploaded to PyPI whenever a tag is created. Use the following steps to issue a release. In the example below, we are assuming that the current version is 0.0.5, and that we are releasing version 0.0.6.

  1. Check the latest pipeline status to make sure that the master branch builds without any errors.

  2. Before making any changes, switch to the master branch and incorporate the changes going into this release:

    git fetch upstream
    git checkout master
    git rebase upstream/master
    
  3. Make sure that all significant changes since the last release are documented in CHANGES.md. If missing, make additional entries.

  4. Update the heading for the current release in CHANGES.md from 0.0.6 (unreleased) to 0.0.6 (YYYY-MM-DD) where YYYY-MM-DD is today's date. Also update the version in pyproject.toml similarly. Save both files once done.

  5. Update the PDF templates with this new version.

  6. Check these files were changed and saved properly

    git status
    
  7. Commit those changes:

    git commit -a -m "Update changelog for version 0.0.6"
    
  8. Tag the release:

    git tag v0.0.6 -m "Version 0.0.6"
    
  9. Add a new section to CHANGES.md like this:

    ## 0.0.7 (unreleased)
    
    -   No changes yet.
    

    You can also consider updating the version in pyproject.toml and template.tex as was done above in preparation for the next release.

  10. Commit the changes:

    git commit -a -m "Back to development"
    
  11. Check that the changes worked correctly:

    git log
    

    You should see the top three commits look like the following:

    commit fc5b54cfb926f3e0265fd10e0501e3b403e7d88c (HEAD -> master)
    Author: Brandon Piotrzkowski <brandon.piotrzkowski@ligo.org>
    Date:   Mon Jun 23 11:18:49 2025 -0400
    
        Back to development
    
    commit 14c43f49022f51d5c72309dc7306171953011516 (tag: v0.0.6)
    Author: Brandon Piotrzkowski <brandon.piotrzkowski@ligo.org>
    Date:   Mon Jun 23 11:17:24 2025 -0400
    
        Update changelog for version 0.0.6
    
    commit d0e9075484992e75b4d1aa4dba02a962b990b84c (upstream/master)
    Author: Deep Chatterjee <deep.chatterjee@ligo.org>
    Date:   Wed Jun 18 20:02:00 2025 +0000
    
        add cgmi information, update skymap filename for aframe events; fix #158
    

    You should see upstream/master for the third commit, the the correct tag name in the second commit, and the top commit coming after both.

  12. If these two new commits look good, push everything to GitLab:

    git push upstream && git push upstream --tags
    

    Within a few minutes, the new package will be built and uploaded to PyPI.

  13. If the changes of this release significantly impact the text of the example templates, upload the PDF of templates created from the publish CI job to DCC. Initiate P&P review and address comments in a new release. Note that it may take multiple releases to get P&P approval.

  14. Once P&P approval has been given, create an SCCB ticket. Note that there is an option to do this via the a button in the CI/CD pipeline, but this template could be outdated. The recommendation is to create the ticket by hand via the above link.

  15. Once the SCCB ticket has been created, created a merge request to update this version in gwcelery if this has not already been done. You can check the current version used via the poetry.lock file. This will involve using poetry, so having this installed and being familiar with the commands will be needed.

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

ligo_followup_advocate-1.3.6.tar.gz (12.3 MB view details)

Uploaded Source

Built Distribution

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

ligo_followup_advocate-1.3.6-py3-none-any.whl (12.4 MB view details)

Uploaded Python 3

File details

Details for the file ligo_followup_advocate-1.3.6.tar.gz.

File metadata

  • Download URL: ligo_followup_advocate-1.3.6.tar.gz
  • Upload date:
  • Size: 12.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for ligo_followup_advocate-1.3.6.tar.gz
Algorithm Hash digest
SHA256 1404e1c4575b0a158c3dd6b977999d1bd2dc32651ff802ebb757cab672c9c205
MD5 c6837403794f568f69017709b5eccd68
BLAKE2b-256 e51e6a5ce3a5aefea43023c6add68eca4c8b67e6856c0862aa5f2d012a01fd22

See more details on using hashes here.

File details

Details for the file ligo_followup_advocate-1.3.6-py3-none-any.whl.

File metadata

File hashes

Hashes for ligo_followup_advocate-1.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 1817f923270087800fa471154c8c47e964a611f06fd8c2fa2ef987126d628028
MD5 80600a4736fa9c2eba2d3d4ba8eda8f7
BLAKE2b-256 b75498ac6c1117f97a0882866735ed3f7e1888b5ae7511c5b6c39cca126acaa4

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