x \cdot \log \left(\frac{x}{y}\right) - zx \cdot \left(2 \cdot \log \left(\frac{\left(\sqrt[3]{\sqrt[3]{x}} \cdot \sqrt[3]{\sqrt[3]{x}}\right) \cdot \sqrt[3]{\sqrt[3]{x}}}{\sqrt[3]{y}}\right) + \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}}\right)\right) - zdouble f(double x, double y, double z) {
double r384175 = x;
double r384176 = y;
double r384177 = r384175 / r384176;
double r384178 = log(r384177);
double r384179 = r384175 * r384178;
double r384180 = z;
double r384181 = r384179 - r384180;
return r384181;
}
double f(double x, double y, double z) {
double r384182 = x;
double r384183 = 2.0;
double r384184 = cbrt(r384182);
double r384185 = cbrt(r384184);
double r384186 = r384185 * r384185;
double r384187 = r384186 * r384185;
double r384188 = y;
double r384189 = cbrt(r384188);
double r384190 = r384187 / r384189;
double r384191 = log(r384190);
double r384192 = r384183 * r384191;
double r384193 = r384184 / r384189;
double r384194 = log(r384193);
double r384195 = r384192 + r384194;
double r384196 = r384182 * r384195;
double r384197 = z;
double r384198 = r384196 - r384197;
return r384198;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 15.6 |
|---|---|
| Target | 8.0 |
| Herbie | 0.2 |
Initial program 15.6
rmApplied add-cube-cbrt15.6
Applied add-cube-cbrt15.6
Applied times-frac15.6
Applied log-prod3.8
Simplified0.2
rmApplied add-cube-cbrt0.2
Final simplification0.2
herbie shell --seed 2020100 +o rules:numerics
(FPCore (x y z)
:name "Numeric.SpecFunctions.Extra:bd0 from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(if (< y 7.595077799083773e-308) (- (* x (log (/ x y))) z) (- (* x (- (log x) (log y))) z))
(- (* x (log (/ x y))) z))