libpappsomspp
Library for mass spectrometry
Loading...
Searching...
No Matches
spectrum.h
Go to the documentation of this file.
1/**
2 * \file pappsomspp/core/processing/cbor/mzcbor/spectrum.h
3 * \date 24/11/2025
4 * \author Olivier Langella
5 * \brief PSI spectrum 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>
37
38namespace pappso
39{
40namespace cbor
41{
42namespace mzcbor
43{
44/**
45 * @todo write docs
46 */
48{
49 /** @brief fill the structure reading data from a CBOR stream
50 * @param reader CBOR stream
51 * @param want_binary_data if true, stores also binary data array list
52 */
53 void fromCbor(CborStreamReader &reader, bool want_binary_data);
54
55 /** @brief write the structure to a JSON object
56 * This is a simplified representation for easy JSON data handling
57 * binary arrays are decoded in simple traces
58 * @result QJsonObject
59 */
60 QJsonObject toJsonObject() const;
61
62
63 static std::map<QString, pappso::cbor::mzcbor::CvParam>
65
66 void decodeTrace(pappso::Trace &trace) const;
67
68 uint getMsLevel() const;
69 double getRtInSeconds() const;
70 qint64 getTotalIonCount() const;
71
72 QString id;
73 std::size_t index;
74 std::size_t defaultArrayLength;
75
79 // QCborMap cborScanList;
80 std::vector<Scan> scanList;
81 std::vector<Precursor> precursorList;
82 std::vector<BinaryDataArray> binaryDataArrayList;
83 // QCborMap cborBinaryDataArray;
84};
85} // namespace mzcbor
86} // namespace cbor
87} // namespace pappso
PSI BinaryDataArray object for mzML/mzCBOR.
A simple container of DataPoint instances.
Definition trace.h:152
simple override of the raw QCborStreamReader This adds convenient functions to put CBOR data into C++...
cvParam map
tries to keep as much as possible monoisotopes, removing any possible C13 peaks and changes multichar...
Definition aa.cpp:39
unsigned int uint
Definition types.h:67
PSI precursor object for mzML/mzCBOR.
PSI scan object for mzML/mzCBOR.
static std::map< QString, pappso::cbor::mzcbor::CvParam > readScanCvParams(CborStreamReader &reader)
Definition spectrum.cpp:275
std::vector< Precursor > precursorList
Definition spectrum.h:81
std::vector< Scan > scanList
Definition spectrum.h:80
QJsonObject toJsonObject() const
write the structure to a JSON object This is a simplified representation for easy JSON data handling ...
Definition spectrum.cpp:228
void fromCbor(CborStreamReader &reader, bool want_binary_data)
fill the structure reading data from a CBOR stream
Definition spectrum.cpp:40
void decodeTrace(pappso::Trace &trace) const
Definition spectrum.cpp:353
std::vector< BinaryDataArray > binaryDataArrayList
Definition spectrum.h:82