\Re(\left(\frac{e^{x} + e^{-x}}{2} \cdot \cos y + \frac{e^{x} - e^{-x}}{2} \cdot \sin y i\right))\frac{\mathsf{fma}\left(\sqrt{e^{x}}, \sqrt{e^{x}}, e^{-x}\right)}{2} \cdot \cos ydouble f(double x, double y) {
double r41912 = x;
double r41913 = exp(r41912);
double r41914 = -r41912;
double r41915 = exp(r41914);
double r41916 = r41913 + r41915;
double r41917 = 2.0;
double r41918 = r41916 / r41917;
double r41919 = y;
double r41920 = cos(r41919);
double r41921 = r41918 * r41920;
double r41922 = r41913 - r41915;
double r41923 = r41922 / r41917;
double r41924 = sin(r41919);
double r41925 = r41923 * r41924;
double r41926 = /* ERROR: no complex support in C */;
double r41927 = /* ERROR: no complex support in C */;
return r41927;
}
double f(double x, double y) {
double r41928 = x;
double r41929 = exp(r41928);
double r41930 = sqrt(r41929);
double r41931 = -r41928;
double r41932 = exp(r41931);
double r41933 = fma(r41930, r41930, r41932);
double r41934 = 2.0;
double r41935 = r41933 / r41934;
double r41936 = y;
double r41937 = cos(r41936);
double r41938 = r41935 * r41937;
return r41938;
}



Bits error versus x



Bits error versus y
Initial program 0.0
Simplified0.0
rmApplied add-sqr-sqrt0.0
Applied fma-def0.0
Final simplification0.0
herbie shell --seed 2020089 +o rules:numerics
(FPCore (x y)
:name "Euler formula real part (p55)"
:precision binary64
(re (complex (* (/ (+ (exp x) (exp (- x))) 2) (cos y)) (* (/ (- (exp x) (exp (- x))) 2) (sin y)))))