Skip to content

Latest commit

 

History

History
148 lines (125 loc) · 9.13 KB

README.md

File metadata and controls

148 lines (125 loc) · 9.13 KB

Software

This directory contains the files to reproduce the analysis in The Directional Isotropy of LIGO-Virgo binaries (Isi+2023), from data publicly avaliable in Zenodo: parameter estimation data releases from GWOSC and LIGO-Virgo selection function injections 10.5281/zenodo.5546676; intermediate data products produced in our analysis are cached in 10.5281/zenodo.7775266.

When compiling the manuscript, showyourwork will automatically use cached data products to speed of the computation (see instructions below).

Code guide

Every quantitative element in the paper can be traced back to a piece of code through the snakemake workflow defined by the showyourwork.yml and Snakemake files located in the root directory of this repository---see below for a visual representation of the Directed Acyclic Graph (DAG) encoding this workflow. The code is mainly written in Python, and the core computations happen inside the utils/ packge described below.

The relation between all these different pieces of software and data is as follows:

graph TD;
    A[(10.5281/zenodo.5546676)]-->compute_selection.py;
    compute_selection.py --> S(vectors_sel.hdf5):::data;
    classDef data fill:#fbf
    S --> F((hierarchical_fit.py)):::script;
    B[(GWOSC)]--> |download_gwosc_pe.py|PE(pe_gwosc_o3/):::data;
    PE --> compute_vectors.py;
    compute_vectors.py --> D(vectors_bbh.pkl):::data;
    D --> F;
    F --> R(gwisotropy_result.nc):::data;
    F2a{{dipole_skymap_j.png}}:::fig --> corner_plot.py;
    classDef fig fill:#f96
    F2b{{dipole_skymap_n.png}}:::fig --> corner_plot.py;
    SKY[/setup_dipole_skymaps.py/] -.-> F2a;
    SKY -.-> F2b;
    R --> corner_plot.py;
    corner_plot.py --> F2{{jn_corner.pdf}}:::fig;
    F2 --> M{manuscript};
    R --> density_3d_plot.py;
    density_3d_plot.py --> F3a{{density_3d_j.pdf}}:::fig;
    density_3d_plot.py --> F3b{{density_3d_n.pdf}}:::fig;
    density_3d_plot.py --> F3c{{density_3d_prior.pdf}}:::fig;
    R -.-> SKY;
    F3a --> M;
    F3b --> M;
    F3c --> M;
    R --> norm_plot.py;
    norm_plot.py --> F4{{jn_norm.pdf}}:::fig;
    F4 --> M;
    R --> make_macros.py;
    make_macros.py --> m>macros.tex];
    m --> M;
    R --> make_table.py;
    make_table.py --> e>events.tex];
    e --> M;
    NB[/gwiso_vector_plots.nb/] -.-> F1a{{gw_orientation_iso.pdf}}:::fig;
    NB -.-> F1b{{gw_orientation_dip.pdf}}:::fig;
    NB -.-> F1c{{gw_orientation_inc.pdf}}:::fig;
    F1a --> M;
    F1b --> M;
    F1c --> M;
    prior_plot.py --> P{{prior.pdf}}:::fig;
    P --> M;
    D --> control_selection.py;
    S --> control_selection.py;
    control_selection.py --> CSEL(control_selection/):::data;
    CSEL --> plot_control_selection.py;
    plot_control_selection.py --> CSELPLOT{{control_selection.pdf}}:::fig;
    CSELPLOT --> M;
    SKYALL[/setup_event_skymaps.py/] -.-> SMAPS{{skymap_j_*.pdf}}:::fig
    D -.-> SKYALL;
    SMAPS --> s>skymaps.tex];
    make_skymap_figure.py --> s;
    s --> M;
    X[(10.5281/zenodo.7843926)]-->|control_rates_get_lvk_pop.py|RP(control_rates_powerlawpeak_map.txt):::data;
    RP --> control_rates_compute_selection.py;
    control_rates_compute_selection.py --> CS(control_rates_vectors_sel.hdf5):::data;
    CS --> CF(control_rates_hierarchical_fit.py):::script
    RP --> control_rates_compute_vectors.py;
    control_rates_compute_vectors.py --> CD(control_rates_vectors_bbh.pkl):::data;
    CD --> CF;
    CF --> CR(control_rates_gwisotropy_result.nc):::data;
    CR --> control_rates_plot.py;
    R --> control_rates_plot.py;
    control_rates_plot.py --> CF2{{contro_rates_jn_corner.pdf}}:::fig;
    CF2 --> M{manuscript};
Loading

In this diagram, figures are represented in orange; datasets produced by this code as pink and scripts in light blue. Datasets downloaded from zenodo are represtented by their DOI and a "database" symbol; tex files and scripts also have characterisitc shapes.

The key executables to perform the analyses in the paper are:

  • hierarchical_fit.py: main script carrying out the hierarchical Bayesian fit to LIGO-Virgo data shown in Figs. 2-4, whose result is cached to gwisotropy_result.nc; to run, it requires outputs from the following scripts (our, equivalently, their cached data products):
    • compute_selection.py: loads LIGO-Virgo selection injections from 10.5281/zenodo.5546676 and computes the corresponding $\vec{N}$ and $\vec{J}$ vectors, whose Cartesian compnents are cached to vectors_sel.hdf5 (6 numbers per injection).
    • compute_vectors.py: loads LIGO-Virgo samples for real detections obtained from GWOSC and computes the corresponding $\vec{N}$ and $\vec{J}$ vectors, whose Cartesian compnents are cached to vectors_bbh.pkl (6 numbers per sample per event).
  • control_selection.py: similar to hierarchical_fit.py but recursively carries out fits to an increasing number of synthetic draws from the injection selection set to produce the result in Fig. 5; the result of each fit is saved to a directory called control_selection/; it also requires vectors_sel.hdf5 and vectors_bbh.pkl as input.
  • control_rates_hierarchical_fit.py: carries out the the fit to LIGO-Virgo data as in hierarchical_fit.py, but this time based on measurements reweighted to a different mass and spin model, to produce the resultin Fig. 6; it depends on output from the following scripts:
    • control_rates_compute_selection.py: similar to compute_selection.py but reweighting to a different astro population; outputs control_rates_vectors_sel.hdf5.
    • control_rates_compute_vectors.py: similar to compute_vectors.py but reweighting to a different astro population; outputs control_rates_vectors_bbh.pkl.

The results produced by the above three scripts are fed into plotting scripts that produce the figures in the paper:

  • Figure 1: gwiso_vector_plots.nb the only Mathematica notebook, creates the diagrams in Fig. 1.
  • Figure 2: corner_plot.py plots corner plot in Fig. 2; requires gwisotropy_result.nc, with an additional preprocessing step:
    • setup_dipole_skymaps.py makes the skymaps shown in the inset of Fig. 2.
  • Figure 3: density_3d_plot.py makes the 3D density plots in Fig. 3, loads gwisotropy_result.nc directly.
  • Figure 4: norm_plot.py plots the posteriors and prior for the $\vec{N}$ and $\vec{J}$ measurements, shown in Fig. 4, depends only on gwisotropy_result.nc.
  • Figure 5: plot_control_selection.py creates the corner plot for all fits in Fig.5, reading in fits from control_selection/.
  • Figure 6: control_rates_plot.py plots the result in Fig. 6 based on control_rates_gwisotropy_result.nc and gwisotropy_result.nc.
  • Figure 7: prior_plot.py
  • Figure 8: make_skymap_figure.py collates skymap plots for all events created using ligo.skymap by L. Singer et al (see setup_event_skymaps.py)

Finally, two scripts collate information to make tables and macros for the paper:

  • make_macros.py
  • make_table.py

Utilities

The scripts rely on a small Python package provided in the utils directory, which contains its own documentation.

The utilities are split up over a number of files in utils/ with the following purposes (key elements in bold):

  • inference.py: defines the statistical models used for sampling the hierarchical posterior using PyMC
  • plots.py: contains lightweight plot settings
  • pops.py: contains utilities for reweighting samples to different populations
  • prior.py: containts a single function to draw vectors from our hierarchical prior
  • settings.py: containts settings for hierarchical analysis and reweighting
  • transf.py: contains code required to compute Cartesian components for $\vec{N}$ and $\vec{J}$ starting from LIGO-Virgo samples

See inside each file for docstrings documenting usage.

Installation

The environment requirements to execute these scripts are specified in the environment.yml in the source directory; if not using showyourwork, this can be used to create a compatible Conda environment by doing, e.g.,

conda env create -f environment.yml

As of Nov 2023, you might need a custom backwards-compatible version of showyourwork for this to work hosted here. You can install it through pip by doing:

pip install -U git+https://github.com/maxisi/showyourwork.git@gwisotropy

You can then simply build the article by calling the following from within the rootdir of this repository:

showyourwork build

Some intermediate data products are generated in the process and cached by showyourwork to speed up computation and skip some intermediate steps. The cached data products will be automatically downloaded from 10.5281/zenodo.7775266 when using showyourwork.