w0 \cdot \sqrt{1 - {\left(\frac{M \cdot D}{2 \cdot d}\right)}^{2} \cdot \frac{h}{\ell}}\begin{array}{l}
\mathbf{if}\;\frac{h}{\ell} = -\infty \lor \neg \left(\frac{h}{\ell} \le -1.137897252452376107719566610395472751847 \cdot 10^{-223}\right):\\
\;\;\;\;w0 \cdot \sqrt{1 - \left({\left(\frac{M \cdot D}{2 \cdot d}\right)}^{\left(\frac{2}{2}\right)} \cdot \left({\left(\left(M \cdot D\right) \cdot \frac{1}{2 \cdot d}\right)}^{\left(\frac{2}{2}\right)} \cdot h\right)\right) \cdot \frac{1}{\ell}}\\
\mathbf{else}:\\
\;\;\;\;w0 \cdot \sqrt{1 - {\left(\frac{M \cdot D}{2 \cdot d}\right)}^{\left(\frac{2}{2}\right)} \cdot \left({\left(\frac{M \cdot D}{2 \cdot d}\right)}^{\left(\frac{2}{2}\right)} \cdot \frac{h}{\ell}\right)}\\
\end{array}double f(double w0, double M, double D, double h, double l, double d) {
double r130496 = w0;
double r130497 = 1.0;
double r130498 = M;
double r130499 = D;
double r130500 = r130498 * r130499;
double r130501 = 2.0;
double r130502 = d;
double r130503 = r130501 * r130502;
double r130504 = r130500 / r130503;
double r130505 = pow(r130504, r130501);
double r130506 = h;
double r130507 = l;
double r130508 = r130506 / r130507;
double r130509 = r130505 * r130508;
double r130510 = r130497 - r130509;
double r130511 = sqrt(r130510);
double r130512 = r130496 * r130511;
return r130512;
}
double f(double w0, double M, double D, double h, double l, double d) {
double r130513 = h;
double r130514 = l;
double r130515 = r130513 / r130514;
double r130516 = -inf.0;
bool r130517 = r130515 <= r130516;
double r130518 = -1.1378972524523761e-223;
bool r130519 = r130515 <= r130518;
double r130520 = !r130519;
bool r130521 = r130517 || r130520;
double r130522 = w0;
double r130523 = 1.0;
double r130524 = M;
double r130525 = D;
double r130526 = r130524 * r130525;
double r130527 = 2.0;
double r130528 = d;
double r130529 = r130527 * r130528;
double r130530 = r130526 / r130529;
double r130531 = 2.0;
double r130532 = r130527 / r130531;
double r130533 = pow(r130530, r130532);
double r130534 = 1.0;
double r130535 = r130534 / r130529;
double r130536 = r130526 * r130535;
double r130537 = pow(r130536, r130532);
double r130538 = r130537 * r130513;
double r130539 = r130533 * r130538;
double r130540 = r130534 / r130514;
double r130541 = r130539 * r130540;
double r130542 = r130523 - r130541;
double r130543 = sqrt(r130542);
double r130544 = r130522 * r130543;
double r130545 = r130533 * r130515;
double r130546 = r130533 * r130545;
double r130547 = r130523 - r130546;
double r130548 = sqrt(r130547);
double r130549 = r130522 * r130548;
double r130550 = r130521 ? r130544 : r130549;
return r130550;
}



Bits error versus w0



Bits error versus M



Bits error versus D



Bits error versus h



Bits error versus l



Bits error versus d
Results
if (/ h l) < -inf.0 or -1.1378972524523761e-223 < (/ h l) Initial program 13.9
rmApplied div-inv13.9
Applied associate-*r*7.5
rmApplied sqr-pow7.5
Applied associate-*l*5.4
rmApplied div-inv5.4
if -inf.0 < (/ h l) < -1.1378972524523761e-223Initial program 14.4
rmApplied sqr-pow14.4
Applied associate-*l*13.0
Final simplification8.6
herbie shell --seed 2019326
(FPCore (w0 M D h l d)
:name "Henrywood and Agarwal, Equation (9a)"
:precision binary64
(* w0 (sqrt (- 1 (* (pow (/ (* M D) (* 2 d)) 2) (/ h l))))))