11 #include <OpenMS/config.h> 
   29         double const left_neighbor_mz,
 
   30         double const right_neighbor_mz,
 
   32         double & max_peak_int,
 
   33         double const threshold = 1e-6)
 
   37       double lefthand = left_neighbor_mz;
 
   38       double righthand = right_neighbor_mz;
 
   40       bool lefthand_sign = 
true;
 
   41       double eps = std::numeric_limits<double>::epsilon();
 
   46         double mid = (lefthand + righthand) / 2.0;
 
   47         double midpoint_deriv_val = peak_spline.derivative(mid);
 
   50         if (!(std::fabs(midpoint_deriv_val) > eps))
 
   55         bool midpoint_sign = (midpoint_deriv_val < 0.0) ? 
false : 
true;
 
   57         if (lefthand_sign ^ midpoint_sign)
 
   66       while (righthand - lefthand > threshold);
 
   68       max_peak_mz = (lefthand + righthand) / 2;
 
   69       max_peak_int = peak_spline.eval(max_peak_mz);
 
void spline_bisection(const T &peak_spline, double const left_neighbor_mz, double const right_neighbor_mz, double &max_peak_mz, double &max_peak_int, double const threshold=1e-6)
Definition: SplineBisection.h:28
 
Main OpenMS namespace.
Definition: FeatureDeconvolution.h:22