\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 r627188 = x;
double r627189 = y;
double r627190 = sin(r627189);
double r627191 = r627190 / r627189;
double r627192 = r627188 * r627191;
double r627193 = z;
double r627194 = r627192 / r627193;
return r627194;
}
double f(double x, double y, double z) {
double r627195 = z;
double r627196 = -4.40806905865946e+69;
bool r627197 = r627195 <= r627196;
double r627198 = x;
double r627199 = y;
double r627200 = sin(r627199);
double r627201 = r627198 * r627200;
double r627202 = r627201 / r627199;
double r627203 = r627202 / r627195;
double r627204 = r627200 / r627199;
double r627205 = r627195 / r627204;
double r627206 = r627198 / r627205;
double r627207 = r627197 ? r627203 : r627206;
return r627207;
}




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))