libpappsomspp
Library for mass spectrometry
Loading...
Searching...
No Matches
pappso::cbor::psm::PsmCborUtils Class Reference

utilities to help managing data in PSM CBOR data file More...

#include <psmcborutils.h>

Classes

struct  PsmProteinRef

Static Public Member Functions

static void prepareCborScanWithSpectrum (QCborMap &cbor_scan, const pappso::QualifiedMassSpectrum &ms2_qualified_mass_spectrum)
static void prepareCborScanWithSpectrumAndPeakList (QCborMap &cbor_scan, const pappso::QualifiedMassSpectrum &ms2_qualified_mass_spectrum)
static std::vector< PsmProteinRefgetPsmProteinRefList (const QCborMap &cbor_psm)
static void setPsmProteinRefList (QCborMap &cbor_psm, const std::vector< PsmProteinRef > &protein_ref_list)
static void mergePsmProteinRefList (QCborMap &cbor_psm_destination, const QCborMap &cbor_psm_source)

Detailed Description

utilities to help managing data in PSM CBOR data file

Definition at line 44 of file psmcborutils.h.

Member Function Documentation

◆ getPsmProteinRefList()

std::vector< PsmCborUtils::PsmProteinRef > pappso::cbor::psm::PsmCborUtils::getPsmProteinRefList ( const QCborMap & cbor_psm)
static

Definition at line 101 of file psmcborutils.cpp.

102{
103 std::vector<PsmCborUtils::PsmProteinRef> protein_ref_list;
104
105 if(cbor_psm.contains(QString("protein_list")))
106 {
107 for(auto it : cbor_psm.value("protein_list").toArray())
108 {
109 QCborMap cbor_protein_ref = it.toMap();
110 PsmCborUtils::PsmProteinRef protein_ref;
111 protein_ref.accession = cbor_protein_ref.value("accession").toString();
112
113 for(auto ref_position : cbor_protein_ref.value("positions").toArray())
114 {
115 protein_ref.positions.push_back(ref_position.toInteger());
116 }
117 protein_ref_list.push_back(protein_ref);
118 }
119 }
120
121 return protein_ref_list;
122}

References pappso::cbor::psm::PsmCborUtils::PsmProteinRef::accession, and pappso::cbor::psm::PsmCborUtils::PsmProteinRef::positions.

Referenced by mergePsmProteinRefList().

◆ mergePsmProteinRefList()

void pappso::cbor::psm::PsmCborUtils::mergePsmProteinRefList ( QCborMap & cbor_psm_destination,
const QCborMap & cbor_psm_source )
static

Definition at line 150 of file psmcborutils.cpp.

152{
153 std::vector<PsmCborUtils::PsmProteinRef> protein_ref_list =
154 getPsmProteinRefList(cbor_psm_destination);
155 std::vector<PsmCborUtils::PsmProteinRef> protein_ref_list_source =
156 getPsmProteinRefList(cbor_psm_source);
157
158 protein_ref_list.insert(
159 protein_ref_list.end(), protein_ref_list_source.begin(), protein_ref_list_source.end());
160
161
162 std::sort(protein_ref_list.begin(),
163 protein_ref_list.end(),
164 [](PsmCborUtils::PsmProteinRef &a, PsmCborUtils::PsmProteinRef &b) {
165 return a.accession > b.accession;
166 });
167
168 std::vector<PsmCborUtils::PsmProteinRef> unique_protein_ref_list;
169
170 for(auto it = protein_ref_list.begin(); it != protein_ref_list.end(); it++)
171 {
172 // qDebug() << it->proforma;
173 if(unique_protein_ref_list.size() > 0)
174 {
175 if(unique_protein_ref_list.back().accession == it->accession)
176 {
177 // merge positions
178 unique_protein_ref_list.back().positions.insert(
179 unique_protein_ref_list.back().positions.end(),
180 it->positions.begin(),
181 it->positions.end());
182
183 std::sort(unique_protein_ref_list.back().positions.begin(),
184 unique_protein_ref_list.back().positions.end());
185
186 auto last = std::unique(unique_protein_ref_list.back().positions.begin(),
187 unique_protein_ref_list.back().positions.end());
188 // v now holds {1 2 3 4 5 x x}, where 'x' is indeterminate
189 unique_protein_ref_list.back().positions.erase(
190 last, unique_protein_ref_list.back().positions.end());
191 }
192 else
193 {
194 unique_protein_ref_list.push_back(*it);
195 }
196 }
197 else
198 {
199 unique_protein_ref_list.push_back(*it);
200 }
201
202 qDebug();
203 }
204
205 setPsmProteinRefList(cbor_psm_destination, unique_protein_ref_list);
206}
static void setPsmProteinRefList(QCborMap &cbor_psm, const std::vector< PsmProteinRef > &protein_ref_list)
static std::vector< PsmProteinRef > getPsmProteinRefList(const QCborMap &cbor_psm)

References pappso::a, pappso::b, getPsmProteinRefList(), pappso::last, and setPsmProteinRefList().

Referenced by pappso::cbor::psm::CborScanMapBase::filterPsmListUniqueUniqueProforma().

◆ prepareCborScanWithSpectrum()

void pappso::cbor::psm::PsmCborUtils::prepareCborScanWithSpectrum ( QCborMap & cbor_scan,
const pappso::QualifiedMassSpectrum & ms2_qualified_mass_spectrum )
static

Definition at line 40 of file psmcborutils.cpp.

42{
43 // id
44 QCborMap cbor_scan_id;
45 cbor_scan_id.insert(QString("index"),
46 (qint64)ms2_qualified_mass_spectrum.getMassSpectrumId().getSpectrumIndex());
47 cbor_scan_id.insert(QString("native_id"),
48 ms2_qualified_mass_spectrum.getMassSpectrumId().getNativeId());
49 bool is_ok;
50 std::size_t scan =
51 ms2_qualified_mass_spectrum.getMassSpectrumId().extractScanNumberFromNativeId(&is_ok);
52 if(is_ok)
53 {
54 cbor_scan_id.insert(QString("scan"), (qint64)scan);
55 }
56 cbor_scan.insert(QString("id"), cbor_scan_id.toCborValue());
57
58
59 // precursor
60 QCborMap cbor_scan_precursor;
61 cbor_scan_precursor.insert(QString("z"), ms2_qualified_mass_spectrum.getPrecursorCharge());
62 cbor_scan_precursor.insert(QString("mz"), ms2_qualified_mass_spectrum.getPrecursorMz());
63 cbor_scan_precursor.insert(QString("mh"), ms2_qualified_mass_spectrum.getPrecursorMass());
64 cbor_scan_precursor.insert(QString("intensity"),
65 ms2_qualified_mass_spectrum.getPrecursorIntensity());
66 cbor_scan.insert(QString("precursor"), cbor_scan_precursor.toCborValue());
67
68
69 // ms2
70 QCborMap cbor_scan_ms2;
71 cbor_scan_ms2.insert(QString("rt"), ms2_qualified_mass_spectrum.getRtInSeconds());
72 cbor_scan.insert(QString("ms2"), cbor_scan_ms2.toCborValue());
73}
std::size_t getSpectrumIndex() const
const QString & getNativeId() const
std::size_t extractScanNumberFromNativeId(bool *is_ok) const
try to find scan id in the native id string
uint getPrecursorCharge(bool *ok=nullptr) const
get precursor charge
pappso_double getPrecursorIntensity(bool *ok=nullptr) const
get precursor intensity
double getPrecursorMass(bool *ok_p=nullptr) const
get precursor mass given the charge stats and precursor mz
const MassSpectrumId & getMassSpectrumId() const
Get the MassSpectrumId.
pappso_double getPrecursorMz(bool *ok=nullptr) const
get precursor mz
pappso_double getRtInSeconds() const
Get the retention time in seconds.

References pappso::MassSpectrumId::extractScanNumberFromNativeId(), pappso::QualifiedMassSpectrum::getMassSpectrumId(), pappso::MassSpectrumId::getNativeId(), pappso::QualifiedMassSpectrum::getPrecursorCharge(), pappso::QualifiedMassSpectrum::getPrecursorIntensity(), pappso::QualifiedMassSpectrum::getPrecursorMass(), pappso::QualifiedMassSpectrum::getPrecursorMz(), pappso::QualifiedMassSpectrum::getRtInSeconds(), and pappso::MassSpectrumId::getSpectrumIndex().

Referenced by prepareCborScanWithSpectrumAndPeakList().

◆ prepareCborScanWithSpectrumAndPeakList()

void pappso::cbor::psm::PsmCborUtils::prepareCborScanWithSpectrumAndPeakList ( QCborMap & cbor_scan,
const pappso::QualifiedMassSpectrum & ms2_qualified_mass_spectrum )
static

Definition at line 76 of file psmcborutils.cpp.

78{
79 prepareCborScanWithSpectrum(cbor_scan, ms2_qualified_mass_spectrum);
80 QCborMap spectrum_cbor;
81
82 QCborArray mz_cbor;
83 QCborArray intensity_cbor;
84 for(const pappso::DataPoint &data_point :
85 *(ms2_qualified_mass_spectrum.getMassSpectrumCstSPtr().get()))
86 {
87 mz_cbor.append(data_point.x);
88 intensity_cbor.append(data_point.y);
89 }
90 spectrum_cbor.insert(QString("mz"), mz_cbor);
91 spectrum_cbor.insert(QString("intensity"), intensity_cbor);
92
93 QCborMap new_ms2_map = cbor_scan.value("ms2").toMap();
94 new_ms2_map.insert(QString("spectrum"), spectrum_cbor.toCborValue());
95
96 cbor_scan.insert(QString("ms2"), new_ms2_map);
97}
MassSpectrumCstSPtr getMassSpectrumCstSPtr() const
Get the MassSpectrumCstSPtr.
static void prepareCborScanWithSpectrum(QCborMap &cbor_scan, const pappso::QualifiedMassSpectrum &ms2_qualified_mass_spectrum)

References pappso::QualifiedMassSpectrum::getMassSpectrumCstSPtr(), and prepareCborScanWithSpectrum().

◆ setPsmProteinRefList()

void pappso::cbor::psm::PsmCborUtils::setPsmProteinRefList ( QCborMap & cbor_psm,
const std::vector< PsmProteinRef > & protein_ref_list )
static

Definition at line 126 of file psmcborutils.cpp.

128{
129 QCborArray protein_list;
130
131 for(auto it : protein_ref_list)
132 {
133 QCborMap protein_ref;
134 protein_ref.insert(QString("accession"), it.accession);
135 QCborArray positions_arr;
136 for(auto position : it.positions)
137 {
138 positions_arr.append((qint64)position);
139 }
140 protein_ref.insert(QString("positions"), positions_arr);
141 protein_list.append(protein_ref);
142 }
143
144 cbor_psm.remove(QString("protein_list"));
145 cbor_psm.insert(QString("protein_list"), protein_list);
146}

Referenced by mergePsmProteinRefList().


The documentation for this class was generated from the following files: