\frac{c0}{2 \cdot w} \cdot \left(\frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)} + \sqrt{\frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)} \cdot \frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)} - M \cdot M}\right)\begin{array}{l}
\mathbf{if}\;\frac{c0}{2 \cdot w} \cdot \left(\frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)} + \sqrt{\frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)} \cdot \frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)} - M \cdot M}\right) \le 1.996806307158958 \cdot 10^{263}:\\
\;\;\;\;\frac{c0}{2 \cdot w} \cdot \left(\frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)} + \sqrt{\frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)} \cdot \frac{c0 \cdot \left(d \cdot d\right)}{\left(w \cdot h\right) \cdot \left(D \cdot D\right)} - M \cdot M}\right)\\
\mathbf{else}:\\
\;\;\;\;c0 \cdot 0\\
\end{array}double f(double c0, double w, double h, double D, double d, double M) {
double r121327 = c0;
double r121328 = 2.0;
double r121329 = w;
double r121330 = r121328 * r121329;
double r121331 = r121327 / r121330;
double r121332 = d;
double r121333 = r121332 * r121332;
double r121334 = r121327 * r121333;
double r121335 = h;
double r121336 = r121329 * r121335;
double r121337 = D;
double r121338 = r121337 * r121337;
double r121339 = r121336 * r121338;
double r121340 = r121334 / r121339;
double r121341 = r121340 * r121340;
double r121342 = M;
double r121343 = r121342 * r121342;
double r121344 = r121341 - r121343;
double r121345 = sqrt(r121344);
double r121346 = r121340 + r121345;
double r121347 = r121331 * r121346;
return r121347;
}
double f(double c0, double w, double h, double D, double d, double M) {
double r121348 = c0;
double r121349 = 2.0;
double r121350 = w;
double r121351 = r121349 * r121350;
double r121352 = r121348 / r121351;
double r121353 = d;
double r121354 = r121353 * r121353;
double r121355 = r121348 * r121354;
double r121356 = h;
double r121357 = r121350 * r121356;
double r121358 = D;
double r121359 = r121358 * r121358;
double r121360 = r121357 * r121359;
double r121361 = r121355 / r121360;
double r121362 = r121361 * r121361;
double r121363 = M;
double r121364 = r121363 * r121363;
double r121365 = r121362 - r121364;
double r121366 = sqrt(r121365);
double r121367 = r121361 + r121366;
double r121368 = r121352 * r121367;
double r121369 = 1.996806307158958e+263;
bool r121370 = r121368 <= r121369;
double r121371 = 0.0;
double r121372 = r121348 * r121371;
double r121373 = r121370 ? r121368 : r121372;
return r121373;
}



Bits error versus c0



Bits error versus w



Bits error versus h



Bits error versus D



Bits error versus d



Bits error versus M
Results
if (* (/ c0 (* 2.0 w)) (+ (/ (* c0 (* d d)) (* (* w h) (* D D))) (sqrt (- (* (/ (* c0 (* d d)) (* (* w h) (* D D))) (/ (* c0 (* d d)) (* (* w h) (* D D)))) (* M M))))) < 1.996806307158958e+263Initial program 34.7
if 1.996806307158958e+263 < (* (/ c0 (* 2.0 w)) (+ (/ (* c0 (* d d)) (* (* w h) (* D D))) (sqrt (- (* (/ (* c0 (* d d)) (* (* w h) (* D D))) (/ (* c0 (* d d)) (* (* w h) (* D D)))) (* M M))))) Initial program 63.9
Taylor expanded around inf 33.9
rmApplied div-inv33.9
Applied associate-*l*31.6
Simplified31.6
Final simplification32.1
herbie shell --seed 2020062
(FPCore (c0 w h D d M)
:name "Henrywood and Agarwal, Equation (13)"
:precision binary64
(* (/ c0 (* 2 w)) (+ (/ (* c0 (* d d)) (* (* w h) (* D D))) (sqrt (- (* (/ (* c0 (* d d)) (* (* w h) (* D D))) (/ (* c0 (* d d)) (* (* w h) (* D D)))) (* M M))))))