x \cdot 0.5 + y \cdot \left(\left(1 - z\right) + \log z\right)
x \cdot 0.5 + y \cdot \left(\left(\left(2 \cdot \log \left(\sqrt[3]{z}\right) + 1\right) - z\right) + \log \left(\sqrt[3]{z}\right)\right)double f(double x, double y, double z) {
double r289310 = x;
double r289311 = 0.5;
double r289312 = r289310 * r289311;
double r289313 = y;
double r289314 = 1.0;
double r289315 = z;
double r289316 = r289314 - r289315;
double r289317 = log(r289315);
double r289318 = r289316 + r289317;
double r289319 = r289313 * r289318;
double r289320 = r289312 + r289319;
return r289320;
}
double f(double x, double y, double z) {
double r289321 = x;
double r289322 = 0.5;
double r289323 = r289321 * r289322;
double r289324 = y;
double r289325 = 2.0;
double r289326 = z;
double r289327 = cbrt(r289326);
double r289328 = log(r289327);
double r289329 = r289325 * r289328;
double r289330 = 1.0;
double r289331 = r289329 + r289330;
double r289332 = r289331 - r289326;
double r289333 = r289332 + r289328;
double r289334 = r289324 * r289333;
double r289335 = r289323 + r289334;
return r289335;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 0.1 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 0.1
rmApplied add-cube-cbrt0.1
Applied log-prod0.1
Applied associate-+r+0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019303
(FPCore (x y z)
:name "System.Random.MWC.Distributions:gamma from mwc-random-0.13.3.2"
:precision binary64
:herbie-target
(- (+ y (* 0.5 x)) (* y (- z (log z))))
(+ (* x 0.5) (* y (+ (- 1 z) (log z)))))