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} \le -1.772435279212265745841411522771178725987 \cdot 10^{308}:\\
\;\;\;\;\sqrt{1} \cdot w0\\
\mathbf{elif}\;\frac{h}{\ell} \le -9.283098232840349567842386362959585009642 \cdot 10^{-319}:\\
\;\;\;\;\sqrt{1 - {\left(\frac{M \cdot D}{d \cdot 2}\right)}^{\left(\frac{2}{2}\right)} \cdot \left(\frac{h}{\ell} \cdot {\left(\frac{M \cdot D}{d \cdot 2}\right)}^{\left(\frac{2}{2}\right)}\right)} \cdot w0\\
\mathbf{else}:\\
\;\;\;\;\sqrt{1} \cdot w0\\
\end{array}double f(double w0, double M, double D, double h, double l, double d) {
double r7663082 = w0;
double r7663083 = 1.0;
double r7663084 = M;
double r7663085 = D;
double r7663086 = r7663084 * r7663085;
double r7663087 = 2.0;
double r7663088 = d;
double r7663089 = r7663087 * r7663088;
double r7663090 = r7663086 / r7663089;
double r7663091 = pow(r7663090, r7663087);
double r7663092 = h;
double r7663093 = l;
double r7663094 = r7663092 / r7663093;
double r7663095 = r7663091 * r7663094;
double r7663096 = r7663083 - r7663095;
double r7663097 = sqrt(r7663096);
double r7663098 = r7663082 * r7663097;
return r7663098;
}
double f(double w0, double M, double D, double h, double l, double d) {
double r7663099 = h;
double r7663100 = l;
double r7663101 = r7663099 / r7663100;
double r7663102 = -1.7724352792122657e+308;
bool r7663103 = r7663101 <= r7663102;
double r7663104 = 1.0;
double r7663105 = sqrt(r7663104);
double r7663106 = w0;
double r7663107 = r7663105 * r7663106;
double r7663108 = -9.2830982328403e-319;
bool r7663109 = r7663101 <= r7663108;
double r7663110 = M;
double r7663111 = D;
double r7663112 = r7663110 * r7663111;
double r7663113 = d;
double r7663114 = 2.0;
double r7663115 = r7663113 * r7663114;
double r7663116 = r7663112 / r7663115;
double r7663117 = 2.0;
double r7663118 = r7663114 / r7663117;
double r7663119 = pow(r7663116, r7663118);
double r7663120 = r7663101 * r7663119;
double r7663121 = r7663119 * r7663120;
double r7663122 = r7663104 - r7663121;
double r7663123 = sqrt(r7663122);
double r7663124 = r7663123 * r7663106;
double r7663125 = r7663109 ? r7663124 : r7663107;
double r7663126 = r7663103 ? r7663107 : r7663125;
return r7663126;
}



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) < -1.7724352792122657e+308 or -9.2830982328403e-319 < (/ h l) Initial program 13.7
Taylor expanded around 0 6.1
if -1.7724352792122657e+308 < (/ h l) < -9.2830982328403e-319Initial program 14.6
rmApplied sqr-pow14.6
Applied associate-*l*12.4
Final simplification9.0
herbie shell --seed 2019179
(FPCore (w0 M D h l d)
:name "Henrywood and Agarwal, Equation (9a)"
(* w0 (sqrt (- 1.0 (* (pow (/ (* M D) (* 2.0 d)) 2.0) (/ h l))))))