Source code for matchms.filtering.metadata_processing.repair_precursor_is_parent_mass

import logging
from matchms import Spectrum
from matchms.filtering.filter_utils.derive_precursor_mz_and_parent_mass import \
    derive_precursor_mz_from_parent_mass
from matchms.filtering.filter_utils.get_neutral_mass_from_smiles import \
    get_monoisotopic_neutral_mass
from .require_parent_mass_match_smiles import require_parent_mass_match_smiles


logger = logging.getLogger("matchms")


[docs]def repair_precursor_is_parent_mass(spectrum_in: Spectrum, mass_tolerance): """Repairs parent mass and precursor mz if the parent mass is entered instead of the precursor_mz""" if spectrum_in is None: return None spectrum = spectrum_in.clone() # Check if parent mass already matches smiles if require_parent_mass_match_smiles(spectrum, mass_tolerance) is not None: return spectrum precursor_mz = spectrum.get("precursor_mz") # Check if the precursor_mz can be calculated from the parent mass. If not skip this function if abs(precursor_mz - derive_precursor_mz_from_parent_mass(spectrum)) > mass_tolerance: return spectrum smiles = spectrum.get("smiles") smiles_mass = get_monoisotopic_neutral_mass(smiles) if smiles_mass is None: return spectrum mass_difference = precursor_mz - smiles_mass if abs(mass_difference) < mass_tolerance: logger.info("Parent mass was changed from %s to %s", spectrum.get("parent_mass"), smiles_mass) spectrum.set("parent_mass", smiles_mass) new_precursor_mz = derive_precursor_mz_from_parent_mass(spectrum) if new_precursor_mz is not None: logger.info("Parent mass was changed from %s to %s", spectrum.get("precursor_mz"), new_precursor_mz) spectrum.set("precursor_mz", new_precursor_mz) return spectrum