x \cdot \log \left(\frac{x}{y}\right) - z\left(x \cdot \left(2 \cdot \log \left(\frac{\sqrt[3]{\sqrt[3]{x} \cdot \sqrt[3]{x}} \cdot \sqrt[3]{\sqrt[3]{x}}}{\sqrt[3]{y}}\right)\right) + x \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}}\right)\right) - zdouble f(double x, double y, double z) {
double r575477 = x;
double r575478 = y;
double r575479 = r575477 / r575478;
double r575480 = log(r575479);
double r575481 = r575477 * r575480;
double r575482 = z;
double r575483 = r575481 - r575482;
return r575483;
}
double f(double x, double y, double z) {
double r575484 = x;
double r575485 = 2.0;
double r575486 = cbrt(r575484);
double r575487 = r575486 * r575486;
double r575488 = cbrt(r575487);
double r575489 = cbrt(r575486);
double r575490 = r575488 * r575489;
double r575491 = y;
double r575492 = cbrt(r575491);
double r575493 = r575490 / r575492;
double r575494 = log(r575493);
double r575495 = r575485 * r575494;
double r575496 = r575484 * r575495;
double r575497 = r575486 / r575492;
double r575498 = log(r575497);
double r575499 = r575484 * r575498;
double r575500 = r575496 + r575499;
double r575501 = z;
double r575502 = r575500 - r575501;
return r575502;
}




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
rmApplied add-cube-cbrt0.2
Applied cbrt-prod0.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))