\frac{\cosh x \cdot \frac{y}{x}}{z}\begin{array}{l}
\mathbf{if}\;\frac{\cosh x \cdot \frac{y}{x}}{z} \le -1.569646754895685203707472211986928556371 \cdot 10^{-6}:\\
\;\;\;\;\frac{\frac{y}{z} \cdot \mathsf{fma}\left(e^{x}, \frac{1}{2}, \frac{\frac{1}{2}}{e^{x}}\right)}{x}\\
\mathbf{elif}\;\frac{\cosh x \cdot \frac{y}{x}}{z} \le 1.43550247534837939212643563586416747364 \cdot 10^{308}:\\
\;\;\;\;\frac{\cosh x \cdot \frac{y}{x}}{z}\\
\mathbf{else}:\\
\;\;\;\;\cosh x \cdot \left(y \cdot \frac{\frac{1}{z}}{x}\right)\\
\end{array}double f(double x, double y, double z) {
double r481755 = x;
double r481756 = cosh(r481755);
double r481757 = y;
double r481758 = r481757 / r481755;
double r481759 = r481756 * r481758;
double r481760 = z;
double r481761 = r481759 / r481760;
return r481761;
}
double f(double x, double y, double z) {
double r481762 = x;
double r481763 = cosh(r481762);
double r481764 = y;
double r481765 = r481764 / r481762;
double r481766 = r481763 * r481765;
double r481767 = z;
double r481768 = r481766 / r481767;
double r481769 = -1.5696467548956852e-06;
bool r481770 = r481768 <= r481769;
double r481771 = r481764 / r481767;
double r481772 = exp(r481762);
double r481773 = 0.5;
double r481774 = r481773 / r481772;
double r481775 = fma(r481772, r481773, r481774);
double r481776 = r481771 * r481775;
double r481777 = r481776 / r481762;
double r481778 = 1.4355024753483794e+308;
bool r481779 = r481768 <= r481778;
double r481780 = 1.0;
double r481781 = r481780 / r481767;
double r481782 = r481781 / r481762;
double r481783 = r481764 * r481782;
double r481784 = r481763 * r481783;
double r481785 = r481779 ? r481768 : r481784;
double r481786 = r481770 ? r481777 : r481785;
return r481786;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 7.3 |
|---|---|
| Target | 0.4 |
| Herbie | 0.3 |
if (/ (* (cosh x) (/ y x)) z) < -1.5696467548956852e-06Initial program 12.2
rmApplied *-un-lft-identity12.2
Applied times-frac12.2
Simplified12.2
Simplified11.5
Taylor expanded around inf 11.5
Simplified0.3
if -1.5696467548956852e-06 < (/ (* (cosh x) (/ y x)) z) < 1.4355024753483794e+308Initial program 0.2
if 1.4355024753483794e+308 < (/ (* (cosh x) (/ y x)) z) Initial program 63.9
rmApplied *-un-lft-identity63.9
Applied times-frac63.7
Simplified63.7
Simplified0.4
rmApplied div-inv0.5
rmApplied add-cube-cbrt0.5
Applied times-frac0.6
Simplified0.6
Simplified0.6
rmApplied associate-*l/0.5
Simplified0.5
Final simplification0.3
herbie shell --seed 2019353 +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))