\left(0.5 \cdot \sin re\right) \cdot \left(e^{0 - im} + e^{im}\right)0.5 \cdot \mathsf{fma}\left(e^{im}, \sin re, \frac{\sin re}{e^{im}}\right)double f(double re, double im) {
double r403257 = 0.5;
double r403258 = re;
double r403259 = sin(r403258);
double r403260 = r403257 * r403259;
double r403261 = 0.0;
double r403262 = im;
double r403263 = r403261 - r403262;
double r403264 = exp(r403263);
double r403265 = exp(r403262);
double r403266 = r403264 + r403265;
double r403267 = r403260 * r403266;
return r403267;
}
double f(double re, double im) {
double r403268 = 0.5;
double r403269 = im;
double r403270 = exp(r403269);
double r403271 = re;
double r403272 = sin(r403271);
double r403273 = r403272 / r403270;
double r403274 = fma(r403270, r403272, r403273);
double r403275 = r403268 * r403274;
return r403275;
}



Bits error versus re



Bits error versus im
Initial program 0.0
Simplified0.0
rmApplied log1p-expm1-u0.2
rmApplied log1p-expm1-u0.5
Simplified0.4
rmApplied fma-udef0.4
Applied distribute-rgt-in0.4
Taylor expanded around inf 0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2019156 +o rules:numerics
(FPCore (re im)
:name "math.sin on complex, real part"
(* (* 0.5 (sin re)) (+ (exp (- 0 im)) (exp im))))