\frac{\cosh x \cdot \frac{y}{x}}{z}\begin{array}{l}
\mathbf{if}\;z \le -4.198394949665206 \cdot 10^{+50}:\\
\;\;\;\;\frac{\cosh x \cdot y}{x \cdot z}\\
\mathbf{elif}\;z \le 6.306951740289983 \cdot 10^{-10}:\\
\;\;\;\;\frac{\frac{\cosh x \cdot y}{z}}{x}\\
\mathbf{else}:\\
\;\;\;\;\frac{\cosh x \cdot y}{x \cdot z}\\
\end{array}double f(double x, double y, double z) {
double r27780786 = x;
double r27780787 = cosh(r27780786);
double r27780788 = y;
double r27780789 = r27780788 / r27780786;
double r27780790 = r27780787 * r27780789;
double r27780791 = z;
double r27780792 = r27780790 / r27780791;
return r27780792;
}
double f(double x, double y, double z) {
double r27780793 = z;
double r27780794 = -4.198394949665206e+50;
bool r27780795 = r27780793 <= r27780794;
double r27780796 = x;
double r27780797 = cosh(r27780796);
double r27780798 = y;
double r27780799 = r27780797 * r27780798;
double r27780800 = r27780796 * r27780793;
double r27780801 = r27780799 / r27780800;
double r27780802 = 6.306951740289983e-10;
bool r27780803 = r27780793 <= r27780802;
double r27780804 = r27780799 / r27780793;
double r27780805 = r27780804 / r27780796;
double r27780806 = r27780803 ? r27780805 : r27780801;
double r27780807 = r27780795 ? r27780801 : r27780806;
return r27780807;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 8.1 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
if z < -4.198394949665206e+50 or 6.306951740289983e-10 < z Initial program 12.9
rmApplied associate-*r/12.9
Applied associate-/l/0.3
if -4.198394949665206e+50 < z < 6.306951740289983e-10Initial program 0.7
rmApplied associate-*r/0.7
Applied associate-/l/17.1
rmApplied associate-/r*0.4
Final simplification0.4
herbie shell --seed 2019165
(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))