c0 \cdot \sqrt{\frac{A}{V \cdot \ell}}\left(c0 \cdot \left(\left|\frac{\sqrt[3]{A}}{\sqrt[3]{V}}\right| \cdot \sqrt{\frac{\frac{1}{\sqrt[3]{\ell}}}{\sqrt[3]{\ell}}}\right)\right) \cdot \sqrt{\frac{\frac{\sqrt[3]{A}}{\sqrt[3]{V}}}{\sqrt[3]{\ell}}}double f(double c0, double A, double V, double l) {
double r2428114 = c0;
double r2428115 = A;
double r2428116 = V;
double r2428117 = l;
double r2428118 = r2428116 * r2428117;
double r2428119 = r2428115 / r2428118;
double r2428120 = sqrt(r2428119);
double r2428121 = r2428114 * r2428120;
return r2428121;
}
double f(double c0, double A, double V, double l) {
double r2428122 = c0;
double r2428123 = A;
double r2428124 = cbrt(r2428123);
double r2428125 = V;
double r2428126 = cbrt(r2428125);
double r2428127 = r2428124 / r2428126;
double r2428128 = fabs(r2428127);
double r2428129 = 1.0;
double r2428130 = l;
double r2428131 = cbrt(r2428130);
double r2428132 = r2428129 / r2428131;
double r2428133 = r2428132 / r2428131;
double r2428134 = sqrt(r2428133);
double r2428135 = r2428128 * r2428134;
double r2428136 = r2428122 * r2428135;
double r2428137 = r2428127 / r2428131;
double r2428138 = sqrt(r2428137);
double r2428139 = r2428136 * r2428138;
return r2428139;
}



Bits error versus c0



Bits error versus A



Bits error versus V



Bits error versus l
Results
Initial program 18.9
rmApplied associate-/r*19.2
rmApplied add-cube-cbrt19.5
Applied add-cube-cbrt19.6
Applied add-cube-cbrt19.7
Applied times-frac19.7
Applied times-frac15.6
Applied sqrt-prod7.2
Applied associate-*r*7.2
Simplified7.2
rmApplied *-un-lft-identity7.2
Applied div-inv7.2
Applied times-frac7.2
Applied sqrt-prod3.4
Simplified3.4
rmApplied rem-sqrt-square1.1
Final simplification1.1
herbie shell --seed 2019128 +o rules:numerics
(FPCore (c0 A V l)
:name "Henrywood and Agarwal, Equation (3)"
(* c0 (sqrt (/ A (* V l)))))