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.5.tar.gz (36.3 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.5-py3-none-any.whl (41.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: sicritfix-0.0.5.tar.gz
  • Upload date:
  • Size: 36.3 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.5.tar.gz
Algorithm Hash digest
SHA256 7c236b05258a14e0719db21c68304a34641a17bb23d5ede2260f87140e73bd33
MD5 b55cda0194fc7693953e8c51eb42f038
BLAKE2b-256 861a2ad7f2dd18a8316d76a538b5018f00f3930a56a5b9a26704e39ee302399c

See more details on using hashes here.

File details

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

File metadata

  • Download URL: sicritfix-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 41.7 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.5-py3-none-any.whl
Algorithm Hash digest
SHA256 9785e48a8207ba37f881de8561092e929872eb8f544768bf77ac1b439b67005a
MD5 6c7a82a014db246ab4b1fb9f19136b82
BLAKE2b-256 6ed02d284b32b6d0b3246c51ac276c0a771b8431ffa6f152fbba05b7e485cc51

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