libpappsomspp
Library for mass spectrometry
Loading...
Searching...
No Matches
pappso::FilterChargeDeconvolution Class Reference

#include <filterchargedeconvolution.h>

Inheritance diagram for pappso::FilterChargeDeconvolution:
pappso::FilterNameInterface pappso::FilterInterface

Classes

struct  DataPointInfo

Public Member Functions

 FilterChargeDeconvolution (PrecisionPtr precision_ptr)
 FilterChargeDeconvolution (const QString &strBuildParams)
 FilterChargeDeconvolution (const FilterChargeDeconvolution &other)
virtual ~FilterChargeDeconvolution ()
Tracefilter (Trace &data_points) const override
 get all the datapoints and remove different isotope and add their intensity and change to charge = 1 when the charge is known
virtual QString name () const override
QString toString () const override
Public Member Functions inherited from pappso::FilterNameInterface
virtual ~FilterNameInterface ()
Public Member Functions inherited from pappso::FilterInterface
virtual ~FilterInterface ()

Protected Member Functions

void buildFilterFromString (const QString &strBuildParams) override
 build this filter using a string

Private Types

typedef std::shared_ptr< DataPointInfoDataPointInfoSp

Private Member Functions

void addDataPointToList (std::vector< FilterChargeDeconvolution::DataPointInfoSp > &points, DataPoint &data_point) const
 Add each datapoint to a vector of structure describe above.
void addDataPointRefByExclusion (std::vector< FilterChargeDeconvolution::DataPointInfoSp > &points, FilterChargeDeconvolution::DataPointInfoSp &new_dpi) const
 For each datapointInfo add the datapoint to the lists by their exclusion range.
void computeBestChargeOfDataPoint (std::vector< FilterChargeDeconvolution::DataPointInfoSp > &data_points_info) const
 Compare both list (z1 and z2) and add the right level of charge.
void computeIsotopeDeconvolution (std::vector< FilterChargeDeconvolution::DataPointInfoSp > &data_points_info) const
 For eache datapointInfo whith no parent copy info in new vector with the intensity of the monoistipics peaks added.
void transformToMonoChargedForAllDataPoint (std::vector< FilterChargeDeconvolution::DataPointInfoSp > &data_points_info) const
 For eache datapointInfo with a charge = 2 transform the peak to a charge = 1 by multiplying the mz by 2 and remove 1 H.

Private Attributes

double m_diffC12C13_z1
double m_diffC12C13_z2
PrecisionPtr m_precisionPtrZ1
PrecisionPtr m_precisionPtrZ2

Detailed Description

Definition at line 42 of file filterchargedeconvolution.h.

Member Typedef Documentation

◆ DataPointInfoSp

Definition at line 46 of file filterchargedeconvolution.h.

Constructor & Destructor Documentation

◆ FilterChargeDeconvolution() [1/3]

FilterChargeDeconvolution::FilterChargeDeconvolution ( PrecisionPtr precision_ptr)

Default constructor

Definition at line 40 of file filterchargedeconvolution.cpp.

41 : m_precisionPtrZ1(precision_ptr)
42{
45 m_precisionPtrZ1 = precision_ptr;
48
49 // pappso::PrecisionFactory::getPrecisionDividedBy(m_precisionPtrZ1, 2):
50
51 // qInfo() << m_precisionPtrZ2->getNominal();
52}
static PrecisionPtr getPrecisionPtrFractionInstance(PrecisionPtr origin, double fraction)
get the fraction of an existing precision pointer
const pappso_double DIFFC12C13(1.0033548378)

References pappso::DIFFC12C13(), pappso::PrecisionFactory::getPrecisionPtrFractionInstance(), m_diffC12C13_z1, m_diffC12C13_z2, m_precisionPtrZ1, and m_precisionPtrZ2.

Referenced by FilterChargeDeconvolution().

◆ FilterChargeDeconvolution() [2/3]

pappso::FilterChargeDeconvolution::FilterChargeDeconvolution ( const QString & strBuildParams)
Parameters
strBuildParamsstring to build the filter "chargeDeconvolution|0.02dalton"

Definition at line 33 of file filterchargedeconvolution.cpp.

34{
35 buildFilterFromString(strBuildParams);
36 // qInfo() << "ChargeDeconvolution created";
37}
void buildFilterFromString(const QString &strBuildParams) override
build this filter using a string

References buildFilterFromString().

◆ FilterChargeDeconvolution() [3/3]

FilterChargeDeconvolution::FilterChargeDeconvolution ( const FilterChargeDeconvolution & other)

◆ ~FilterChargeDeconvolution()

FilterChargeDeconvolution::~FilterChargeDeconvolution ( )
virtual

Destructor

Definition at line 61 of file filterchargedeconvolution.cpp.

62{
63 qDebug() << "ChargeDeconvolution destroyed";
64}

Member Function Documentation

◆ addDataPointRefByExclusion()

void pappso::FilterChargeDeconvolution::addDataPointRefByExclusion ( std::vector< FilterChargeDeconvolution::DataPointInfoSp > & points,
FilterChargeDeconvolution::DataPointInfoSp & new_dpi ) const
private

For each datapointInfo add the datapoint to the lists by their exclusion range.

Returns
the vecotr of datapointInfo with their lists of isotopics peaks

Definition at line 162 of file filterchargedeconvolution.cpp.

165{
166 // add datapoint which match the mz_range = 1 to z1_list
167 auto i_z1 = points.begin(), end = points.end();
168 while(i_z1 != end)
169 {
170 // get the datapoint which match the range
171 i_z1 = std::find_if(i_z1, end, [&new_dpi](DataPointInfoSp dpi) {
172 return (new_dpi->data_point.x >= dpi->z1_range.first &&
173 new_dpi->data_point.x <= dpi->z1_range.second);
174 });
175 if(i_z1 != end)
176 {
177 // add the datapoint to the list and add the parent pointer
178 i_z1->get()->z1_vect.push_back(new_dpi);
179 new_dpi->parent = *i_z1;
180 DataPointInfoSp parent_z1 = i_z1->get()->parent.lock();
181 while(parent_z1 != nullptr)
182 {
183 parent_z1.get()->z1_vect.push_back(new_dpi);
184 parent_z1 = parent_z1->parent.lock();
185 }
186 i_z1++;
187 }
188 }
189
190 // add datapoint which match the mz_range = 2 to z2_list
191 auto i_z2 = points.begin();
192 while(i_z2 != end)
193 {
194 // get the datapoint which match the range
195 i_z2 = std::find_if(i_z2, end, [&new_dpi](DataPointInfoSp dpi) {
196 return (new_dpi->data_point.x >= dpi->z2_range.first &&
197 new_dpi->data_point.x <= dpi->z2_range.second);
198 });
199 if(i_z2 != end)
200 {
201 // add the datapoint to the list and add the parent pointer
202 i_z2->get()->z2_vect.push_back(new_dpi);
203 new_dpi->parent = *i_z2;
204 DataPointInfoSp parent_z2 = i_z2->get()->parent.lock();
205 while(parent_z2 != nullptr)
206 {
207 parent_z2.get()->z2_vect.push_back(new_dpi);
208 parent_z2 = parent_z2->parent.lock();
209 }
210 i_z2++;
211 }
212 }
213}
std::shared_ptr< DataPointInfo > DataPointInfoSp
pappso_double x
Definition datapoint.h:24

Referenced by addDataPointToList().

◆ addDataPointToList()

void pappso::FilterChargeDeconvolution::addDataPointToList ( std::vector< FilterChargeDeconvolution::DataPointInfoSp > & points,
pappso::DataPoint & data_point ) const
private

Add each datapoint to a vector of structure describe above.

Returns
the vecotr of datapointInfo with their datapoint and their exclusion mass range

Definition at line 146 of file filterchargedeconvolution.cpp.

149{
150 DataPointInfoSp new_dpi(std::make_shared<DataPointInfo>());
151
152 new_dpi->data_point = data_point;
153 MzRange range1(data_point.x + m_diffC12C13_z1, m_precisionPtrZ1);
154 new_dpi->z1_range = std::pair<double, double>(range1.lower(), range1.upper());
155 MzRange range2(data_point.x + m_diffC12C13_z2, m_precisionPtrZ2);
156 new_dpi->z2_range = std::pair<double, double>(range2.lower(), range2.upper());
157 addDataPointRefByExclusion(points, new_dpi);
158 points.push_back(new_dpi);
159}
void addDataPointRefByExclusion(std::vector< FilterChargeDeconvolution::DataPointInfoSp > &points, FilterChargeDeconvolution::DataPointInfoSp &new_dpi) const
For each datapointInfo add the datapoint to the lists by their exclusion range.

References addDataPointRefByExclusion(), pappso::MzRange::lower(), m_diffC12C13_z1, m_diffC12C13_z2, m_precisionPtrZ1, m_precisionPtrZ2, pappso::MzRange::upper(), and pappso::DataPoint::x.

Referenced by filter().

◆ buildFilterFromString()

void pappso::FilterChargeDeconvolution::buildFilterFromString ( const QString & strBuildParams)
overrideprotectedvirtual

build this filter using a string

Parameters
strBuildParamsa string coding the filter and its parameters "filterName|param1;param2;param3"

Implements pappso::FilterNameInterface.

Definition at line 68 of file filterchargedeconvolution.cpp.

69{
70 //"chargeDeconvolution|0.02dalton"
71 qDebug();
72 if(strBuildParams.startsWith("chargeDeconvolution|"))
73 {
74 QStringList params = strBuildParams.split("|").back().split(";", Qt::SkipEmptyParts);
75
76 QString precision = params.at(0);
78 precision.replace("dalton", " dalton").replace("ppm", " ppm").replace("res", " res"));
79 qDebug();
82
83
86 }
87 else
88 {
89 throw pappso::ExceptionNotRecognized(
90 QString("building chargeDeconvolution from string %1 is not possible").arg(strBuildParams));
91 }
92 qDebug();
93}
static PrecisionPtr fromString(const QString &str)
get a precision pointer from a string
Definition precision.cpp:80

References pappso::DIFFC12C13(), pappso::PrecisionFactory::fromString(), pappso::PrecisionFactory::getPrecisionPtrFractionInstance(), m_diffC12C13_z1, m_diffC12C13_z2, m_precisionPtrZ1, and m_precisionPtrZ2.

Referenced by FilterChargeDeconvolution().

◆ computeBestChargeOfDataPoint()

void pappso::FilterChargeDeconvolution::computeBestChargeOfDataPoint ( std::vector< FilterChargeDeconvolution::DataPointInfoSp > & data_points_info) const
private

Compare both list (z1 and z2) and add the right level of charge.

Returns
the vecotr of datapointInfo with their charge

Definition at line 216 of file filterchargedeconvolution.cpp.

218{
219 for(DataPointInfoSp &data_point_info : data_points_info)
220 {
221 if(data_point_info.get()->z1_vect.size() >= 1 && data_point_info.get()->z2_vect.size() == 0)
222 {
223 for(std::weak_ptr<DataPointInfo> other : data_point_info.get()->z1_vect)
224 {
225 other.lock()->z_charge = 1;
226 }
227 data_point_info.get()->z_charge = 1;
228 }
229 else if(data_point_info.get()->z1_vect.size() == 0 &&
230 data_point_info.get()->z2_vect.size() >= 1)
231 {
232 for(std::weak_ptr<DataPointInfo> other : data_point_info.get()->z2_vect)
233 {
234 other.lock()->z_charge = 2;
235 }
236 data_point_info.get()->z_charge = 2;
237 }
238 else if(data_point_info.get()->z1_vect.size() >= 1 &&
239 data_point_info.get()->z2_vect.size() >= 1)
240 {
241 for(std::weak_ptr<DataPointInfo> other : data_point_info.get()->z2_vect)
242 {
243 other.lock()->z_charge = 2;
244 }
245 data_point_info.get()->z_charge = 2;
246 }
247 else
248 {
249 if(data_point_info.get()->z_charge == -1)
250 {
251 data_point_info.get()->z_charge = 0;
252 }
253 }
254 }
255}

Referenced by filter().

◆ computeIsotopeDeconvolution()

void pappso::FilterChargeDeconvolution::computeIsotopeDeconvolution ( std::vector< FilterChargeDeconvolution::DataPointInfoSp > & data_points_info) const
private

For eache datapointInfo whith no parent copy info in new vector with the intensity of the monoistipics peaks added.

Returns
the vecotr of datapointInfo with their intensity merged

Definition at line 258 of file filterchargedeconvolution.cpp.

260{
261 std::vector<FilterChargeDeconvolution::DataPointInfoSp> deconvoluted_points_info;
262
263 for(DataPointInfoSp &data_point_info : data_points_info)
264 {
265 if(data_point_info->parent.lock() == nullptr)
266 {
267 DataPointInfoSp deconvoluted_point(std::make_shared<DataPointInfo>());
268
269 deconvoluted_point->z_charge = data_point_info->z_charge;
270 deconvoluted_point->new_mono_charge_data_point = data_point_info->data_point;
271
272 if(data_point_info->z_charge == 1)
273 {
274
275 for(std::weak_ptr<DataPointInfo> data : data_point_info->z1_vect)
276 {
277 deconvoluted_point->new_mono_charge_data_point.y += data.lock()->data_point.y;
278 }
279 }
280 else if(data_point_info->z_charge == 2)
281 {
282 for(std::weak_ptr<DataPointInfo> data : data_point_info->z2_vect)
283 {
284 deconvoluted_point->new_mono_charge_data_point.y += data.lock()->data_point.y;
285 }
286 }
287 else // if z.charge == 0
288 {
289 deconvoluted_point->new_mono_charge_data_point = data_point_info->data_point;
290 }
291 deconvoluted_points_info.push_back(deconvoluted_point);
292 }
293 }
294 data_points_info = deconvoluted_points_info;
295}

Referenced by filter().

◆ filter()

Trace & FilterChargeDeconvolution::filter ( Trace & data_points) const
overridevirtual

get all the datapoints and remove different isotope and add their intensity and change to charge = 1 when the charge is known

Returns
a list of datapoint

Implements pappso::FilterInterface.

Definition at line 114 of file filterchargedeconvolution.cpp.

115{
116 qDebug();
117 std::vector<FilterChargeDeconvolution::DataPointInfoSp> data_points_info;
119 qDebug() << data_points.size();
120 Trace new_trace;
121
122 for(auto &data_point : data_points)
123 {
124 addDataPointToList(data_points_info, data_point);
125 }
126 computeBestChargeOfDataPoint(data_points_info);
127
128 // qDebug() << data_points_info.size();
129 computeIsotopeDeconvolution(data_points_info);
130 // qDebug() << data_points_info.size();
132 for(DataPointInfoSp &dpi : data_points_info)
133 {
134 // qDebug() << dpi->new_mono_charge_data_point.x << dpi->z_charge;
135 new_trace.push_back(dpi->new_mono_charge_data_point);
136 }
137
138 new_trace.sortX();
139 data_points = std::move(new_trace);
140 qDebug() << data_points.size();
141 qDebug();
142 return data_points;
143}
void computeBestChargeOfDataPoint(std::vector< FilterChargeDeconvolution::DataPointInfoSp > &data_points_info) const
Compare both list (z1 and z2) and add the right level of charge.
void transformToMonoChargedForAllDataPoint(std::vector< FilterChargeDeconvolution::DataPointInfoSp > &data_points_info) const
For eache datapointInfo with a charge = 2 transform the peak to a charge = 1 by multiplying the mz by...
void addDataPointToList(std::vector< FilterChargeDeconvolution::DataPointInfoSp > &points, DataPoint &data_point) const
Add each datapoint to a vector of structure describe above.
void computeIsotopeDeconvolution(std::vector< FilterChargeDeconvolution::DataPointInfoSp > &data_points_info) const
For eache datapointInfo whith no parent copy info in new vector with the intensity of the monoistipic...
void sortY(Enums::SortOrder sort_order=Enums::SortOrder::ascending)
Definition trace.cpp:1049
void sortX(Enums::SortOrder sort_order=Enums::SortOrder::ascending)
Definition trace.cpp:1039

References addDataPointToList(), computeBestChargeOfDataPoint(), computeIsotopeDeconvolution(), pappso::Enums::descending, pappso::Trace::sortX(), pappso::Trace::sortY(), and transformToMonoChargedForAllDataPoint().

Referenced by pappso::cbor::psm::PsmSpecGlob::filterMassSpectrum(), and pappso::cbor::psm::PsmSpecPeptidOms::filterMassSpectrum().

◆ name()

QString pappso::FilterChargeDeconvolution::name ( ) const
overridevirtual

Implements pappso::FilterNameInterface.

Definition at line 97 of file filterchargedeconvolution.cpp.

98{
99 return "chargeDeconvolution";
100}

Referenced by toString().

◆ toString()

QString pappso::FilterChargeDeconvolution::toString ( ) const
overridevirtual

Implements pappso::FilterNameInterface.

Definition at line 104 of file filterchargedeconvolution.cpp.

105{
106 QString strCode = QString("%1|%2").arg(name()).arg(m_precisionPtrZ1->toString());
107
108 strCode.replace(" ", "");
109
110 return strCode;
111}
virtual QString name() const override

References m_precisionPtrZ1, and name().

◆ transformToMonoChargedForAllDataPoint()

void pappso::FilterChargeDeconvolution::transformToMonoChargedForAllDataPoint ( std::vector< FilterChargeDeconvolution::DataPointInfoSp > & data_points_info) const
private

For eache datapointInfo with a charge = 2 transform the peak to a charge = 1 by multiplying the mz by 2 and remove 1 H.

Returns
the vecotr of datapointInfo their z corrected

Definition at line 298 of file filterchargedeconvolution.cpp.

300{
301 for(DataPointInfoSp &dpi : data_points_info)
302 {
303 if(dpi->z_charge == 2)
304 {
305 dpi->new_mono_charge_data_point.x += dpi->new_mono_charge_data_point.x - MHPLUS;
306 }
307 }
308}
const pappso_double MHPLUS(1.007276466879)

References pappso::MHPLUS().

Referenced by filter().

Member Data Documentation

◆ m_diffC12C13_z1

double pappso::FilterChargeDeconvolution::m_diffC12C13_z1
private

◆ m_diffC12C13_z2

double pappso::FilterChargeDeconvolution::m_diffC12C13_z2
private

◆ m_precisionPtrZ1

PrecisionPtr pappso::FilterChargeDeconvolution::m_precisionPtrZ1
private

◆ m_precisionPtrZ2

PrecisionPtr pappso::FilterChargeDeconvolution::m_precisionPtrZ2
private

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