Skip to main content

CERES: A Collection of Echelle Reduction Scripts for extracting precise radial velocities and activity indicators from echelle spectrograph data.

Project description

CERES3

A Python 3 port of CERES — a collection of fully automated pipelines for the reduction, extraction and analysis of echelle spectrograph data. CERES3 produces wavelength-calibrated spectra, precise radial velocities, bisector spans, and chromospheric activity indicators (S-index, H-alpha, HeI, NaI D1/D2).

If you use this code, please cite Brahm et al 2017.

Installation

System prerequisites

# Debian/Ubuntu
sudo apt install gfortran libgsl-dev libopenblas-dev build-essential pkg-config

# macOS (Homebrew)
brew install gcc gsl openblas

Install CERES3

pip install ceres3

Or from source:

git clone https://github.com/jvines/ceres3.git
cd ceres3
pip install .

This compiles the C/Fortran extensions (Marsh optimal extraction, CCF cross-correlation) automatically.

Quick start

# Step 1: Reduce calibration frames (bias, flat, ThAr)
ceres3 feros /path/to/raw/calibrations --is-calib

# Step 2: Reduce science frames
ceres3 feros /path/to/raw/science --calib-dir /path/to/calibrations_red/

Output goes to {input_dir}_red/ by default. Override with -o /custom/path.

Supported instruments

Instrument Telescope Pipeline
ARCES APO 3.5m ceres3 arces
CAFE CAHA 2.2m ceres3 cafe
Coralie Euler 1.2m ceres3 coralie
Echelle DuPont 2.5m ceres3 dupont
ESPaDOnS CFHT 3.6m ceres3 espadons
FEROS MPG/ESO 2.2m ceres3 feros
FIDEOS ESO 1.0m ceres3 fideos
FIES NOT 2.5m ceres3 fies
HARPS ESO 3.6m ceres3 harps
HIRES Keck 10m ceres3 hires
MIKE Magellan 6.5m ceres3 mike
PFS Magellan 6.5m ceres3 pfs
PUCHEROS PUC 0.5m ceres3 pucheros
VBT Echelle VBT 2.3m ceres3 vbt

CLI options

ceres3 <instrument> <input_dir> [options]

Options:
  -o, --output-dir DIR     Output directory (default: {input_dir}_red/)
  --npools N               CPU cores to use (default: 4)
  --nsigmas N              Order detection sigma threshold (default: 5.0)
  --is-calib               Process as calibration data
  --calib-dir DIR          Path to pre-computed calibration directory
  --do-class               Enable spectral classification (Teff, logg, [Fe/H])
  --target NAME            Process only this target (default: all)

Python API

# Import and run a pipeline directly
from ceres3.instruments import get_pipeline_module
feros = get_pipeline_module('feros')
# Pipeline runs on import (module-level code)

Data products

All final products are in the proc/ subdirectory of the output directory.

FITS spectrum cube (*_sp.fits)

Shape: (11, n_orders, n_pixels) — 11 data layers per echelle order:

Layer Contents
0 Wavelength (Angstroms)
1 Extracted flux
2 Flux error (1/sqrt(variance))
3 Blaze-corrected flux
4 Blaze-corrected flux error
5 Continuum-normalized flux
6 Continuum-normalized flux error
7 Estimated continuum
8 Signal-to-noise ratio per pixel
9 Continuum-normalized flux × d(wavelength)/d(pixel)
10 Error of layer 9

Merged 1D spectrum (*_1d.fits)

A single FITS binary table with columns WAVELENGTH, FLUX, ERROR — the echelle orders merged into one continuous spectrum using S/N-weighted crossover. This is the rest-frame, continuum-normalized spectrum suitable for input to spectral analysis tools (e.g., SPECIES).

FITS header keywords

Keyword Description
RV Radial velocity (km/s)
RV_E RV error (km/s)
BS Bisector span (km/s)
BS_E BS error (km/s)
FWHM CCF full width at half maximum (km/s)
XC_MIN CCF contrast (depth of minimum)
BJD_OUT Barycentric Julian Date
SNR Signal-to-noise at ~5130 A
S_INDEX Ca H+K S-index
HALPHA H-alpha activity index
HEI HeI 5876 activity index
NAI_D1D2 NaI D1+D2 activity index
SPEC1D Path to merged 1D spectrum
INST Instrument name
PIPELINE CERES

results.txt

Tab-separated summary with columns: object name, BJD, RV, RV error, bisector span, BS error, FWHM, instrument, pipeline, resolving power, Teff, log(g), [Fe/H], v*sin(i), XC_min, CCF dispersion, exposure time, SNR, S-index, H-alpha, HeI, NaI D1/D2, CCF plot path.

CCF plots (*.pdf)

PDF files showing the cross-correlation function and Gaussian fit for each target.

Auxiliary files

Place these in the raw data directory to customize the reduction:

reffile.txt

Comma-separated file with target-specific parameters:

HD157347,17:22:51.28809,-02:23:17.4297,49.39,-107.16,1,G2,4.0
HD32147,05:00:48.99977,-05:45:13.2303,550.12,-1109.23,1,G2,4.0

Columns: name, RA (J2000), Dec (J2000), PM_RA (mas/yr), PM_Dec (mas/yr), use_coords (0/1), CCF mask (G2/K5/M2), velocity width (km/s).

bad_files.txt

List filenames (one per line) to exclude from processing.

moon_corr.txt

List filenames for which the CCF fit includes a double Gaussian to correct for scattered moonlight.

Spectral classification

To estimate atmospheric parameters (Teff, log(g), [Fe/H], v*sin(i)), use --do-class. This requires the Coelho et al. (2005) model grid:

mkdir -p ~/.ceres3/COELHO_MODELS
cd ~/.ceres3/COELHO_MODELS
wget http://www.astro.puc.cl/~rbrahm/coelho_05_red4_R40.tar.gz
tar -xf coelho_05_red4_R40.tar.gz

What changed from the original CERES

  • Python 3.10+ (was Python 2.7)
  • No R dependency (rpy2 was never used)
  • No SWIG / SOFA / manual ephemeris updates — astropy handles barycentric corrections with DE440 ephemeris (auto-downloaded)
  • Inline activity indicators — S-index, H-alpha, HeI, NaI D1/D2 computed during reduction (no separate post-processing step)
  • Merged 1D spectrum output — rest-frame continuum-normalized spectrum as a FITS binary table
  • Batch CCF — Fortran subroutine processes all velocity steps in one call (3-4x faster)
  • pip installablepip install ceres3 compiles extensions automatically

Authors

Rafael Brahm, Andres Jordan, Nestor Espinoza, Jose Vines.

License

MIT

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

ceres3-1.1.0.tar.gz (21.0 MB view details)

Uploaded Source

Built Distributions

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

ceres3-1.1.0-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl (3.1 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.17+ x86-64manylinux: glibc 2.28+ x86-64

ceres3-1.1.0-cp312-cp312-manylinux2014_aarch64.manylinux_2_17_aarch64.manylinux_2_28_aarch64.whl (3.0 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.17+ ARM64manylinux: glibc 2.28+ ARM64

File details

Details for the file ceres3-1.1.0.tar.gz.

File metadata

  • Download URL: ceres3-1.1.0.tar.gz
  • Upload date:
  • Size: 21.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for ceres3-1.1.0.tar.gz
Algorithm Hash digest
SHA256 2aa92ba3f94ba93780727de17937cdcbfcde520a5418401c7d6463df7611faf9
MD5 cd439158267fd9753520d6f80e1a1775
BLAKE2b-256 e1098ebaf875054522a630521ca549d8d300bc12a4e999c769e1cd266808efee

See more details on using hashes here.

File details

Details for the file ceres3-1.1.0-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for ceres3-1.1.0-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 ecad54679dc8011b5a4d12e15027e864adbd53d296bdba718fbe273af0695b0f
MD5 10b4ace4be4d4d773a9b8d6b39e56f24
BLAKE2b-256 7342d37be4699eadcadb564eeb74401aeb5e35631c9f2147f95eb8c3e1afbb9d

See more details on using hashes here.

File details

Details for the file ceres3-1.1.0-cp312-cp312-manylinux2014_aarch64.manylinux_2_17_aarch64.manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for ceres3-1.1.0-cp312-cp312-manylinux2014_aarch64.manylinux_2_17_aarch64.manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 527b4fa517a431221697d52549d4db6f606b99189791218dd50bd82a5465adc0
MD5 93325cbb8795b63fdc857ddee8ccd7f1
BLAKE2b-256 85890dee98a68b9129efba14341d0ced6d5581a4f9734c93ae5480cd802055e1

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