34{
35 picked_peaks.clear();
36
37 qsizetype trace_size = trace.size();
38
39 if(trace_size < 5)
40 return;
41
42
43 LocalSignalToNoiseEstimator::Parameters signal_to_noise_estimator_parameters;
44 LocalSignalToNoiseEstimator local_signal_estimator(signal_to_noise_estimator_parameters);
45
47 {
48
49
50 local_signal_estimator.initialize(trace);
51 }
52
53
54
55 for(qsizetype iter = 2; iter < trace_size - 2; ++iter)
56 {
57
59 {
60 qDebug() << "Now skipping low intensity peak at m/z:" << trace.at(iter).x
61 << "with intensity:" << trace.at(iter).y;
62 continue;
63 }
64 double center_data_point_mz = trace.at(iter).x;
65 double center_data_point_int = trace.at(iter).y;
66 double left_data_point_mz = trace.at(iter - 1).x;
67 double left_data_point_int = trace.at(iter - 1).y;
68 double right_data_point_mz = trace.at(iter + 1).x;
69 double right_data_point_int = trace.at(iter + 1).y;
70
71
72 if(std::fabs(left_data_point_int) <
73 std::numeric_limits<double>::epsilon())
74 {
75 continue;
76 }
77 if(std::fabs(right_data_point_int) <
78 std::numeric_limits<double>::epsilon())
79 {
80 continue;
81 }
82
83 double current_snt_estimate = 0.0;
84 double current_snt_estimate_left_1 = 0.0;
85 double current_snt_estimate_right_1 = 0.0;
86
88 {
89 current_snt_estimate =
90 local_signal_estimator.getSignalToNoiseRatio(iter);
91
92
93
94
95
96
97 current_snt_estimate_left_1 =
98 local_signal_estimator.getSignalToNoiseRatio(iter - 1);
99 current_snt_estimate_right_1 =
100 local_signal_estimator.getSignalToNoiseRatio(iter + 1);
101 }
102
103
104
105
106
107
108 if((center_data_point_int > left_data_point_int) &&
109 (center_data_point_int > right_data_point_int) &&
111 (current_snt_estimate_left_1 >=
m_parameters.signalToNoise) &&
112 (current_snt_estimate_right_1 >=
m_parameters.signalToNoise))
113 {
114
115
116
117
118
119
120 double current_snt_estimate_left_2 = 0.0;
121 double current_snt_estimate_right_2 = 0.0;
122
124 {
125 current_snt_estimate_left_2 =
126 local_signal_estimator.getSignalToNoiseRatio(iter - 2);
127 current_snt_estimate_right_2 =
128 local_signal_estimator.getSignalToNoiseRatio(iter + 2);
129 }
130
131
132 if((iter > 1) && (iter + 2 < static_cast<qsizetype>(trace.size())) &&
133 (left_data_point_int < trace.at(iter - 2).y) &&
134 (right_data_point_int < trace.at(iter + 2).y) &&
135 (current_snt_estimate_left_2 >=
m_parameters.signalToNoise) &&
136 (current_snt_estimate_right_2 >=
m_parameters.signalToNoise))
137 {
138
139
140
141
142
143
144
145 ++iter;
146 continue;
147 }
148
149 QMap<double, double> peak_raw_data;
150
151 peak_raw_data[center_data_point_mz] = center_data_point_int;
152 peak_raw_data[left_data_point_mz] = left_data_point_int;
153 peak_raw_data[right_data_point_mz] = right_data_point_int;
154
155
156 qsizetype k = 2;
157
158
159 bool previous_zero_left = false;
160 qsizetype missing_left_count = 0;
161
162 qsizetype left_boundary = iter - 1;
163
164 while((k <= iter) &&
165 (iter - k + 1 > 0) && !previous_zero_left &&
166 (trace.at(iter - k).y <= peak_raw_data.begin().value()))
167 {
168 double current_snt_estimate_left_k = 0.0;
169
171 {
172 current_snt_estimate_left_k =
173 local_signal_estimator.getSignalToNoiseRatio(iter - k);
174 }
175
176 if(current_snt_estimate_left_k >=
m_parameters.signalToNoise)
177 {
178 peak_raw_data[trace.at(iter - k).x] = trace.at(iter - k).y;
179 }
180 {
181 ++missing_left_count;
183 {
184 peak_raw_data[trace.at(iter - k).x] = trace.at(iter - k).y;
185 }
186 }
187
188 previous_zero_left = (trace.at(iter - k).
y == 0);
189 left_boundary = iter - k;
190 ++k;
191 }
192
193
194 k = 2;
195
196
197 bool previous_zero_right = false;
198 qsizetype missing_right_count = 0;
199
200 qsizetype right_boundary(iter + 1);
201
202 while((iter + k < static_cast<qsizetype>(trace.size())) &&
203 !previous_zero_right &&
204 (trace.at(iter + k).y <= peak_raw_data.last()))
205 {
206 double current_snt_estimate_right_k = 0.0;
207
209 {
210 current_snt_estimate_right_k =
211 local_signal_estimator.getSignalToNoiseRatio(iter + k);
212 }
213
214 if(current_snt_estimate_right_k >=
m_parameters.signalToNoise)
215 {
216 peak_raw_data[trace.at(iter + k).x] = trace.at(iter + k).y;
217 }
218 else
219 {
220 ++missing_right_count;
221 if(missing_right_count <=
m_parameters.missingPeakCount)
222 {
223 peak_raw_data[trace.at(iter + k).x] =
224 trace.at(iter + k).y;
225 }
226 }
227
228 previous_zero_right = (trace.at(iter + k).
y == 0);
229 right_boundary = iter + k;
230 ++k;
231 }
232
233
234 if(peak_raw_data.size() < 3)
235 {
236 continue;
237 }
238
239
240
241 CubicSplineModel cubic_spline_model(peak_raw_data);
242
243
244
245
246
247
248
249
250 double max_peak_mz = center_data_point_mz;
251 double max_peak_int = center_data_point_int;
252 double threshold = 1e-6;
254 left_data_point_mz,
255 right_data_point_mz,
256 max_peak_mz,
257 max_peak_int,
258 threshold);
259
260
261 DataPoint data_point;
262
264
265 data_point.x = max_peak_mz;
266 data_point.y = max_peak_int;
267 peak_range.
mz_start = trace.at(left_boundary).x;
268 peak_range.mz_stop = trace.at(right_boundary).x;
269
270
271
272
273 picked_peaks.append(data_point);
274
275 peak_ranges.push_back(peak_range);
276
277
278 iter += k - 1;
279 }
280 }
281
282
283
284}
void spline_bisection(const CubicSplineModel &spline_model, double const mz_at_left, double const mz_at_right, double ¢er_peak_mz, double ¢er_peak_intensity, double const threshold)