Skip to main content

A Backwards-One-Body Gravitational Waveform Package

Project description

gwBOB Logo

gwBOB

The Backwards-One-Body Gravitational Waveform Package

License: MIT Build Status Documentation Status Python Version Project Status

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)
  • kuibit
  • sxs
  • qnmfits
  • scri
  • jax (install the GPU compatible version if possible)
  • sympy
  • numpy
  • scipy
  • matplotlib

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

gwbob-1.1.0.tar.gz (46.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gwbob-1.1.0-py3-none-any.whl (45.8 kB view details)

Uploaded Python 3

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

Hashes for gwbob-1.1.0.tar.gz
Algorithm Hash digest
SHA256 dcadfd07bb98c2d8d9a40ed7e6b035a4e7decaaf57f819605d2632871d54590a
MD5 3fec8d0413131348f39614e100e32fc9
BLAKE2b-256 6e31126293c4f0ce876b48c152b959305b5773986938e583a99e2f362345520b

See more details on using hashes here.

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

Hashes for gwbob-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 367d3b293aadc18637e4b9ae69536fab2b857427997b2393efaa29ad29278ed8
MD5 1a42ebfd0a9e857273264a1876a15e50
BLAKE2b-256 b0a1fb3b60f9510fb1b893161b7e6051b908c50635c2e55b98d8e28feea1cf19

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page