\left(x \cdot \log y + z \cdot \log \left(1 - y\right)\right) - t
\left(\left(\log y \cdot \left(x \cdot \frac{2}{3}\right) + \left(3 \cdot \left(x \cdot \log \left(\sqrt[3]{\sqrt[3]{y}}\right)\right) + z \cdot \left(\log 1 - y \cdot 1\right)\right)\right) - \frac{1}{2} \cdot \frac{z \cdot {y}^{2}}{{1}^{2}}\right) - tdouble f(double x, double y, double z, double t) {
double r305301 = x;
double r305302 = y;
double r305303 = log(r305302);
double r305304 = r305301 * r305303;
double r305305 = z;
double r305306 = 1.0;
double r305307 = r305306 - r305302;
double r305308 = log(r305307);
double r305309 = r305305 * r305308;
double r305310 = r305304 + r305309;
double r305311 = t;
double r305312 = r305310 - r305311;
return r305312;
}
double f(double x, double y, double z, double t) {
double r305313 = y;
double r305314 = log(r305313);
double r305315 = x;
double r305316 = 0.6666666666666666;
double r305317 = r305315 * r305316;
double r305318 = r305314 * r305317;
double r305319 = 3.0;
double r305320 = cbrt(r305313);
double r305321 = cbrt(r305320);
double r305322 = log(r305321);
double r305323 = r305315 * r305322;
double r305324 = r305319 * r305323;
double r305325 = z;
double r305326 = 1.0;
double r305327 = log(r305326);
double r305328 = r305313 * r305326;
double r305329 = r305327 - r305328;
double r305330 = r305325 * r305329;
double r305331 = r305324 + r305330;
double r305332 = r305318 + r305331;
double r305333 = 0.5;
double r305334 = 2.0;
double r305335 = pow(r305313, r305334);
double r305336 = r305325 * r305335;
double r305337 = pow(r305326, r305334);
double r305338 = r305336 / r305337;
double r305339 = r305333 * r305338;
double r305340 = r305332 - r305339;
double r305341 = t;
double r305342 = r305340 - r305341;
return r305342;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 9.2 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
Initial program 9.2
Taylor expanded around 0 0.3
rmApplied add-cube-cbrt0.3
Applied log-prod0.3
Applied distribute-lft-in0.3
Simplified0.3
rmApplied add-cube-cbrt0.3
Applied log-prod0.3
Applied distribute-lft-in0.3
Applied associate-+r+0.3
Simplified0.3
Final simplification0.3
herbie shell --seed 2019308
(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.333333333333333315 (* 1 (* 1 1))) (* y (* y y))))) (- t (* x (log y))))
(- (+ (* x (log y)) (* z (log (- 1 y)))) t))