64 qDebug() <<
"ChargeDeconvolution destroyed";
73 if(strBuildParams.startsWith(
"chargeDeconvolution|"))
75 QStringList params = strBuildParams.split(
"|").back().split(
";", Qt::SkipEmptyParts);
77 QString precision = params.at(0);
79 precision.replace(
"dalton",
" dalton").replace(
"ppm",
" ppm").replace(
"res",
" res"));
91 QString(
"building chargeDeconvolution from string %1 is not possible").arg(strBuildParams));
100 return "chargeDeconvolution";
109 strCode.replace(
" ",
"");
118 std::vector<FilterChargeDeconvolution::DataPointInfoSp> data_points_info;
120 qDebug() << data_points.size();
123 for(
auto &data_point : data_points)
136 new_trace.push_back(dpi->new_mono_charge_data_point);
140 data_points = std::move(new_trace);
141 qDebug() << data_points.size();
148 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &points,
153 new_dpi->data_point = data_point;
155 new_dpi->z1_range = std::pair<double, double>(range1.
lower(), range1.
upper());
157 new_dpi->z2_range = std::pair<double, double>(range2.
lower(), range2.
upper());
159 points.push_back(new_dpi);
164 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &points,
168 auto i_z1 = points.begin(), end = points.end();
173 return (new_dpi->data_point.x >= dpi->z1_range.first &&
174 new_dpi->data_point.x <= dpi->z1_range.second);
179 i_z1->get()->z1_vect.push_back(new_dpi);
180 new_dpi->parent = *i_z1;
182 while(parent_z1 !=
nullptr)
184 parent_z1.get()->z1_vect.push_back(new_dpi);
185 parent_z1 = parent_z1->parent.lock();
192 auto i_z2 = points.begin();
197 return (new_dpi->data_point.x >= dpi->z2_range.first &&
198 new_dpi->data_point.x <= dpi->z2_range.second);
203 i_z2->get()->z2_vect.push_back(new_dpi);
204 new_dpi->parent = *i_z2;
206 while(parent_z2 !=
nullptr)
208 parent_z2.get()->z2_vect.push_back(new_dpi);
209 parent_z2 = parent_z2->parent.lock();
218 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &data_points_info)
const
222 if(data_point_info.get()->z1_vect.size() >= 1 && data_point_info.get()->z2_vect.size() == 0)
224 for(std::weak_ptr<DataPointInfo> other : data_point_info.get()->z1_vect)
226 other.lock()->z_charge = 1;
228 data_point_info.get()->z_charge = 1;
230 else if(data_point_info.get()->z1_vect.size() == 0 &&
231 data_point_info.get()->z2_vect.size() >= 1)
233 for(std::weak_ptr<DataPointInfo> other : data_point_info.get()->z2_vect)
235 other.lock()->z_charge = 2;
237 data_point_info.get()->z_charge = 2;
239 else if(data_point_info.get()->z1_vect.size() >= 1 &&
240 data_point_info.get()->z2_vect.size() >= 1)
242 for(std::weak_ptr<DataPointInfo> other : data_point_info.get()->z2_vect)
244 other.lock()->z_charge = 2;
246 data_point_info.get()->z_charge = 2;
250 if(data_point_info.get()->z_charge == -1)
252 data_point_info.get()->z_charge = 0;
260 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &data_points_info)
const
262 std::vector<FilterChargeDeconvolution::DataPointInfoSp> deconvoluted_points_info;
266 if(data_point_info->parent.lock() ==
nullptr)
270 deconvoluted_point->z_charge = data_point_info->z_charge;
271 deconvoluted_point->new_mono_charge_data_point = data_point_info->data_point;
273 if(data_point_info->z_charge == 1)
276 for(std::weak_ptr<DataPointInfo> data : data_point_info->z1_vect)
278 deconvoluted_point->new_mono_charge_data_point.y += data.lock()->data_point.y;
281 else if(data_point_info->z_charge == 2)
283 for(std::weak_ptr<DataPointInfo> data : data_point_info->z2_vect)
285 deconvoluted_point->new_mono_charge_data_point.y += data.lock()->data_point.y;
290 deconvoluted_point->new_mono_charge_data_point = data_point_info->data_point;
292 deconvoluted_points_info.push_back(deconvoluted_point);
295 data_points_info = deconvoluted_points_info;
300 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &data_points_info)
const
304 if(dpi->z_charge == 2)
306 dpi->new_mono_charge_data_point.x += dpi->new_mono_charge_data_point.x -
MHPLUS;
excetion to use when an item type is not recognized
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 buildFilterFromString(const QString &strBuildParams) override
build this filter using a string
virtual QString name() const override
QString toString() const override
std::shared_ptr< DataPointInfo > DataPointInfoSp
void computeBestChargeOfDataPoint(std::vector< FilterChargeDeconvolution::DataPointInfoSp > &data_points_info) const
Compare both list (z1 and z2) and add the right level of charge.
FilterChargeDeconvolution(PrecisionPtr precision_ptr)
PrecisionPtr m_precisionPtrZ2
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.
PrecisionPtr m_precisionPtrZ1
Trace & filter(Trace &data_points) const override
get all the datapoints and remove different isotope and add their intensity and change to charge = 1 ...
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...
virtual ~FilterChargeDeconvolution()
pappso_double lower() const
pappso_double upper() const
static PrecisionPtr fromString(const QString &str)
get a precision pointer from a string
static PrecisionPtr getPrecisionPtrFractionInstance(PrecisionPtr origin, double fraction)
get the fraction of an existing precision pointer
A simple container of DataPoint instances.
void sortY(Enums::SortOrder sort_order=Enums::SortOrder::ascending)
void sortX(Enums::SortOrder sort_order=Enums::SortOrder::ascending)
tries to keep as much as possible monoisotopes, removing any possible C13 peaks and changes multichar...
const pappso_double MHPLUS(1.007276466879)
const PrecisionBase * PrecisionPtr
const pappso_double DIFFC12C13(1.0033548378)