\left(0.5 \cdot \sin re\right) \cdot \left(e^{-im} - e^{im}\right)0.5 \cdot \left(\sin re \cdot \left(\frac{-1}{3} \cdot {im}^{3}\right)\right) + \left(0.5 \cdot \sin re\right) \cdot \left(-\mathsf{fma}\left(\frac{1}{60}, {im}^{5}, 2 \cdot im\right)\right)double f(double re, double im) {
double r313889 = 0.5;
double r313890 = re;
double r313891 = sin(r313890);
double r313892 = r313889 * r313891;
double r313893 = im;
double r313894 = -r313893;
double r313895 = exp(r313894);
double r313896 = exp(r313893);
double r313897 = r313895 - r313896;
double r313898 = r313892 * r313897;
return r313898;
}
double f(double re, double im) {
double r313899 = 0.5;
double r313900 = re;
double r313901 = sin(r313900);
double r313902 = -0.3333333333333333;
double r313903 = im;
double r313904 = 3.0;
double r313905 = pow(r313903, r313904);
double r313906 = r313902 * r313905;
double r313907 = r313901 * r313906;
double r313908 = r313899 * r313907;
double r313909 = r313899 * r313901;
double r313910 = 0.016666666666666666;
double r313911 = 5.0;
double r313912 = pow(r313903, r313911);
double r313913 = 2.0;
double r313914 = r313913 * r313903;
double r313915 = fma(r313910, r313912, r313914);
double r313916 = -r313915;
double r313917 = r313909 * r313916;
double r313918 = r313908 + r313917;
return r313918;
}




Bits error versus re




Bits error versus im
| Original | 43.4 |
|---|---|
| Target | 0.3 |
| Herbie | 0.8 |
Initial program 43.4
Taylor expanded around 0 0.8
Simplified0.8
rmApplied sub-neg0.8
Applied distribute-lft-in0.8
Simplified0.8
Final simplification0.8
herbie shell --seed 2020062 +o rules:numerics
(FPCore (re im)
:name "math.cos on complex, imaginary part"
:precision binary64
:herbie-target
(if (< (fabs im) 1) (- (* (sin re) (+ (+ im (* (* (* 0.16666666666666666 im) im) im)) (* (* (* (* (* 0.008333333333333333 im) im) im) im) im)))) (* (* 0.5 (sin re)) (- (exp (- im)) (exp im))))
(* (* 0.5 (sin re)) (- (exp (- im)) (exp im))))