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.2.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.2-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.2-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.2.tar.gz.

File metadata

  • Download URL: ceres3-1.1.2.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.2.tar.gz
Algorithm Hash digest
SHA256 b7138d0e674135d351eb335dc34f7cbac68255b183b197a4603bab7246498612
MD5 1507aad55c14ef040e040a99817a49d0
BLAKE2b-256 2c576c994232dcaf76fed10070eaf5e5bef12c915400026109e810a49b082060

See more details on using hashes here.

File details

Details for the file ceres3-1.1.2-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.2-cp312-cp312-manylinux2014_x86_64.manylinux_2_17_x86_64.manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 b93e2fb605643b1a8c3351c855aeb4d0a0ed4083d801c0ae876216b000cbdcda
MD5 151d11a729806157125aec365214be26
BLAKE2b-256 6a8857bf3bc4c8935a671e9596c1278def99efcf93dfeca04e0fe2d5650b69ca

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for ceres3-1.1.2-cp312-cp312-manylinux2014_aarch64.manylinux_2_17_aarch64.manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 37e120accf820ab8594d8304c4ee7352574960ee17b0f0db035aff9a88ffa2b6
MD5 0f5e2f7185e78a2c8e420909c0c3ac48
BLAKE2b-256 640116512125f71e0e4fe03fcbe012206bffbed74ab84387aaa7f5925865a8c0

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