43 template <
typename Container = MSSpectrum>
67 this->
setName(
"SignalToNoiseEstimatorMeanIterative");
69 defaults_.
setValue(
"max_intensity", -1,
"maximal intensity considered for histogram construction. By default, it will be calculated automatically (see auto_mode)." \
70 " Only provide this parameter if you know what you are doing (and change 'auto_mode' to '-1')!" \
71 " All intensities EQUAL/ABOVE 'max_intensity' will not be added to the histogram." \
72 " If you choose 'max_intensity' too small, the noise estimate might be too small as well." \
73 " If chosen too big, the bins become quite large (which you could counter by increasing 'bin_count', which increases runtime).", {
"advanced"});
76 defaults_.
setValue(
"auto_max_stdev_factor", 3.0,
"parameter for 'max_intensity' estimation (if 'auto_mode' == 0): mean + 'auto_max_stdev_factor' * stdev", {
"advanced"});
81 defaults_.
setValue(
"auto_max_percentile", 95,
"parameter for 'max_intensity' estimation (if 'auto_mode' == 1): auto_max_percentile th percentile", {
"advanced"});
85 defaults_.
setValue(
"auto_mode", 0,
"method to use to determine maximal intensity: -1 --> use 'max_intensity'; 0 --> 'auto_max_stdev_factor' method (default); 1 --> 'auto_max_percentile' method", {
"advanced"});
99 defaults_.
setValue(
"min_required_elements", 10,
"minimum number of elements required in a window (otherwise it is considered sparse)");
102 defaults_.
setValue(
"noise_for_empty_window", std::pow(10.0, 20),
"noise value used for sparse windows", {
"advanced"});
120 if (&source ==
this)
return *
this;
150 double sparse_window_percent = 0;
172 OPENMS_PRETTY_FUNCTION,
173 "auto_mode is on AUTOMAXBYPERCENT! auto_max_percentile is not in [0,100]. Use setAutoMaxPercentile(<value>) to change it!",
177 std::vector<int> histogram_auto(100, 0);
180 auto maxIt = std::max_element(
c.begin(),
c.end() ,[](
const PeakType& a,
const PeakType& b){ return a.getIntensity() > b.getIntensity();});
183 double bin_size = maxInt / 100;
188 ++histogram_auto[(int) (((run).getIntensity() - 1) / bin_size)];
193 int elements_seen = 0;
197 while (run != scan_last_ && elements_seen < elements_below_percentile)
200 elements_seen += histogram_auto[i];
213 OPENMS_PRETTY_FUNCTION,
214 "auto_mode is on MANUAL! max_intensity is <=0. Needs to be positive! Use setMaxIntensity(<value>) or enable auto_mode!",
221 std::cerr <<
"TODO SignalToNoiseEstimatorMedian: the max_intensity_ value should be positive! " <<
max_intensity_ << std::endl;
229 double window_half_size =
win_len_ / 2;
238 bin_value[bin] = (bin + 0.5) * bin_size;
241 int hist_rightmost_bin;
249 int elements_in_window = 0;
250 int window_count = 0;
258 while (window_pos_center != scan_last_)
261 while ((*window_pos_borderleft).getMZ() < (*window_pos_center).getMZ() - window_half_size)
264 to_bin = (int) ((std::max((*window_pos_borderleft).getIntensity(), 0.0f)) / bin_size);
268 --elements_in_window;
270 ++window_pos_borderleft;
277 while ((window_pos_borderright != scan_last_)
278 && ((*window_pos_borderright).getMZ() < (*window_pos_center).getMZ() + window_half_size))
282 to_bin = (int) ((std::max((*window_pos_borderright).getIntensity(), 0.0f)) / bin_size);
286 ++elements_in_window;
288 ++window_pos_borderright;
294 ++sparse_window_percent;
302 for (
int i = 0; i < 3; ++i)
306 for (
int bin = 0; bin < hist_rightmost_bin; ++bin)
310 hist_mean += histogram[bin] / (double) elements_in_window * bin_value[bin];
316 for (
int bin = 0; bin < hist_rightmost_bin; ++bin)
318 double tmp(bin_value[bin] - hist_mean);
319 hist_stdev += histogram[bin] / (double) elements_in_window * tmp * tmp;
321 hist_stdev = std::sqrt(hist_stdev);
324 int estimate = (int) ((hist_mean + hist_stdev *
stdev_ - 1) / bin_size + 1);
326 hist_rightmost_bin = std::min(estimate,
bin_count_);
330 noise = std::max(1.0, hist_mean);
334 stn_estimates_[window_count] = (*window_pos_center).getIntensity() / noise;
348 sparse_window_percent = sparse_window_percent * 100 / window_count;
350 if (sparse_window_percent > 20)
352 std::cerr <<
"WARNING in SignalToNoiseEstimatorMeanIterative: "
353 << sparse_window_percent
354 <<
"% of all windows were sparse. You should consider increasing 'win_len' or increasing 'min_required_elements'"
355 <<
" You should also check the MaximalIntensity value (or the parameters for its heuristic estimation)"
356 <<
" If it is too low, then too many high intensity peaks will be discarded, which leads to a sparse window!"
void defaultsToParam_()
Updates the parameters after the defaults have been set in the constructor.
Param param_
Container for current parameters.
Definition: DefaultParamHandler.h:139
Param defaults_
Container for default parameters. This member should be filled in the constructor of derived classes!
Definition: DefaultParamHandler.h:146
void setName(const String &name)
Mutable access to the name.
Invalid value exception.
Definition: Exception.h:305
void setMaxFloat(const std::string &key, double max)
Sets the maximum value for the floating point or floating point list parameter key.
void setMaxInt(const std::string &key, int max)
Sets the maximum value for the integer or integer list parameter key.
const ParamValue & getValue(const std::string &key) const
Returns a value of a parameter.
void setMinInt(const std::string &key, int min)
Sets the minimum value for the integer or integer list parameter key.
void setValue(const std::string &key, const ParamValue &value, const std::string &description="", const std::vector< std::string > &tags=std::vector< std::string >())
Sets a value.
void setMinFloat(const std::string &key, double min)
Sets the minimum value for the floating point or floating point list parameter key.
float IntensityType
Intensity type.
Definition: Peak2D.h:36
void setProgress(SignedSize value) const
Sets the current progress.
void startProgress(SignedSize begin, SignedSize end, const String &label) const
Initializes the progress display.
void endProgress(UInt64 bytes_processed=0) const
Estimates the signal/noise (S/N) ratio of each data point in a scan based on an iterative scheme whic...
Definition: SignalToNoiseEstimatorMeanIterative.h:46
SignalToNoiseEstimator< Container >::PeakIterator PeakIterator
Definition: SignalToNoiseEstimatorMeanIterative.h:57
SignalToNoiseEstimatorMeanIterative()
default constructor
Definition: SignalToNoiseEstimatorMeanIterative.h:64
double win_len_
range of data points which belong to a window in Thomson
Definition: SignalToNoiseEstimatorMeanIterative.h:388
double stdev_
multiplier for the stdev of intensities
Definition: SignalToNoiseEstimatorMeanIterative.h:392
double noise_for_empty_window_
Definition: SignalToNoiseEstimatorMeanIterative.h:397
~SignalToNoiseEstimatorMeanIterative() override
Destructor.
Definition: SignalToNoiseEstimatorMeanIterative.h:131
SignalToNoiseEstimatorMeanIterative(const SignalToNoiseEstimatorMeanIterative &source)
Copy Constructor.
Definition: SignalToNoiseEstimatorMeanIterative.h:108
double max_intensity_
maximal intensity considered during binning (values above get discarded)
Definition: SignalToNoiseEstimatorMeanIterative.h:380
double auto_max_percentile_
parameter for initial automatic estimation of "max_intensity_" percentile or a stdev
Definition: SignalToNoiseEstimatorMeanIterative.h:384
void computeSTN_(const Container &c) override
Definition: SignalToNoiseEstimatorMeanIterative.h:142
void updateMembers_() override
overridden function from DefaultParamHandler to keep members up to date, when a parameter is changed
Definition: SignalToNoiseEstimatorMeanIterative.h:365
int min_required_elements_
minimal number of elements a window needs to cover to be used
Definition: SignalToNoiseEstimatorMeanIterative.h:394
SignalToNoiseEstimator< Container >::PeakType PeakType
Definition: SignalToNoiseEstimatorMeanIterative.h:58
SignalToNoiseEstimator< Container >::GaussianEstimate GaussianEstimate
Definition: SignalToNoiseEstimatorMeanIterative.h:60
int auto_mode_
determines which method shall be used for estimating "max_intensity_". valid are MANUAL=-1,...
Definition: SignalToNoiseEstimatorMeanIterative.h:386
IntensityThresholdCalculation
method to use for estimating the maximal intensity that is used for histogram calculation
Definition: SignalToNoiseEstimatorMeanIterative.h:51
@ MANUAL
Definition: SignalToNoiseEstimatorMeanIterative.h:51
@ AUTOMAXBYSTDEV
Definition: SignalToNoiseEstimatorMeanIterative.h:51
@ AUTOMAXBYPERCENT
Definition: SignalToNoiseEstimatorMeanIterative.h:51
SignalToNoiseEstimatorMeanIterative & operator=(const SignalToNoiseEstimatorMeanIterative &source)
Definition: SignalToNoiseEstimatorMeanIterative.h:118
int bin_count_
number of bins in the histogram
Definition: SignalToNoiseEstimatorMeanIterative.h:390
double auto_max_stdev_Factor_
parameter for initial automatic estimation of "max_intensity_": a stdev multiplier
Definition: SignalToNoiseEstimatorMeanIterative.h:382
This class represents the abstract base class of a signal to noise estimator.
Definition: SignalToNoiseEstimator.h:33
double variance
variance of estimated Gaussian
Definition: SignalToNoiseEstimator.h:108
SignalToNoiseEstimator & operator=(const SignalToNoiseEstimator &source)
Assignment operator.
Definition: SignalToNoiseEstimator.h:60
PeakIterator::value_type PeakType
Definition: SignalToNoiseEstimator.h:40
GaussianEstimate estimate_(const PeakIterator &scan_first_, const PeakIterator &scan_last_) const
calculate mean & stdev of intensities of a spectrum
Definition: SignalToNoiseEstimator.h:113
double mean
mean of estimated Gaussian
Definition: SignalToNoiseEstimator.h:107
std::vector< double > stn_estimates_
stores the noise estimate for each peak
Definition: SignalToNoiseEstimator.h:146
Container::const_iterator PeakIterator
Definition: SignalToNoiseEstimator.h:39
protected struct to store parameters my, sigma for a Gaussian distribution
Definition: SignalToNoiseEstimator.h:106
A more convenient string class.
Definition: String.h:34
const double c
Definition: Constants.h:188
Main OpenMS namespace.
Definition: openswathalgo/include/OpenMS/OPENSWATHALGO/DATAACCESS/ISpectrumAccess.h:19