\frac{\cosh x \cdot \frac{y}{x}}{z}\begin{array}{l}
\mathbf{if}\;\cosh x \cdot \frac{y}{x} \le -5.3891980105264862 \cdot 10^{217}:\\
\;\;\;\;\frac{\frac{y}{z} \cdot \mathsf{fma}\left(e^{x}, \frac{1}{2}, \frac{\frac{1}{2}}{e^{x}}\right)}{x}\\
\mathbf{elif}\;\cosh x \cdot \frac{y}{x} \le 7.8168077226517798 \cdot 10^{108}:\\
\;\;\;\;\frac{\sqrt{\cosh x} \cdot \left(\sqrt{\cosh x} \cdot \frac{y}{x}\right)}{z}\\
\mathbf{else}:\\
\;\;\;\;\cosh x \cdot \frac{y}{x \cdot z}\\
\end{array}double f(double x, double y, double z) {
double r583978 = x;
double r583979 = cosh(r583978);
double r583980 = y;
double r583981 = r583980 / r583978;
double r583982 = r583979 * r583981;
double r583983 = z;
double r583984 = r583982 / r583983;
return r583984;
}
double f(double x, double y, double z) {
double r583985 = x;
double r583986 = cosh(r583985);
double r583987 = y;
double r583988 = r583987 / r583985;
double r583989 = r583986 * r583988;
double r583990 = -5.389198010526486e+217;
bool r583991 = r583989 <= r583990;
double r583992 = z;
double r583993 = r583987 / r583992;
double r583994 = exp(r583985);
double r583995 = 0.5;
double r583996 = r583995 / r583994;
double r583997 = fma(r583994, r583995, r583996);
double r583998 = r583993 * r583997;
double r583999 = r583998 / r583985;
double r584000 = 7.81680772265178e+108;
bool r584001 = r583989 <= r584000;
double r584002 = sqrt(r583986);
double r584003 = r584002 * r583988;
double r584004 = r584002 * r584003;
double r584005 = r584004 / r583992;
double r584006 = r583985 * r583992;
double r584007 = r583987 / r584006;
double r584008 = r583986 * r584007;
double r584009 = r584001 ? r584005 : r584008;
double r584010 = r583991 ? r583999 : r584009;
return r584010;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 7.7 |
|---|---|
| Target | 0.4 |
| Herbie | 0.8 |
if (* (cosh x) (/ y x)) < -5.389198010526486e+217Initial program 30.5
rmApplied *-un-lft-identity30.5
Applied times-frac30.4
Simplified30.4
Simplified0.8
Taylor expanded around inf 0.9
Simplified0.7
if -5.389198010526486e+217 < (* (cosh x) (/ y x)) < 7.81680772265178e+108Initial program 0.3
rmApplied add-sqr-sqrt0.3
Applied associate-*l*0.3
if 7.81680772265178e+108 < (* (cosh x) (/ y x)) Initial program 18.4
rmApplied *-un-lft-identity18.4
Applied times-frac18.4
Simplified18.4
Simplified2.6
Final simplification0.8
herbie shell --seed 2020081 +o rules:numerics
(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.0385305359351529e-39) (/ (/ (* (cosh x) y) x) z) (* (/ (/ y z) x) (cosh x))))
(/ (* (cosh x) (/ y x)) z))