Skip to main content

Signal correction module for Ariel Data Challenge 2025.

Project description

Ariel Data Preprocessing

PyPI release Unittest

This module contains the complete FGS1 and AIRS-CH0 signal data preprocessing pipeline for the Ariel Data Challenge.

Overview

The DataProcessor class provides an integrated pipeline that combines:

  1. Signal correction - Complete 6-step calibration pipeline for raw telescope data
  2. Signal extraction - Intelligent data reduction and spectral signal extraction

This unified approach transforms raw Ariel telescope data directly into extracted, science-ready spectral time series in a single processing step.

1. Signal correction

Implements the complete six-step signal correction pipeline outlined in the Calibrating and Binning Ariel Data notebook shared by the contest organizers. This module transforms raw Ariel telescope data into science-ready corrected signals.

Processing Pipeline:

  1. ADC Conversion - Convert raw counts to physical units
  2. Hot/Dead Pixel Masking - Remove problematic detector pixels
  3. Linearity Correction - Account for non-linear detector response
  4. Dark Current Subtraction - Remove thermal background noise
  5. Correlated Double Sampling (CDS) - Reduce read noise via paired exposures
  6. Flat Field Correction - Normalize pixel-to-pixel sensitivity variations

Key Features:

  • Multiprocessing support for parallel planet processing
  • Optional FGS1 downsampling to match AIRS-CH0 cadence (83% data reduction)
  • Configurable processing steps (enable/disable individual corrections)
  • HDF5 output for efficient large dataset storage

See the following notebooks for implementation details and performance analysis:

  1. Signal correction
  2. Signal correction optimization

Example use:

from ariel_data_preprocessing.data_preprocessing import DataProcessor

data_processor = DataProcessor(
    input_data_path='data/raw',
    output_data_path='data/corrected',
    n_cpus=4,
    downsample_fgs=True,
    n_planets=100
)

data_processor.run()

The signal correction pipeline will write the corrected frames and hot/dead pixel masks as an HDF5 archive called train.h5 by default with the following structure:

    train.h5:
    │
    ├── planet_id_1/
    │   ├── signal  # Combined corrected/extracted spectral time series
    │   └── mask    # Dead/hot pixel mask for spectra
    |
    ├── planet_id_2/
    │   ├── signal  
    │   └── mask    
    |
    └── planet_id_n/

2. Signal extraction

Complete extraction pipeline integrated with DataProcessor

The signal extraction functionality is integrated within the DataProcessor class, which handles both signal correction and extraction in a unified pipeline. This approach transforms 3D detector arrays into focused time series suitable for exoplanet atmospheric analysis.

Processing Features:

  • AIRS-CH0 Extraction: Selects brightest detector rows containing spectral traces, sums to create 1D spectra per frame
  • FGS1 Extraction: Uses 2D block extraction to identify signal regions, collapses to single brightness value per frame
  • Combined Output: Merges FGS1 and AIRS-CH0 signals (FGS1 as first column for transit detection)
  • Adaptive Thresholding: Automatically selects signal-bearing pixels based on configurable intensity thresholds
  • Optional Smoothing: Applies moving average filtering across wavelengths to reduce noise
  • Massive Data Reduction: Achieves ~97-98% volume reduction while preserving transit signals

Key Benefits:

  • Dramatically faster downstream processing due to reduced data volume
  • Improved signal-to-noise ratio by focusing on high-signal detector regions
  • Preserved exoplanet transit signatures with cleaner temporal structure
  • Unified processing for both instrument types

See the following notebooks for implementation details and analysis:

  1. AIRS-CH0 signal extraction
  2. FGS1 signal extraction
  3. Wavelength smoothing

Example usage:

The signal extraction is performed as part of the integrated DataProcessor pipeline:

from ariel_data_preprocessing.data_preprocessing import DataProcessor

data_processor = DataProcessor(
    input_data_path='data/raw',
    output_data_path='data/processed',
    inclusion_threshold=0.75,
    smooth=True,
    smoothing_window=200
)

data_processor.run()

Output data will be written to train.h5 by default in the directory passed to output_data_path. The structure of the HDF5 archive combines both AIRS-CH0 and FGS1 signals:

    train.h5
    |
    ├── planet_1/
    │   ├── signal  # Shape: (n_frames, n_wavelengths + 1) - FGS1 + AIRS-CH0
    │   └── mask    # Shape: (n_wavelengths + 1,) - combined mask
    │
    ├── planet_2/
    │   ├── signal  # Shape: (n_frames, n_wavelengths + 1) - FGS1 + AIRS-CH0  
    │   └── mask    # Shape: (n_wavelengths + 1,) - combined mask
    │
    └── planet_n/

Note: The first column of the signal dataset contains the extracted FGS1 brightness time series, followed by the AIRS-CH0 spectral channels. This structure facilitates easy transit detection using FGS1 data while providing wavelength-dependent atmospheric information from AIRS-CH0.

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

ariel_data_preprocessing-1.3a2.tar.gz (12.4 MB view details)

Uploaded Source

Built Distribution

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

ariel_data_preprocessing-1.3a2-py3-none-any.whl (18.9 kB view details)

Uploaded Python 3

File details

Details for the file ariel_data_preprocessing-1.3a2.tar.gz.

File metadata

  • Download URL: ariel_data_preprocessing-1.3a2.tar.gz
  • Upload date:
  • Size: 12.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ariel_data_preprocessing-1.3a2.tar.gz
Algorithm Hash digest
SHA256 3105cf37cb23a489914821292b5fd6c34e7fe01824c1c7a2f70840f411b71f27
MD5 f7e5f097cb05079eca71126f0d34ac99
BLAKE2b-256 a522f837c90395e5d5240b5f78ca9a17238bd7cb68ff97202c43ba090439d15f

See more details on using hashes here.

Provenance

The following attestation bundles were made for ariel_data_preprocessing-1.3a2.tar.gz:

Publisher: pypi_release.yml on gperdrizet/ariel-data-challenge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ariel_data_preprocessing-1.3a2-py3-none-any.whl.

File metadata

File hashes

Hashes for ariel_data_preprocessing-1.3a2-py3-none-any.whl
Algorithm Hash digest
SHA256 9608e78dd29cd2716f771b2b1ffab2edeb44b6a2fd304c5086b79efc9f24a4b6
MD5 313fab20fe853bdddce5e61cde2282a1
BLAKE2b-256 6c51ec53fa339cd3684ca815fe0c9f7fc42a50fce26416eefb93a3740ceffa71

See more details on using hashes here.

Provenance

The following attestation bundles were made for ariel_data_preprocessing-1.3a2-py3-none-any.whl:

Publisher: pypi_release.yml on gperdrizet/ariel-data-challenge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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