63 qDebug() <<
"ChargeDeconvolution destroyed";
72 if(strBuildParams.startsWith(
"chargeDeconvolution|"))
74 QStringList params = strBuildParams.split(
"|").back().split(
";", Qt::SkipEmptyParts);
76 QString precision = params.at(0);
78 precision.replace(
"dalton",
" dalton").replace(
"ppm",
" ppm").replace(
"res",
" res"));
90 QString(
"building chargeDeconvolution from string %1 is not possible").arg(strBuildParams));
99 return "chargeDeconvolution";
108 strCode.replace(
" ",
"");
117 std::vector<FilterChargeDeconvolution::DataPointInfoSp> data_points_info;
119 qDebug() << data_points.size();
122 for(
auto &data_point : data_points)
135 new_trace.push_back(dpi->new_mono_charge_data_point);
139 data_points = std::move(new_trace);
140 qDebug() << data_points.size();
147 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &points,
152 new_dpi->data_point = data_point;
154 new_dpi->z1_range = std::pair<double, double>(range1.
lower(), range1.
upper());
156 new_dpi->z2_range = std::pair<double, double>(range2.
lower(), range2.
upper());
158 points.push_back(new_dpi);
163 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &points,
167 auto i_z1 = points.begin(), end = points.end();
172 return (new_dpi->data_point.x >= dpi->z1_range.first &&
173 new_dpi->data_point.x <= dpi->z1_range.second);
178 i_z1->get()->z1_vect.push_back(new_dpi);
179 new_dpi->parent = *i_z1;
181 while(parent_z1 !=
nullptr)
183 parent_z1.get()->z1_vect.push_back(new_dpi);
184 parent_z1 = parent_z1->parent.lock();
191 auto i_z2 = points.begin();
196 return (new_dpi->data_point.x >= dpi->z2_range.first &&
197 new_dpi->data_point.x <= dpi->z2_range.second);
202 i_z2->get()->z2_vect.push_back(new_dpi);
203 new_dpi->parent = *i_z2;
205 while(parent_z2 !=
nullptr)
207 parent_z2.get()->z2_vect.push_back(new_dpi);
208 parent_z2 = parent_z2->parent.lock();
217 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &data_points_info)
const
221 if(data_point_info.get()->z1_vect.size() >= 1 && data_point_info.get()->z2_vect.size() == 0)
223 for(std::weak_ptr<DataPointInfo> other : data_point_info.get()->z1_vect)
225 other.lock()->z_charge = 1;
227 data_point_info.get()->z_charge = 1;
229 else if(data_point_info.get()->z1_vect.size() == 0 &&
230 data_point_info.get()->z2_vect.size() >= 1)
232 for(std::weak_ptr<DataPointInfo> other : data_point_info.get()->z2_vect)
234 other.lock()->z_charge = 2;
236 data_point_info.get()->z_charge = 2;
238 else if(data_point_info.get()->z1_vect.size() >= 1 &&
239 data_point_info.get()->z2_vect.size() >= 1)
241 for(std::weak_ptr<DataPointInfo> other : data_point_info.get()->z2_vect)
243 other.lock()->z_charge = 2;
245 data_point_info.get()->z_charge = 2;
249 if(data_point_info.get()->z_charge == -1)
251 data_point_info.get()->z_charge = 0;
259 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &data_points_info)
const
261 std::vector<FilterChargeDeconvolution::DataPointInfoSp> deconvoluted_points_info;
265 if(data_point_info->parent.lock() ==
nullptr)
269 deconvoluted_point->z_charge = data_point_info->z_charge;
270 deconvoluted_point->new_mono_charge_data_point = data_point_info->data_point;
272 if(data_point_info->z_charge == 1)
275 for(std::weak_ptr<DataPointInfo> data : data_point_info->z1_vect)
277 deconvoluted_point->new_mono_charge_data_point.y += data.lock()->data_point.y;
280 else if(data_point_info->z_charge == 2)
282 for(std::weak_ptr<DataPointInfo> data : data_point_info->z2_vect)
284 deconvoluted_point->new_mono_charge_data_point.y += data.lock()->data_point.y;
289 deconvoluted_point->new_mono_charge_data_point = data_point_info->data_point;
291 deconvoluted_points_info.push_back(deconvoluted_point);
294 data_points_info = deconvoluted_points_info;
299 std::vector<FilterChargeDeconvolution::DataPointInfoSp> &data_points_info)
const
303 if(dpi->z_charge == 2)
305 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)