libpappsomspp
Library for mass spectrometry
Loading...
Searching...
No Matches
psmionseries.h
Go to the documentation of this file.
1/**
2 * \file pappsomspp/processing/cbor/psm/evalscan/psmionseries.h
3 * \date 04/10/2025
4 * \author Olivier Langella
5 * \brief compute ion series for a PSM and associated spectrum
6 */
7
8/*******************************************************************************
9 * Copyright (c) 2025 Olivier Langella <Olivier.Langella@universite-paris-saclay.fr>.
10 *
11 * This file is part of PAPPSOms-tools.
12 *
13 * PAPPSOms-tools is free software: you can redistribute it and/or modify
14 * it under the terms of the GNU General Public License as published by
15 * the Free Software Foundation, either version 3 of the License, or
16 * (at your option) any later version.
17 *
18 * PAPPSOms-tools is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU General Public License for more details.
22 *
23 * You should have received a copy of the GNU General Public License
24 * along with PAPPSOms-tools. If not, see <http://www.gnu.org/licenses/>.
25 *
26 ******************************************************************************/
27#pragma once
28
30#include <QJsonObject>
32
33
34namespace pappso
35{
36namespace cbor
37{
38namespace psm
39{
40
41
42/**
43 * @brief computes spectrum isotope match for each PSM and stores ion series in "props"
44 */
46{
47 public:
48 /**
49 * Default constructor
50 */
51 PsmIonSeries(std::size_t buffer_scan_size,
52 CborStreamWriter *cbor_output_p,
53 const QJsonObject &parameters);
54
55 /**
56 * Destructor
57 */
58 virtual ~PsmIonSeries();
59
60
61 void filterMassSpectrum(pappso::MassSpectrum &mass_spectrum) const;
62
63 protected:
65 void parameterMapReady(pappso::UiMonitorInterface &monitor) override;
66
67 protected:
70};
71
72
74{
75 public:
76 /**
77 * Default constructor
78 */
79 PsmIonSeriesScan(const PsmIonSeries &psm_specpeptidoms, pappso::PrecisionPtr fragment_tolerance);
80
81 /**
82 * Destructor
83 */
84 virtual ~PsmIonSeriesScan();
85
86 protected:
87 void process() override;
88
89 private:
92};
93} // namespace psm
94} // namespace cbor
95} // namespace pappso
Class to represent a mass spectrum.
overrides QCborStreamWriter base class to provide convenient functions
CborScanMapBase(const PsmFileScanProcess &psm_file_scan_process)
PsmFileScanProcessAndCopy(std::size_t buffer_scan_size, CborStreamWriter *cbor_output_p, const QString &operation)
const PsmIonSeries * mp_psmSpecPeptidOms
pappso::PrecisionPtr m_fragmentTolerance
PsmIonSeriesScan(const PsmIonSeries &psm_specpeptidoms, pappso::PrecisionPtr fragment_tolerance)
computes spectrum isotope match for each PSM and stores ion series in "props"
void filterMassSpectrum(pappso::MassSpectrum &mass_spectrum) const
void parameterMapReady(pappso::UiMonitorInterface &monitor) override
PsmIonSeries(std::size_t buffer_scan_size, CborStreamWriter *cbor_output_p, const QJsonObject &parameters)
pappso::PrecisionPtr m_fragmentTolerance
CborScanMapBase * newCborScanMap() override
#define PMSPP_LIB_DECL
tries to keep as much as possible monoisotopes, removing any possible C13 peaks and changes multichar...
Definition aa.cpp:39
const PrecisionBase * PrecisionPtr
Definition precision.h:122