Skip to content

Tool for rapid response to astrophysical transients with the IceCube Neutrino Observatory

Notifications You must be signed in to change notification settings

icecube/FastResponseAnalysis

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Fast Response Analysis

Overview

The fast response analysis is a way of using established transient likelihood methods to quickly respond to astronomical events of interest in realtime.

The current implementation houses the code for responding to

  • Generic externally triggered transients (eg. bright GRBs or blazar flares)
  • IceCube alert events
  • Gravitational Wave events

Dependencies

To install all dependencies external from IceCube software, we recommend creating a virtual environment, and pip installing the required packages, which are given in the file requirements.txt. This can be set up using (current FRA uses Python 3.7.5):

python3 -m venv fra_env
source fra_env/bin/activate
pip install -r /path/to/fast-response/requirements.txt

This will create a virtual environment named fra_env, and the source fra_env/bin/activate line will activate the environment.

You should then install fast_response into this environment by navigating into the FastResponseAnalysis and running

pip install -e .

The docs are built using Sphinx. If you want to build your own set of docs, you should also pip install sphinx to the environment, and the docs can be built following the instructions in the Sphinx docs here.

This package also has dependencies on IceCube software, specifically IceTray, realtime, and Skylab. realtime is a parasitic metaproject, meaning you need a built version of icetray before building the realtime environment.

After you have a version of IceTray installed and built, you will want to do a parasitic build of the realtime project, building off of this version of icetray. To do this, navigate to a new directory where you want your realtime project to live, and run

git clone git@github.com:icecube/realtime.git src
mkdir build
cd build
cmake ../src/ -DMETAPROJECT=/path/to/icerec/build/ -DCMAKE_INSTALL_PREFIX=icerec-plus.${OS_ARCH}
make

You can now load the realtime project with

/path/to/realtime/build/env-shell.sh

In the future, you will not need to jump through these hoops, and you can load the environment with these lines:

[PATH_TO_REALTIME]/realtime/build/env-shell.sh
source [PATH_TO_VENV]/fra_env/bin/activate

Options

To specify where the output should go, you can set the environment variable with

export FAST_RESPONSE_OUTPUT=[PATH_TO_OUTPUT_DIR]

You can also specify where the scripts directory is, using another environment variable:

export FAST_RESPONSE_SCRIPTS=[PATH_TO_SCRIPTS]

Tutorial — externally triggered analysis

In order to perform a short timescale followup using the realtime GFU stream, you need only know:

  1. The time window of interest
  2. The location of the source (either RA, Dec or localization probability skymap)

In order to run an analysis, navigate to the directory containing run_external_followup.py. All you need to do is

python run_external_followup.py --name="Fast Response Test" --start="2020-01-01 12:00:00.00" --stop="2020-01-02 12:00:00.0" --ra=250.0 --dec=45.0

You can either pass the location as an RA, DEC or pass a skymap with --skymap=/path/to/skymap (this can be a url or a path). After a few seconds, you should see the following screen:

********************************************************************************
 _____         _     ____                                      
|  ___|_ _ ___| |_  |  _ \ ___  ___ _ __   ___  _ __  ___  ___ 
| |_ / _` / __| __| | |_) / _ \/ __| '_ \ / _ \| '_ \/ __|/ _ \
|  _| (_| \__ \ |_  |  _ <  __/\__ \ |_) | (_) | | | \__ \  __/
|_|  \__,_|___/\__| |_| \_\___||___/ .__/ \___/|_| |_|___/\___|
                                   |_|                         
 _____     _ _                           
|  ___|__ | | | _____      ___   _ _ __  
| |_ / _ \| | |/ _ \ \ /\ / / | | | '_ \ 
|  _| (_) | | | (_) \ V  V /| |_| | |_) |
|_|  \___/|_|_|\___/ \_/\_/  \__,_| .__/ 
                                  |_|    

********************************************************************************

Working on unscrambled (UNBLINDED) data
********************************************************************************
*                                                                              *
*                            Fast Response Example                             *
*                                                                              *
********************************************************************************
          2020-01-01 12:00:00.000          2020-01-02 12:00:00.000
          RA, dec.: 250.00, 45.000          Extension: 0.0

This printout is meant as a double check for the user, to ensure that the proper source details were passed. This includes a warning that the analysis is being performed on UNBLINDED data. If you want to run an analysis on scrambled data for verification, include the string test anywhere in the name argument of the run_external_followup.py script.

It will then take about one minute to initialize all relevant objects for the likelihood analysis. If everything ran properly, after messages about time to initialize, you will see a printout with the best-fit ns value as well as the test statistic. If the best-fit ns is zero, then no background trials will be run (p=1.0), otherwise, 1000 background trials will be run to quantify the significance.

After this, an upper limit will be calculated. You should see a printout like:

Beginning upper limit calculation
Initializing Point Source Injector
Found upper limit of 2.44 events

If the analysis was run on a short time window and the best-fit ns was 0, a nice sanity check is that this number should be within about 10% from 2.3 events. Once the analysis is complete, there will be some performance plots that are generated and saved to a folder. A pdf report is also generated in this folder.

Additionally, the following arguments can be passed at the command line:

  • --extension source extension in degrees for following up extended sources
  • --skip-events=run_id:event_id for removing events from the analysis (ie when following up high energy events)
  • --ntrials to change the number of background trials performed in the case of a non-zero TS
  • --n_per_sig to change the number of signal trials performed when calculating the upper limit

Tutorial - Alert followup

To run the analysis to follow up an alert event, you will either run run_track_followup.py or run_cascade_followup.py depending on which alert type you are following up. You need to wait until at least 24 hours after the alert event time in order to run the analysis.

In order to run this analysis, you should find the alert event time (sent in the GCN notice, and also written in a GCN Circular, if sent). You'll need to convert the ISO UTC time to MJD (I recommend this tool). You'll also need the alert run number and event number.

Once you have these details, you can run the analysis with

python run_track_followup.py --skymap=/home/followup/output_plots/run{RUNID}.evt{EVENTID}.neutrino_8_64_512_1024.skymap_nside_1024.fits.gz --time={ALERT_MJD} --alert_circ={GCN_CIRCULAR_NUMBER} --alert_id={RUNID}:{EVENTID}

This will run two analyses, one with a time window of 1000 seconds and one with a time window of 2 days, both centered on the alert time. It will also remove the alert event from the sample, and it will assume a spectral index of -2.5, which is different than the -2 used for the run_external_followup.py script.

Tutorial — Gravitational wave followup

To run the analysis to follow up a graviational wave event, you will need to navigate to the directory including run_gw_followup.py. You need to know:

  1. The name of the GW event
  2. The time of the GW
  3. A link to the skymap for the GW (can be a string url link or a path if run on the cobalts

As an example, there is a sample map included here: fast_response/sample_skymaps/S191216ap_update.xml. To run this event, the input would look like:

python run_gw_followup.py --name="S191216ap Update" --time=58833.89836 --skymap="https://gracedb.ligo.org/api/superevents/S191216ap/files/LALInference.fits.gz,0"

Additionally, you can choose to pass the argument --allow_neg_ts (bool) if you want to use the convention where a negative TS is allowed. The default is to use the convention TS>=0.

When running the code, you will see a printout like (similar to the externally triggered follow up):

********************************************************************************
  ______        __  _____     _ _                           
 / ___\ \      / / |  ___|__ | | | _____      ___   _ _ __  
| |  _ \ \ /\ / /  | |_ / _ \| | |/ _ \ \ /\ / / | | | '_ \ 
| |_| | \ V  V /   |  _| (_) | | | (_) \ V  V /| |_| | |_) |
 \____|  \_/\_/    |_|  \___/|_|_|\___/ \_/\_/  \__,_| .__/ 
                                                     |_|    

********************************************************************************
Working on unscrambled (UNBLINDED) data
Grabbing data

Performance plots will be saved and a report with the results generated in the same way as the above analyses. The output directory is specified in the same way as above, with the FAST_RESPONSE_OUTPUT environment variable.

Contacts

Please send any questions or feature requests to: