c0 \cdot \sqrt{\frac{A}{V \cdot \ell}}\left(\left|\frac{\frac{\sqrt[3]{A}}{\sqrt[3]{V}}}{\sqrt[3]{\ell}}\right| \cdot c0\right) \cdot \sqrt{\frac{\frac{\sqrt[3]{A}}{1 \cdot \sqrt[3]{V}}}{\sqrt[3]{\ell}}}double f(double c0, double A, double V, double l) {
double r129049 = c0;
double r129050 = A;
double r129051 = V;
double r129052 = l;
double r129053 = r129051 * r129052;
double r129054 = r129050 / r129053;
double r129055 = sqrt(r129054);
double r129056 = r129049 * r129055;
return r129056;
}
double f(double c0, double A, double V, double l) {
double r129057 = A;
double r129058 = cbrt(r129057);
double r129059 = V;
double r129060 = cbrt(r129059);
double r129061 = r129058 / r129060;
double r129062 = l;
double r129063 = cbrt(r129062);
double r129064 = r129061 / r129063;
double r129065 = fabs(r129064);
double r129066 = c0;
double r129067 = r129065 * r129066;
double r129068 = 1.0;
double r129069 = r129068 * r129060;
double r129070 = r129058 / r129069;
double r129071 = r129070 / r129063;
double r129072 = sqrt(r129071);
double r129073 = r129067 * r129072;
return r129073;
}



Bits error versus c0



Bits error versus A



Bits error versus V



Bits error versus l
Results
Initial program 19.5
rmApplied associate-/r*19.9
rmApplied add-cube-cbrt20.2
Applied add-cube-cbrt20.4
Applied add-cube-cbrt20.5
Applied times-frac20.5
Applied times-frac16.0
Applied sqrt-prod7.3
Applied associate-*r*7.3
Simplified1.2
rmApplied *-un-lft-identity1.2
Final simplification1.2
herbie shell --seed 2019347 +o rules:numerics
(FPCore (c0 A V l)
:name "Henrywood and Agarwal, Equation (3)"
:precision binary64
(* c0 (sqrt (/ A (* V l)))))