\left(0.5 \cdot \cos re\right) \cdot \left(e^{-im} + e^{im}\right)
\left(0.5 \cdot \cos re\right) \cdot 2
(FPCore (re im) :precision binary64 (* (* 0.5 (cos re)) (+ (exp (- im)) (exp im))))
(FPCore (re im) :precision binary64 (* (* 0.5 (cos re)) 2.0))
double code(double re, double im) {
return (0.5 * cos(re)) * (exp(-im) + exp(im));
}
double code(double re, double im) {
return (0.5 * cos(re)) * 2.0;
}



Bits error versus re



Bits error versus im
Results
Initial program 0.0
Taylor expanded in im around 0 1.0
Final simplification1.0
herbie shell --seed 2022127
(FPCore (re im)
:name "math.cos on complex, real part"
:precision binary64
(* (* 0.5 (cos re)) (+ (exp (- im)) (exp im))))