37 #include <OpenMS/config.h> 
   55         double const left_neighbor_mz,
 
   56         double const right_neighbor_mz,
 
   58         double & max_peak_int,
 
   59         double const threshold = 1e-6)
 
   63       double lefthand = left_neighbor_mz;
 
   64       double righthand = right_neighbor_mz;
 
   66       bool lefthand_sign = 1;
 
   67       double eps = std::numeric_limits<double>::epsilon();
 
   72         double mid = (lefthand + righthand) / 2.0;
 
   73         double midpoint_deriv_val = peak_spline.derivatives(mid, 1);
 
   76         if (!(std::fabs(midpoint_deriv_val) > eps))
 
   81         bool midpoint_sign = (midpoint_deriv_val < 0.0) ? 0 : 1;
 
   83         if (lefthand_sign ^ midpoint_sign)
 
   92       while (righthand - lefthand > threshold);
 
   94       max_peak_mz = (lefthand + righthand) / 2;
 
   95       max_peak_int = peak_spline.eval(max_peak_mz);