Skip to main content

Python package to detect and correct oscillatory artifacts in mass spectrometry mzML data.

Project description

Oscillations_Corrector_Algorithm_SICRIT

Suppressing Signal Artifacts in CE-SICRIT-MS via Oscillation Processing

This repository contains a Python tool to detect and correct oscillations that appear in mass spectrometry (MS) spectra acquired with the SICRIT ionization source. The program reads .mzXML or .mzML files, identifies oscillatory m/z signals via FFT analysis, corrects their intensities, and outputs cleaned .mzML files.

The tool includes a command-line interface (CLI) to process single files or whole folders.


Table of Contents


Introduction

This Python module provides a pipeline for correcting oscillatory artifacts in CE-SICRIT-MS spectra.
It includes:

  • Automatic loading of .mzML and .mzXML files.
  • Conversion of .mzXML to .mzML using ProteoWizard MSConvert.
  • Detection of oscillatory m/z values using FFT-based power analysis.
  • Correction of intensity oscillations via residual signal reconstruction.
  • Saving corrected spectra in .mzML format.

Installation

If you want to use the last released version, it is published in pypy already.

pip install sicritfix

If you want to install the source code or develop over it, clone the repository and install the dependencies inside a conda environment. If you want to run the CLI you shall install it as a module.

git clone https://github.com/ceu-biolab/Oscillations_Corrector_Algorithm_SICRIT.git
cd Oscillations_Corrector_Algorithm_SICRIT

conda create -n sicritfix python=3.12
conda activate sicritfix
pip install -e .

Usage

You can run the program from the command line after installation.
Both single files and folders are supported.

Processing a Single File

Run the tool with an input file:

sicritfix input_file.mzXML --output corrected.mzML --overwrite

If no --output is provided, the tool will automatically generate a filename by appending _corrected.mzML.

Processing a Folder of Files

To process an entire folder of .mzXML files, simply pass the folder path as input.
Each file will be automatically converted to .mzML, processed, and saved.

python CLI.py /path/to/folder --overwrite --verbose

During execution you’ll see messages like:

file: sample1.mzXML loaded correctly
file: sample2.mzXML loaded correctly

Command-Line Options

  • --output : Output path (optional).
  • --overwrite : Overwrite existing files.
  • --plot : Show diagnostic plots.
  • --verbose : Print detailed execution logs.
  • --mz_window : m/z bin size for oscillation detection (default: 0.01). Increasing this value groups nearby m/z peaks into larger bins, making the algorithm less sensitive to small differences in m/z but more tolerant to noise. Decreasing it makes detection more precise at the cost of possibly missing weak or noisy signals.
  • --rt_window : Retention time window for XIC smoothing (default: 0.01). This controls how intensities are aggregated across retention time. A larger value smooths the signal more strongly, which can improve frequency detection but may blur fine details in short peaks. A smaller value preserves fine temporal resolution but may leave more noise in the XIC. Note: Both parameters should be adjusted depending on the type of signa being processed.

Detection and Correction Workflow

  1. Load the input file(s).

    • If .mzXML is detected, it is converted to .mzML.
  2. Extract relevant MS data.

    • Retention times (RT), m/z values, and intensities.
  3. Detect oscillating m/z values.

    • Uses FFT-based power spectrum analysis.
  4. Correct oscillations.

    • Subtracts a modeled sinusoidal component to recover residual signal.
  5. Update spectra.

    • Replace oscillating intensities with corrected values.
  6. Save results.

    • Corrected file is written to disk in .mzML format.

Examples

Process a single file:

sicritfix data/sample.mzXML --plot

or

python CLI.py data/sample.mzXML --plot

Process all files in a folder:

sicritfix data/sample.mzXML --overwrite

or

python CLI.py data/sample.mzXML --overwrite

Verbose mode:

sicritfix data/sample.mzXML --verbose

or

python CLI.py data/sample.mzML --verbose

License

This project is licensed under the GNU General Public License v3.0.

You are free to use, modify, and distribute the software, but any derivative work must also be open-source under the GPL-3.0 license.

For more details, see the full GPL-3.0 license.

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

sicritfix-0.0.6.tar.gz (36.6 kB view details)

Uploaded Source

Built Distribution

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

sicritfix-0.0.6-py3-none-any.whl (42.0 kB view details)

Uploaded Python 3

File details

Details for the file sicritfix-0.0.6.tar.gz.

File metadata

  • Download URL: sicritfix-0.0.6.tar.gz
  • Upload date:
  • Size: 36.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for sicritfix-0.0.6.tar.gz
Algorithm Hash digest
SHA256 bd98c9f87c0d9ea5bcccb4c91fc8bc2d45b5e938b2ce4ac4e0337bad34dbcccb
MD5 0a0450a1d79665d80ca492db809bf306
BLAKE2b-256 b05c07ccf71584b6bdcdf67350352b0bbbfacff25cf8ad55489323eb8259dc05

See more details on using hashes here.

File details

Details for the file sicritfix-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: sicritfix-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 42.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for sicritfix-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 586888a170aa3dbfa2e0e2f3304f7b947857cd3ea2fcd19d37606ab51992f90a
MD5 4b4028f3b9dd6cba86d5550419d2efac
BLAKE2b-256 5f979cd5bb8afbf40eaf98698d012ca81b35e234c2c4ca36f15137d8a31e7f6a

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