c0 \cdot \sqrt{\frac{A}{V \cdot \ell}}\sqrt{\frac{\frac{\sqrt[3]{A}}{\sqrt[3]{\sqrt[3]{V}} \cdot \left(\sqrt[3]{\sqrt[3]{V}} \cdot \sqrt[3]{\sqrt[3]{V}}\right)}}{\sqrt[3]{\ell}}} \cdot \left(\left|\frac{\sqrt[3]{A}}{\sqrt[3]{\ell} \cdot \sqrt[3]{V}}\right| \cdot c0\right)double f(double c0, double A, double V, double l) {
double r5857222 = c0;
double r5857223 = A;
double r5857224 = V;
double r5857225 = l;
double r5857226 = r5857224 * r5857225;
double r5857227 = r5857223 / r5857226;
double r5857228 = sqrt(r5857227);
double r5857229 = r5857222 * r5857228;
return r5857229;
}
double f(double c0, double A, double V, double l) {
double r5857230 = A;
double r5857231 = cbrt(r5857230);
double r5857232 = V;
double r5857233 = cbrt(r5857232);
double r5857234 = cbrt(r5857233);
double r5857235 = r5857234 * r5857234;
double r5857236 = r5857234 * r5857235;
double r5857237 = r5857231 / r5857236;
double r5857238 = l;
double r5857239 = cbrt(r5857238);
double r5857240 = r5857237 / r5857239;
double r5857241 = sqrt(r5857240);
double r5857242 = r5857239 * r5857233;
double r5857243 = r5857231 / r5857242;
double r5857244 = fabs(r5857243);
double r5857245 = c0;
double r5857246 = r5857244 * r5857245;
double r5857247 = r5857241 * r5857246;
return r5857247;
}



Bits error versus c0



Bits error versus A



Bits error versus V



Bits error versus l
Results
Initial program 19.2
rmApplied associate-/r*18.7
rmApplied add-cube-cbrt19.1
Applied add-cube-cbrt19.2
Applied add-cube-cbrt19.3
Applied times-frac19.3
Applied times-frac15.3
Applied sqrt-prod6.8
Applied associate-*r*6.8
Simplified1.1
rmApplied add-cube-cbrt1.3
Final simplification1.3
herbie shell --seed 2019168 +o rules:numerics
(FPCore (c0 A V l)
:name "Henrywood and Agarwal, Equation (3)"
(* c0 (sqrt (/ A (* V l)))))