Skip to main content

Pipeline for detecting circumbinary planets in TESS light curves

Project description

mono-cbp: Search for Monotransits of Circumbinary Planets

A Python package for detecting circumbinary planets in TESS eclipsing binary light curves through the identification of single transit events ("monotransits").

Python Version License: GPL v3

Overview

mono-cbp is a pipeline designed to systematically search for circumbinary planets by detecting individual transit signatures in TESS eclipsing binary systems. The pipeline automates the complete workflow from masking stellar eclipses, threshold crossing event (TCE) detection, Bayesian vetting, and completeness analysis, making it easy to process large catalogues of eclipsing binaries.

Key Features

  • Eclipse Masking: Automatically mask primary and secondary eclipses in eclipsing binary light curves using eclipse positions and widths and binary ephemeris provided by an input catalogue
  • Transit Detection: Removes unwanted trends from the input light curves and performs single-event detection using the by identifying Threshold Crossing Events (see Hawthorn et al. 2024)
  • Bayesian Model Comparison: Event classification to discern transit-like events and systematics/detrending artefacts
  • Injection-Retrieval Testing: Completeness analysis through synthetic transit injection and recovery statistics
  • Modular Architecture: Use individual components independently or run the complete integrated pipeline
  • Configuration-Driven: Easily customise parameters via Python dictionaries or JSON files without modifying code
  • Command-Line Interface: Shell scripts and CLI subcommands for batch processing and reproducibility

Installation

Requirements

  • Python 3.8 or higher (tested most rigourously with Python 3.9)

From Source

git clone https://github.com/bdrdavies/mono-cbp.git
cd mono-cbp
pip install -e .

It is advisable to install mono-cbp into a Python environment using your favourite package manager, e.g. for conda:

conda create --name mono-cbp
conda activate mono-cbp
# Install from source as above

This installs the package in editable mode and creates the mono-cbp command-line tool.

To check that the installation has been successful, you can run the following

python -c "import mono_cbp; print(mono_cbp.__version__)"

Dependencies

See requirements.txt for the complete dependency list and exact versions.

Troubleshooting Installation

  • scipy>=1.13.0 may cause compatibility issues with PyMC 5.12.0; use scipy<1.13.0
  • PyTensor version must match PyMC 5.12.0 requirements (2.19.0)

Examples & Tutorials

There are a series of Jupyter notebooks in the examples/ directory to demonstrate how to use the package in your own code:

  1. 00_download_light_curves.ipynb - Download TESS light curves in the mono-cbp format using lightkurve
  2. 01_complete_pipeline.ipynb - End-to-end workflow on sample data
  3. 02_eclipse_masking.ipynb - Eclipse masking demo
  4. 03_transit_finding.ipynb - TCE detection example
  5. 04_model_comparison.ipynb - Bayesian model comparison example
  6. 05_injection_retrieval.ipynb - Completeness testing

Documentation

Documentation is available in the docs/ directory:

Support & Contact

For questions, issues, or feature requests:

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

mono_cbp-0.1.0.tar.gz (66.0 kB view details)

Uploaded Source

Built Distribution

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

mono_cbp-0.1.0-py3-none-any.whl (71.7 kB view details)

Uploaded Python 3

File details

Details for the file mono_cbp-0.1.0.tar.gz.

File metadata

  • Download URL: mono_cbp-0.1.0.tar.gz
  • Upload date:
  • Size: 66.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for mono_cbp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 9f68497f515b54e2f4073381a5f18965433625a86b300bc8626591d0c54a0fd5
MD5 b9ccff31689454027a2af9ab38b7ed1f
BLAKE2b-256 58f471a66920ecf47fdaee7ceafc846d7cfe7236f0e4dcd14f957c6b985f798a

See more details on using hashes here.

File details

Details for the file mono_cbp-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: mono_cbp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 71.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for mono_cbp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0c5da77b0e1e8691f22b2f40936614a5fea74030cfc540777aa58c92ea1cd793
MD5 7a4f298c6d85a003a45baf860789b836
BLAKE2b-256 26cfb4b9c8c640803a938f4b4f7c534d1ed22040a0d01e3c63daba5a182a37c0

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