A Backwards-One-Body Gravitational Waveform Package
Project description
gwBOB
The Backwards-One-Body Gravitational Waveform Package
Getting Started
Please see more detailed documentation here!
What is the Backwards One Body Model?
The Backwards One Body (BOB) model is an analytical and physically motivated approach to modeling gravitational waveforms from black hole binary mergers, as described in arXiv:1810.00040. The BOB model is based on the physical insight that, during the late stages of binary evolution, the spacetime dynamics of the binary system closely resemble a linear perturbation of the final, stationary black hole remnant.
Features
- Analytical accuracy: Closed form expressions for the amplitude and frequency evolution.
- Minimally Calibrated: Requires minimal calibration to numerical relativity (NR)
- Test all BOB flavors Easily generate and switch between different "flavors" of BOB depending on your research problem.
- Easy initialization Easy initialization using SXS, CCE, or raw NR data.
- Beyond Kerr waveforms Compare NR data to BOB waveforms generated with custom QNMs.
- Easy comparisons: Easy comparisons to waveforms from the public SXS and CCE catalog, as well as raw NR data.
- Well Documented and Actively Developed
Generate plots like these with just a few lines of code!
Requirements
- (Windows users should use WSL)
kuibitsxsqnmfitsscrijax(install the GPU compatible version if possible)sympynumpyscipymatplotlib
Install via pip
pip install gwBOB
Running the Tests
If you've cloned the repo and want to run the test suite:
cd BackwardsOneBody/
pip install -e ".[tests]"
# Unit tests are fast and need no external data:
pytest tests/unit/
# Integration tests need ~90 MB of waveform data from the SXS catalog and
# the Zenodo CCE record. Fetch it once:
python tests/fetch_data.py
pytest tests/
Citing this Code
If you use this code please cite
@article{mcwilliams2019analytical,
title={Analytical black-hole binary merger waveforms},
author={McWilliams, Sean T},
journal={Physical review letters},
volume={122},
number={19},
pages={191102},
year={2019},
publisher={APS}
}
@misc{kankani2025bobwaveformbuilderoptimizing,
title={BOB the (Waveform) Builder: Optimizing Analytical Black-Hole Binary Merger Waveforms},
author={Anuj Kankani and Sean T. McWilliams},
year={2025},
eprint={2510.25012},
archivePrefix={arXiv},
primaryClass={gr-qc},
url={https://arxiv.org/abs/2510.25012},
}
JOSS paper to be added. If you have any issues with this code, want any new features, or use this code for your own research, please let me know!
AI Usage
While the original code was written largely manually, this code is now mostly developed through the use of Claude Code. AI usage follows the JOSS policy on AI usage. All design decisions are made by humans. All LLM generated code is verified manually by humans. Throughout the code you will likely see comments starting with "Claude Code:" that refer to specific MD files. These files are not part of the git but Anuj will share them on request.
Contributing
Contributions are always welcome! If you find an issue, or have any questions on how to use the code, please raise an issue on this repo. If you want to contribute directly to the code, please fork the code and create a pull request!
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gwbob-1.1.0.tar.gz.
File metadata
- Download URL: gwbob-1.1.0.tar.gz
- Upload date:
- Size: 46.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.20
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dcadfd07bb98c2d8d9a40ed7e6b035a4e7decaaf57f819605d2632871d54590a
|
|
| MD5 |
3fec8d0413131348f39614e100e32fc9
|
|
| BLAKE2b-256 |
6e31126293c4f0ce876b48c152b959305b5773986938e583a99e2f362345520b
|
File details
Details for the file gwbob-1.1.0-py3-none-any.whl.
File metadata
- Download URL: gwbob-1.1.0-py3-none-any.whl
- Upload date:
- Size: 45.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.10.20
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
367d3b293aadc18637e4b9ae69536fab2b857427997b2393efaa29ad29278ed8
|
|
| MD5 |
1a42ebfd0a9e857273264a1876a15e50
|
|
| BLAKE2b-256 |
b0a1fb3b60f9510fb1b893161b7e6051b908c50635c2e55b98d8e28feea1cf19
|