x \cdot 0.5 + y \cdot \left(\left(1 - z\right) + \log z\right)
x \cdot 0.5 + \left(y \cdot \left(\left(1 - z\right) + \log \left(\sqrt{z}\right)\right) + y \cdot \log \left(\sqrt{z}\right)\right)double f(double x, double y, double z) {
double r301987 = x;
double r301988 = 0.5;
double r301989 = r301987 * r301988;
double r301990 = y;
double r301991 = 1.0;
double r301992 = z;
double r301993 = r301991 - r301992;
double r301994 = log(r301992);
double r301995 = r301993 + r301994;
double r301996 = r301990 * r301995;
double r301997 = r301989 + r301996;
return r301997;
}
double f(double x, double y, double z) {
double r301998 = x;
double r301999 = 0.5;
double r302000 = r301998 * r301999;
double r302001 = y;
double r302002 = 1.0;
double r302003 = z;
double r302004 = r302002 - r302003;
double r302005 = sqrt(r302003);
double r302006 = log(r302005);
double r302007 = r302004 + r302006;
double r302008 = r302001 * r302007;
double r302009 = r302001 * r302006;
double r302010 = r302008 + r302009;
double r302011 = r302000 + r302010;
return r302011;
}




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 distribute-lft-in0.1
rmApplied add-sqr-sqrt0.1
Applied log-prod0.1
Applied distribute-lft-in0.1
Applied associate-+r+0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2020003
(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)))))