\left(0.5 \cdot \sin re\right) \cdot \left(e^{-im} - e^{im}\right)-\left(\left(\left(\left(im \cdot \left(im \cdot im\right)\right) \cdot \left(im \cdot im\right)\right) \cdot 0.008333333333333333 + im \cdot 1.0\right) \cdot \sin re + \sin re \cdot \left(\left(im \cdot \left(im \cdot im\right)\right) \cdot 0.16666666666666666\right)\right)
double f(double re, double im) {
double r4933875 = 0.5;
double r4933876 = re;
double r4933877 = sin(r4933876);
double r4933878 = r4933875 * r4933877;
double r4933879 = im;
double r4933880 = -r4933879;
double r4933881 = exp(r4933880);
double r4933882 = exp(r4933879);
double r4933883 = r4933881 - r4933882;
double r4933884 = r4933878 * r4933883;
return r4933884;
}
double f(double re, double im) {
double r4933885 = im;
double r4933886 = r4933885 * r4933885;
double r4933887 = r4933885 * r4933886;
double r4933888 = r4933887 * r4933886;
double r4933889 = 0.008333333333333333;
double r4933890 = r4933888 * r4933889;
double r4933891 = 1.0;
double r4933892 = r4933885 * r4933891;
double r4933893 = r4933890 + r4933892;
double r4933894 = re;
double r4933895 = sin(r4933894);
double r4933896 = r4933893 * r4933895;
double r4933897 = 0.16666666666666666;
double r4933898 = r4933887 * r4933897;
double r4933899 = r4933895 * r4933898;
double r4933900 = r4933896 + r4933899;
double r4933901 = -r4933900;
return r4933901;
}




Bits error versus re




Bits error versus im
Results
| Original | 43.3 |
|---|---|
| Target | 0.3 |
| Herbie | 0.7 |
Initial program 43.3
Taylor expanded around 0 0.7
Simplified0.7
Taylor expanded around inf 0.7
Simplified0.7
Final simplification0.7
herbie shell --seed 2019146
(FPCore (re im)
:name "math.cos on complex, imaginary part"
:herbie-target
(if (< (fabs im) 1) (- (* (sin re) (+ (+ im (* (* (* 1/6 im) im) im)) (* (* (* (* (* 1/120 im) im) im) im) im)))) (* (* 0.5 (sin re)) (- (exp (- im)) (exp im))))
(* (* 0.5 (sin re)) (- (exp (- im)) (exp im))))