\frac{\cosh x \cdot \frac{y}{x}}{z}\begin{array}{l}
\mathbf{if}\;z \le -3.1569808277222708 \cdot 10^{-65}:\\
\;\;\;\;\frac{y}{\frac{x \cdot z}{\sqrt{\mathsf{fma}\left(e^{x}, \frac{1}{2}, \frac{\frac{1}{2}}{e^{x}}\right)}}} \cdot \sqrt{\mathsf{fma}\left(e^{x}, \frac{1}{2}, \frac{\frac{1}{2}}{e^{x}}\right)}\\
\mathbf{elif}\;z \le 2.0130873820056925 \cdot 10^{-20}:\\
\;\;\;\;\frac{\frac{y}{\frac{z}{\mathsf{fma}\left(\frac{1}{2}, e^{x}, \frac{\frac{1}{2}}{e^{x}}\right)}}}{x}\\
\mathbf{else}:\\
\;\;\;\;\frac{y}{\frac{x \cdot z}{\sqrt{\mathsf{fma}\left(e^{x}, \frac{1}{2}, \frac{\frac{1}{2}}{e^{x}}\right)}}} \cdot \sqrt{\mathsf{fma}\left(e^{x}, \frac{1}{2}, \frac{\frac{1}{2}}{e^{x}}\right)}\\
\end{array}double f(double x, double y, double z) {
double r21968373 = x;
double r21968374 = cosh(r21968373);
double r21968375 = y;
double r21968376 = r21968375 / r21968373;
double r21968377 = r21968374 * r21968376;
double r21968378 = z;
double r21968379 = r21968377 / r21968378;
return r21968379;
}
double f(double x, double y, double z) {
double r21968380 = z;
double r21968381 = -3.1569808277222708e-65;
bool r21968382 = r21968380 <= r21968381;
double r21968383 = y;
double r21968384 = x;
double r21968385 = r21968384 * r21968380;
double r21968386 = exp(r21968384);
double r21968387 = 0.5;
double r21968388 = r21968387 / r21968386;
double r21968389 = fma(r21968386, r21968387, r21968388);
double r21968390 = sqrt(r21968389);
double r21968391 = r21968385 / r21968390;
double r21968392 = r21968383 / r21968391;
double r21968393 = r21968392 * r21968390;
double r21968394 = 2.0130873820056925e-20;
bool r21968395 = r21968380 <= r21968394;
double r21968396 = fma(r21968387, r21968386, r21968388);
double r21968397 = r21968380 / r21968396;
double r21968398 = r21968383 / r21968397;
double r21968399 = r21968398 / r21968384;
double r21968400 = r21968395 ? r21968399 : r21968393;
double r21968401 = r21968382 ? r21968393 : r21968400;
return r21968401;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 7.4 |
|---|---|
| Target | 0.5 |
| Herbie | 0.5 |
if z < -3.1569808277222708e-65 or 2.0130873820056925e-20 < z Initial program 10.3
Taylor expanded around inf 0.5
Simplified10.3
Taylor expanded around inf 0.5
Simplified10.3
rmApplied add-sqr-sqrt10.3
Applied *-un-lft-identity10.3
Applied times-frac10.3
Applied *-un-lft-identity10.3
Applied *-un-lft-identity10.3
Applied times-frac10.3
Applied times-frac10.3
Simplified10.3
Simplified0.5
if -3.1569808277222708e-65 < z < 2.0130873820056925e-20Initial program 0.3
Taylor expanded around inf 22.4
Simplified0.5
Taylor expanded around inf 22.4
Simplified0.4
rmApplied div-inv0.5
rmApplied associate-*l/0.5
Simplified0.4
Final simplification0.5
herbie shell --seed 2019162 +o rules:numerics
(FPCore (x y z)
:name "Linear.Quaternion:$ctan from linear-1.19.1.3"
:herbie-target
(if (< y -4.618902267687042e-52) (* (/ (/ y z) x) (cosh x)) (if (< y 1.038530535935153e-39) (/ (/ (* (cosh x) y) x) z) (* (/ (/ y z) x) (cosh x))))
(/ (* (cosh x) (/ y x)) z))