\frac{\cosh x \cdot \frac{y}{x}}{z}\begin{array}{l}
\mathbf{if}\;y \le -6.19754678860515829 \cdot 10^{-22}:\\
\;\;\;\;\frac{\frac{1}{2} \cdot \left(e^{-1 \cdot x} + e^{x}\right)}{\frac{z \cdot x}{y}}\\
\mathbf{elif}\;y \le 12219.624869563231:\\
\;\;\;\;\frac{\left(\sqrt[3]{\cosh x} \cdot \sqrt[3]{\cosh x}\right) \cdot \left(\sqrt[3]{\cosh x} \cdot \frac{y}{x}\right)}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{2} \cdot \frac{x \cdot y}{z} + \frac{y}{x \cdot z}\\
\end{array}double code(double x, double y, double z) {
return ((double) (((double) (((double) cosh(x)) * ((double) (y / x)))) / z));
}
double code(double x, double y, double z) {
double VAR;
if ((y <= -6.197546788605158e-22)) {
VAR = ((double) (((double) (0.5 * ((double) (((double) exp(((double) (-1.0 * x)))) + ((double) exp(x)))))) / ((double) (((double) (z * x)) / y))));
} else {
double VAR_1;
if ((y <= 12219.624869563231)) {
VAR_1 = ((double) (((double) (((double) (((double) cbrt(((double) cosh(x)))) * ((double) cbrt(((double) cosh(x)))))) * ((double) (((double) cbrt(((double) cosh(x)))) * ((double) (y / x)))))) / z));
} else {
VAR_1 = ((double) (((double) (0.5 * ((double) (((double) (x * y)) / z)))) + ((double) (y / ((double) (x * z))))));
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 8.0 |
|---|---|
| Target | 0.5 |
| Herbie | 0.6 |
if y < -6.197546788605158e-22Initial program 20.4
Taylor expanded around inf 0.4
Simplified0.4
if -6.197546788605158e-22 < y < 12219.624869563231Initial program 0.3
rmApplied add-cube-cbrt0.3
Applied associate-*l*0.3
if 12219.624869563231 < y Initial program 22.5
Taylor expanded around 0 1.6
Final simplification0.6
herbie shell --seed 2020120
(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))