\left(0.5 \cdot \cos re\right) \cdot \left(e^{0.0 - im} - e^{im}\right)\left(\cos re \cdot \left({im}^{5} \cdot \frac{-1}{60} - \left(2 - \left(im \cdot \frac{-1}{3}\right) \cdot im\right) \cdot im\right)\right) \cdot 0.5double f(double re, double im) {
double r9995985 = 0.5;
double r9995986 = re;
double r9995987 = cos(r9995986);
double r9995988 = r9995985 * r9995987;
double r9995989 = 0.0;
double r9995990 = im;
double r9995991 = r9995989 - r9995990;
double r9995992 = exp(r9995991);
double r9995993 = exp(r9995990);
double r9995994 = r9995992 - r9995993;
double r9995995 = r9995988 * r9995994;
return r9995995;
}
double f(double re, double im) {
double r9995996 = re;
double r9995997 = cos(r9995996);
double r9995998 = im;
double r9995999 = 5.0;
double r9996000 = pow(r9995998, r9995999);
double r9996001 = -0.016666666666666666;
double r9996002 = r9996000 * r9996001;
double r9996003 = 2.0;
double r9996004 = -0.3333333333333333;
double r9996005 = r9995998 * r9996004;
double r9996006 = r9996005 * r9995998;
double r9996007 = r9996003 - r9996006;
double r9996008 = r9996007 * r9995998;
double r9996009 = r9996002 - r9996008;
double r9996010 = r9995997 * r9996009;
double r9996011 = 0.5;
double r9996012 = r9996010 * r9996011;
return r9996012;
}




Bits error versus re




Bits error versus im
Results
| Original | 58.3 |
|---|---|
| Target | 0.3 |
| Herbie | 0.7 |
Initial program 58.3
Taylor expanded around 0 0.6
Simplified0.6
rmApplied associate-*l*0.6
Simplified0.7
Final simplification0.7
herbie shell --seed 2019172
(FPCore (re im)
:name "math.sin on complex, imaginary part"
:herbie-target
(if (< (fabs im) 1.0) (- (* (cos re) (+ (+ im (* (* (* 0.16666666666666666 im) im) im)) (* (* (* (* (* 0.008333333333333333 im) im) im) im) im)))) (* (* 0.5 (cos re)) (- (exp (- 0.0 im)) (exp im))))
(* (* 0.5 (cos re)) (- (exp (- 0.0 im)) (exp im))))