Gravitational waveforms and snr.
Project description
gwsnrcalc is a package designed for fast signal-to-noise ratio (SNR) calculations for single gravitational wave sources using a matched filtering SNR approach. It was originally designed to support BOWIE for Evaluating Black Hole Detectability with LISA (arXiv:1807.02511). It provides a fast SNR calculator, frequency-domain amplitude waveforms for binary black holes, and a SNR grid generator for binary black holes.
The main snr function is gwsnrcalc.gw_snr_calculator.snr. It has the capability to perform calculations in parallel across processors for faster calculation.
The waveform generator (gwsnrcalc.utils.waveforms) creates either circular or eccentric waveforms.
Circular waveforms are created with PhenomD amplitude 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). The current waveforms returned are in units of characteristic strain.
Eccentric waveforms are generated according to Peters evolution only for the inspiral phase.
The snr grid generator: gwsnrcalc.generate_contour_data uses gwsnrcalc.gw_snr_calculator.snr to create SNR grids for contour plots (like those used in BOWIE).
Available via pip and on github: https://github.com/mikekatz04/BOWIE/
Getting Started
These instructions will get you a copy of the project up and running on your local machine for usage and testing purposes.
Prerequisites
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. All 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, and h5py. All can be installed with pip. For example, within your python environment of choice:
pip install astropy
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.
Installation
- Begin with updating conda:
conda update conda
- Create a conda environment (change the name as desired. Default: gwsnr_env):
conda create -n gwsnr_env numpy scipy astropy h5py gsl matplotlib jupyter ipython python=3.7
Installation is done two ways:
using pip
pip install gwsnrcalc
This will download the 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 downloading it from github. This is for all the modules, example jupyter notebooks, and extra files. This method will include BOWIE if pip install is used on the outer directory. To just download specific files that do not come with pip (e.g. jupyter notebook with examples), just download the files from the github.
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 code to add the modules to your environment and compile the c codes.
pip install ./BOWIE/snr_calculator_folder/
Testing and Running an Example
To test the codes, you run the guide notebook.
jupyter notebook pyphenomd_guide.ipynb
Contributing
Please read CONTRIBUTING.md for details on our code of conduct, and the process for submitting pull requests to us.
Versioning
Current version is 1.1.0.
We use SemVer for versioning.
License
This project is licensed under the GNU License - see the LICENSE.md file for details.
Acknowledgments
Thanks to Michael Puerrer, Sebastian Khan, Frank Ohme, Ofek Birnholtz, Lionel London for authorship of the original c code for PhenomD within LALsuite.
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
File details
Details for the file gwsnrcalc-1.1.0.tar.gz
.
File metadata
- Download URL: gwsnrcalc-1.1.0.tar.gz
- Upload date:
- Size: 7.4 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2.post20191203 requests-toolbelt/0.9.1 tqdm/4.41.0 CPython/3.7.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 38214a0651893ca167e04342fc25d1b98f0f0b6345907d3a672fba6c595ad96a |
|
MD5 | 3b25d162e6802c0d5115875876b015e5 |
|
BLAKE2b-256 | af5cc67051c744f6ef51de367b284634ecf931a5399b17879f7ab4f9f425715f |
File details
Details for the file gwsnrcalc-1.1.0-cp37-cp37m-macosx_10_7_x86_64.whl
.
File metadata
- Download URL: gwsnrcalc-1.1.0-cp37-cp37m-macosx_10_7_x86_64.whl
- Upload date:
- Size: 7.6 MB
- Tags: CPython 3.7m, macOS 10.7+ x86-64
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.2.post20191203 requests-toolbelt/0.9.1 tqdm/4.41.0 CPython/3.7.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8228c41963df0e8325a5f1fde8aa084a02186f107bcc494f850e6e55f162a992 |
|
MD5 | cac121297195d2e32b6d13fa576eebdb |
|
BLAKE2b-256 | f34c9de6350fb30ffedcc243cea71877c8edd533da86fb8d8fc206e0070132a0 |