double f(double c0, double w, double h, double D, double d, double M) {
double r28201136 = c0;
double r28201137 = 2.0;
double r28201138 = w;
double r28201139 = r28201137 * r28201138;
double r28201140 = r28201136 / r28201139;
double r28201141 = d;
double r28201142 = r28201141 * r28201141;
double r28201143 = r28201136 * r28201142;
double r28201144 = h;
double r28201145 = r28201138 * r28201144;
double r28201146 = D;
double r28201147 = r28201146 * r28201146;
double r28201148 = r28201145 * r28201147;
double r28201149 = r28201143 / r28201148;
double r28201150 = r28201149 * r28201149;
double r28201151 = M;
double r28201152 = r28201151 * r28201151;
double r28201153 = r28201150 - r28201152;
double r28201154 = sqrt(r28201153);
double r28201155 = r28201149 + r28201154;
double r28201156 = r28201140 * r28201155;
return r28201156;
}
double f(double c0, double w, double h, double D, double d, double M) {
double r28201157 = c0;
double r28201158 = w;
double r28201159 = 2.0;
double r28201160 = r28201158 * r28201159;
double r28201161 = r28201157 / r28201160;
double r28201162 = d;
double r28201163 = r28201162 * r28201162;
double r28201164 = r28201157 * r28201163;
double r28201165 = D;
double r28201166 = r28201165 * r28201165;
double r28201167 = h;
double r28201168 = r28201158 * r28201167;
double r28201169 = r28201166 * r28201168;
double r28201170 = r28201164 / r28201169;
double r28201171 = r28201170 * r28201170;
double r28201172 = M;
double r28201173 = r28201172 * r28201172;
double r28201174 = r28201171 - r28201173;
double r28201175 = sqrt(r28201174);
double r28201176 = r28201175 + r28201170;
double r28201177 = r28201161 * r28201176;
double r28201178 = 4.761158986801599e+252;
bool r28201179 = r28201177 <= r28201178;
double r28201180 = 0.0;
double r28201181 = r28201179 ? r28201177 : r28201180;
return r28201181;
}
\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}{w \cdot 2} \cdot \left(\sqrt{\frac{c0 \cdot \left(d \cdot d\right)}{\left(D \cdot D\right) \cdot \left(w \cdot h\right)} \cdot \frac{c0 \cdot \left(d \cdot d\right)}{\left(D \cdot D\right) \cdot \left(w \cdot h\right)} - M \cdot M} + \frac{c0 \cdot \left(d \cdot d\right)}{\left(D \cdot D\right) \cdot \left(w \cdot h\right)}\right) \le 4.761158986801599 \cdot 10^{+252}:\\
\;\;\;\;\frac{c0}{w \cdot 2} \cdot \left(\sqrt{\frac{c0 \cdot \left(d \cdot d\right)}{\left(D \cdot D\right) \cdot \left(w \cdot h\right)} \cdot \frac{c0 \cdot \left(d \cdot d\right)}{\left(D \cdot D\right) \cdot \left(w \cdot h\right)} - M \cdot M} + \frac{c0 \cdot \left(d \cdot d\right)}{\left(D \cdot D\right) \cdot \left(w \cdot h\right)}\right)\\
\mathbf{else}:\\
\;\;\;\;0\\
\end{array}


Bits error versus c0



Bits error versus w



Bits error versus h



Bits error versus D



Bits error versus d



Bits error versus M
if (* (/ 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))))) < 4.761158986801599e+252Initial program 35.1
if 4.761158986801599e+252 < (* (/ 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))))) Initial program 62.6
Simplified56.0
Taylor expanded around -inf 33.7
rmApplied mul031.4
Final simplification32.0
herbie shell --seed 2019101 +o rules:numerics
(FPCore (c0 w h D d M)
:name "Henrywood and Agarwal, Equation (13)"
(* (/ 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))))))