\left(0.5 \cdot \sin re\right) \cdot \left(e^{-im} - e^{im}\right)\left(\left(\left(im \cdot im\right) \cdot im\right) \cdot \sin re\right) \cdot \left(-0.16666666666666666\right) - \left({im}^{5} \cdot \left(0.008333333333333333 \cdot \sin re\right) + \left(1.0 \cdot \sin re\right) \cdot im\right)double f(double re, double im) {
double r4885391 = 0.5;
double r4885392 = re;
double r4885393 = sin(r4885392);
double r4885394 = r4885391 * r4885393;
double r4885395 = im;
double r4885396 = -r4885395;
double r4885397 = exp(r4885396);
double r4885398 = exp(r4885395);
double r4885399 = r4885397 - r4885398;
double r4885400 = r4885394 * r4885399;
return r4885400;
}
double f(double re, double im) {
double r4885401 = im;
double r4885402 = r4885401 * r4885401;
double r4885403 = r4885402 * r4885401;
double r4885404 = re;
double r4885405 = sin(r4885404);
double r4885406 = r4885403 * r4885405;
double r4885407 = 0.16666666666666666;
double r4885408 = -r4885407;
double r4885409 = r4885406 * r4885408;
double r4885410 = 5.0;
double r4885411 = pow(r4885401, r4885410);
double r4885412 = 0.008333333333333333;
double r4885413 = r4885412 * r4885405;
double r4885414 = r4885411 * r4885413;
double r4885415 = 1.0;
double r4885416 = r4885415 * r4885405;
double r4885417 = r4885416 * r4885401;
double r4885418 = r4885414 + r4885417;
double r4885419 = r4885409 - r4885418;
return r4885419;
}




Bits error versus re




Bits error versus im
Results
| Original | 43.7 |
|---|---|
| Target | 0.3 |
| Herbie | 0.8 |
Initial program 43.7
Taylor expanded around 0 0.8
Simplified0.8
Taylor expanded around inf 0.8
Simplified0.8
Final simplification0.8
herbie shell --seed 2019153
(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))))