BOWIE: Binary Observability With Illustrative Exploration
BOWIE is a tool designed for graphical analysis of binary signals from gravitational waves. It takes gridded data sets and produces different types of plots in customized arrangements for detailed analysis of gravitational wave sensitivity curves and/or binary signals. The paper detailing this tool and examples of its usage can be found at arXiv:1807.02511 (Evaluating Black Hole Detectability with LISA). There are three main portions of the code: a gridded data generator (
snr_calculator.generate_contour_data.py), a plotting tool (
bowie.make_plot.py), and waveform generator for general use (
snr_calculator.utils.pyphenomd.py). The waveform generator creates PhenomD waveforms for binary black hole inspiral, merger, and ringdown. PhenomD is from Husa et al 2016 (arXiv:1508.07250) and Khan et al 2016 (arXiv:1508.07253). Gridded data sets are created using the PhenomD generator for signal-to-noise (SNR) analysis. Using the gridded data sets, customized configurations of plots are created with the plotting package.
The three plots to choose from are Waterfall, Ratio, and Horizon. A Waterfall plot is a filled contour plot similar to figure 3 in the LISA Mission Proposal (arxiv:1702.00786). Ratio plots show the ratio of SNRs between two different binary and sensitivity configurations. They also include loss/gain contours showing where two configurations differ in terms of the sources they can and cannot detect. Horizon plots show line contours of multiple configurations for a given SNR value. See the original paper and notebook examples for more information.
Note: The remainder of this introduction specifically details installation of the plotting module. It is very adaptable to different gravitational wave sources or other measurements with similar signal-to-noise properties. The
snr_calculator package is listed as a requirement for BOWIE (meaning the plotting module). This package is installed with the bowie install, however, it is available separately from the plotting module. For this purpose, it has its own README and documentation here.
These instructions will get you a copy of the project up and running on your local machine for usage and testing purposes.
Available via pip and on github: https://github.com/mikekatz04/BOWIE
It is best to run out of conda environment. It will handle the dependencies better. If you have issues with certain modules, try to update them.
Software installation/usage only requires a few specific libraries in python. If you install with pip, all of these libraries should be automatically installed if you do not have them (this includes
snr_calculator, which is required). All python libraries are included with Anaconda. If you do not run python in an anaconda environment, you will need the following libraries and modules to run with all capabilities: Numpy, Scipy, collections, sys, json, multiprocessing, datetime, time, astropy, h5py, and matplotlib. All can be installed with pip. For example, within your python environment of choice:
pip install h5py
In order to properly create waveforms with ctypes, you will need complex, gsl, and math c libraries. For installing gsl, refer to https://www.gnu.org/software/gsl/ or install it through anaconda.
gwsnrcalc is also required. This will install automatically with pip install or setup.py.
- Begin with updating conda:
conda update conda
Installation is done two ways:
- using pip
pip install bowie
This will download all necessary packages to your current environment. It will not download the notebooks for testing and example usage.
- Clone the git repo on the command line, or download it from github. This is for all the modules, example jupyter notebooks, and extra files.
- navigate to the directory of your choice.
- clone the git repo on the command line.
git clone https://github.com/mikekatz04/BOWIE.git
- pip install the local files to add the modules to your environment and compile the c codes.
pip install ./BOWIE/
Testing and Running an Example
To test the codes, you run the testing notebook.
jupyter notebook quick_testing_example.ipynb
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
Current version is 2.0.0.
We use SemVer for versioning.
- Michael Katz - mikekatz04
Please email the author with any bugs or requests.
This project is licensed under the GNU License - see the LICENSE.md file for details.
- Thanks to Michael Puerrer, Sebastian Khan, Frank Ohme, Ofek Birnholtz, Lionel London for authorship of the original c code for PhenomD within LALsuite.