\Im(\left(\frac{e^{x} + e^{-x}}{2} \cdot \cos y + \frac{e^{x} - e^{-x}}{2} \cdot \sin y i\right))\begin{array}{l}
\mathbf{if}\;x \le -0.01288229977934218090096507580710749607533:\\
\;\;\;\;\Im(\left(\frac{e^{x} + e^{-x}}{2} \cdot \cos y + \left(\sqrt[3]{\frac{e^{x} - e^{-x}}{2} \cdot \sin y} \cdot \sqrt[3]{\frac{e^{x} - e^{-x}}{2} \cdot \sin y}\right) \cdot \sqrt[3]{\frac{e^{x} - e^{-x}}{2} \cdot \sin y} i\right))\\
\mathbf{else}:\\
\;\;\;\;\Im(\left(\frac{e^{x} + e^{-x}}{2} \cdot \cos y + \frac{\frac{1}{3} \cdot {x}^{3} + \left(\frac{1}{60} \cdot {x}^{5} + 2 \cdot x\right)}{2} \cdot \sin y i\right))\\
\end{array}double f(double x, double y) {
double r56046 = x;
double r56047 = exp(r56046);
double r56048 = -r56046;
double r56049 = exp(r56048);
double r56050 = r56047 + r56049;
double r56051 = 2.0;
double r56052 = r56050 / r56051;
double r56053 = y;
double r56054 = cos(r56053);
double r56055 = r56052 * r56054;
double r56056 = r56047 - r56049;
double r56057 = r56056 / r56051;
double r56058 = sin(r56053);
double r56059 = r56057 * r56058;
double r56060 = /* ERROR: no complex support in C */;
double r56061 = /* ERROR: no complex support in C */;
return r56061;
}
double f(double x, double y) {
double r56062 = x;
double r56063 = -0.012882299779342181;
bool r56064 = r56062 <= r56063;
double r56065 = exp(r56062);
double r56066 = -r56062;
double r56067 = exp(r56066);
double r56068 = r56065 + r56067;
double r56069 = 2.0;
double r56070 = r56068 / r56069;
double r56071 = y;
double r56072 = cos(r56071);
double r56073 = r56070 * r56072;
double r56074 = r56065 - r56067;
double r56075 = r56074 / r56069;
double r56076 = sin(r56071);
double r56077 = r56075 * r56076;
double r56078 = cbrt(r56077);
double r56079 = r56078 * r56078;
double r56080 = r56079 * r56078;
double r56081 = /* ERROR: no complex support in C */;
double r56082 = /* ERROR: no complex support in C */;
double r56083 = 0.3333333333333333;
double r56084 = 3.0;
double r56085 = pow(r56062, r56084);
double r56086 = r56083 * r56085;
double r56087 = 0.016666666666666666;
double r56088 = 5.0;
double r56089 = pow(r56062, r56088);
double r56090 = r56087 * r56089;
double r56091 = 2.0;
double r56092 = r56091 * r56062;
double r56093 = r56090 + r56092;
double r56094 = r56086 + r56093;
double r56095 = r56094 / r56069;
double r56096 = r56095 * r56076;
double r56097 = /* ERROR: no complex support in C */;
double r56098 = /* ERROR: no complex support in C */;
double r56099 = r56064 ? r56082 : r56098;
return r56099;
}



Bits error versus x



Bits error versus y
if x < -0.012882299779342181Initial program 2.8
rmApplied add-cube-cbrt3.5
if -0.012882299779342181 < x Initial program 43.5
Taylor expanded around 0 0.4
Final simplification0.5
herbie shell --seed 2019323
(FPCore (x y)
:name "Euler formula imaginary part (p55)"
:precision binary64
(im (complex (* (/ (+ (exp x) (exp (- x))) 2) (cos y)) (* (/ (- (exp x) (exp (- x))) 2) (sin y)))))