x \cdot \log \left(\frac{x}{y}\right) - z\left(\left(2 \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}}\right)\right) \cdot x + \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) \cdot x\right) - zdouble f(double x, double y, double z) {
double r534471 = x;
double r534472 = y;
double r534473 = r534471 / r534472;
double r534474 = log(r534473);
double r534475 = r534471 * r534474;
double r534476 = z;
double r534477 = r534475 - r534476;
return r534477;
}
double f(double x, double y, double z) {
double r534478 = 2.0;
double r534479 = x;
double r534480 = cbrt(r534479);
double r534481 = y;
double r534482 = cbrt(r534481);
double r534483 = r534480 / r534482;
double r534484 = log(r534483);
double r534485 = r534478 * r534484;
double r534486 = r534485 * r534479;
double r534487 = cbrt(r534480);
double r534488 = r534487 * r534487;
double r534489 = r534488 * r534487;
double r534490 = r534489 / r534482;
double r534491 = log(r534490);
double r534492 = r534491 * r534479;
double r534493 = r534486 + r534492;
double r534494 = z;
double r534495 = r534493 - r534494;
return r534495;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 15.0 |
|---|---|
| Target | 8.0 |
| Herbie | 0.2 |
Initial program 15.0
rmApplied add-cube-cbrt15.0
Applied add-cube-cbrt15.0
Applied times-frac15.0
Applied log-prod3.5
Applied distribute-lft-in3.5
Simplified0.2
Simplified0.2
rmApplied add-cube-cbrt0.2
Final simplification0.2
herbie shell --seed 2020047
(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))