\frac{x \cdot \frac{\sin y}{y}}{z}\begin{array}{l}
\mathbf{if}\;z \le -4.40806905865946009 \cdot 10^{69}:\\
\;\;\;\;\frac{\frac{x \cdot \sin y}{y}}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\frac{z}{\frac{\sin y}{y}}}\\
\end{array}double f(double x, double y, double z) {
double r538601 = x;
double r538602 = y;
double r538603 = sin(r538602);
double r538604 = r538603 / r538602;
double r538605 = r538601 * r538604;
double r538606 = z;
double r538607 = r538605 / r538606;
return r538607;
}
double f(double x, double y, double z) {
double r538608 = z;
double r538609 = -4.40806905865946e+69;
bool r538610 = r538608 <= r538609;
double r538611 = x;
double r538612 = y;
double r538613 = sin(r538612);
double r538614 = r538611 * r538613;
double r538615 = r538614 / r538612;
double r538616 = r538615 / r538608;
double r538617 = r538613 / r538612;
double r538618 = r538608 / r538617;
double r538619 = r538611 / r538618;
double r538620 = r538610 ? r538616 : r538619;
return r538620;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 2.7 |
|---|---|
| Target | 0.3 |
| Herbie | 2.0 |
if z < -4.40806905865946e+69Initial program 0.1
rmApplied associate-*r/1.7
if -4.40806905865946e+69 < z Initial program 3.3
rmApplied associate-/l*2.0
Final simplification2.0
herbie shell --seed 2020060
(FPCore (x y z)
:name "Linear.Quaternion:$ctanh from linear-1.19.1.3"
:precision binary64
:herbie-target
(if (< z -4.2173720203427147e-29) (/ (* x (/ 1 (/ y (sin y)))) z) (if (< z 4.446702369113811e+64) (/ x (* z (/ y (sin y)))) (/ (* x (/ 1 (/ y (sin y)))) z)))
(/ (* x (/ (sin y) y)) z))