\frac{\cosh x \cdot \frac{y}{x}}{z}\begin{array}{l}
\mathbf{if}\;z \le -7.499151431129345690915331400810285626293 \cdot 10^{-22} \lor \neg \left(z \le 3.123371243102039260157787505142381731931 \cdot 10^{-43}\right):\\
\;\;\;\;\frac{y}{\frac{z \cdot x}{\left(e^{x} + e^{-x}\right) \cdot \frac{1}{2}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{y}{\frac{z}{e^{x} + e^{-x}}}}{\frac{x}{\frac{1}{2}}}\\
\end{array}double f(double x, double y, double z) {
double r340401 = x;
double r340402 = cosh(r340401);
double r340403 = y;
double r340404 = r340403 / r340401;
double r340405 = r340402 * r340404;
double r340406 = z;
double r340407 = r340405 / r340406;
return r340407;
}
double f(double x, double y, double z) {
double r340408 = z;
double r340409 = -7.499151431129346e-22;
bool r340410 = r340408 <= r340409;
double r340411 = 3.1233712431020393e-43;
bool r340412 = r340408 <= r340411;
double r340413 = !r340412;
bool r340414 = r340410 || r340413;
double r340415 = y;
double r340416 = x;
double r340417 = r340408 * r340416;
double r340418 = exp(r340416);
double r340419 = -r340416;
double r340420 = exp(r340419);
double r340421 = r340418 + r340420;
double r340422 = 0.5;
double r340423 = r340421 * r340422;
double r340424 = r340417 / r340423;
double r340425 = r340415 / r340424;
double r340426 = r340408 / r340421;
double r340427 = r340415 / r340426;
double r340428 = r340416 / r340422;
double r340429 = r340427 / r340428;
double r340430 = r340414 ? r340425 : r340429;
return r340430;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 7.5 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
if z < -7.499151431129346e-22 or 3.1233712431020393e-43 < z Initial program 10.7
Taylor expanded around inf 0.4
Simplified0.4
if -7.499151431129346e-22 < z < 3.1233712431020393e-43Initial program 0.3
Taylor expanded around inf 22.1
Simplified22.1
rmApplied times-frac22.1
Applied associate-/r*0.3
Final simplification0.4
herbie shell --seed 2019323
(FPCore (x y z)
:name "Linear.Quaternion:$ctan from linear-1.19.1.3"
:precision binary64
: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))