\left(x \cdot \log y + z \cdot \log \left(1 - y\right)\right) - t
\left(\left(x \cdot \left(2 \cdot \log \left(\sqrt[3]{y}\right)\right) + x \cdot \log \left({y}^{\frac{1}{3}}\right)\right) + z \cdot \left(\log 1 - \left(1 \cdot y + \frac{1}{2} \cdot \frac{{y}^{2}}{{1}^{2}}\right)\right)\right) - tdouble f(double x, double y, double z, double t) {
double r463437 = x;
double r463438 = y;
double r463439 = log(r463438);
double r463440 = r463437 * r463439;
double r463441 = z;
double r463442 = 1.0;
double r463443 = r463442 - r463438;
double r463444 = log(r463443);
double r463445 = r463441 * r463444;
double r463446 = r463440 + r463445;
double r463447 = t;
double r463448 = r463446 - r463447;
return r463448;
}
double f(double x, double y, double z, double t) {
double r463449 = x;
double r463450 = 2.0;
double r463451 = y;
double r463452 = cbrt(r463451);
double r463453 = log(r463452);
double r463454 = r463450 * r463453;
double r463455 = r463449 * r463454;
double r463456 = 0.3333333333333333;
double r463457 = pow(r463451, r463456);
double r463458 = log(r463457);
double r463459 = r463449 * r463458;
double r463460 = r463455 + r463459;
double r463461 = z;
double r463462 = 1.0;
double r463463 = log(r463462);
double r463464 = r463462 * r463451;
double r463465 = 0.5;
double r463466 = pow(r463451, r463450);
double r463467 = pow(r463462, r463450);
double r463468 = r463466 / r463467;
double r463469 = r463465 * r463468;
double r463470 = r463464 + r463469;
double r463471 = r463463 - r463470;
double r463472 = r463461 * r463471;
double r463473 = r463460 + r463472;
double r463474 = t;
double r463475 = r463473 - r463474;
return r463475;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 9.7 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
Initial program 9.7
Taylor expanded around 0 0.3
rmApplied add-cube-cbrt0.3
Applied log-prod0.3
Applied distribute-lft-in0.3
Simplified0.3
rmApplied pow1/30.3
Final simplification0.3
herbie shell --seed 2020064
(FPCore (x y z t)
:name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2, B"
:precision binary64
:herbie-target
(- (* (- z) (+ (+ (* 0.5 (* y y)) y) (* (/ 0.3333333333333333 (* 1 (* 1 1))) (* y (* y y))))) (- t (* x (log y))))
(- (+ (* x (log y)) (* z (log (- 1 y)))) t))