libpappsomspp
Library for mass spectrometry
Loading...
Searching...
No Matches
precursor.h
Go to the documentation of this file.
1/**
2 * \file pappsomspp/core/processing/cbor/mzcbor/precursor.h
3 * \date 24/11/2025
4 * \author Olivier Langella
5 * \brief PSI precursor object for mzML/mzCBOR
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
28
29#pragma once
30#include <QString>
33
34namespace pappso
35{
36namespace cbor
37{
38namespace mzcbor
39{
40
42{
43 void fromCbor(CborStreamReader &reader);
44
45 /** @brief write the structure to a JSON object
46 * @result QJsonObject
47 */
48 QJsonObject toJsonObject() const;
49
50 /** @brief get isolation window target m/z given cvParam informations
51 *
52 */
53 double getTargetMz() const;
54
55 /** @brief compute isolation window lower m/z given cvParam informations
56 *
57 */
58 double getLowerMz() const;
59
60
61 /** @brief compute isolation window upper m/z given cvParam informations
62 *
63 */
64 double getUpperMz() const;
65
67};
68
70{
71 void fromCbor(CborStreamReader &reader);
72
73 int getChargeState() const;
74 double getIntensity(bool *isok) const;
75 double getMz() const;
76
78};
79/**
80 * @todo write docs
81 */
83{
84 void fromCbor(CborStreamReader &reader);
85
86 /** @brief write the structure to a JSON object
87 * @result QJsonObject
88 */
89 QJsonObject toJsonObject() const;
90
91 QString spectrumRef;
92
94
96
97 std::vector<SelectedIon> selectedIonList;
98};
99} // namespace mzcbor
100} // namespace cbor
101} // namespace pappso
simple override of the raw QCborStreamReader This adds convenient functions to put CBOR data into C++...
cvParam map
#define PMSPP_LIB_DECL
tries to keep as much as possible monoisotopes, removing any possible C13 peaks and changes multichar...
Definition aa.cpp:39
double getUpperMz() const
compute isolation window upper m/z given cvParam informations
double getLowerMz() const
compute isolation window lower m/z given cvParam informations
Definition precursor.cpp:84
double getTargetMz() const
get isolation window target m/z given cvParam informations
Definition precursor.cpp:70
QJsonObject toJsonObject() const
write the structure to a JSON object
void fromCbor(CborStreamReader &reader)
Definition precursor.cpp:34
IsolationWindow isolationWindow
Definition precursor.h:93
QJsonObject toJsonObject() const
write the structure to a JSON object
std::vector< SelectedIon > selectedIonList
Definition precursor.h:97
void fromCbor(CborStreamReader &reader)
void fromCbor(CborStreamReader &reader)
double getIntensity(bool *isok) const