\frac{x \cdot \frac{\sin y}{y}}{z}\begin{array}{l}
\mathbf{if}\;z \le -2.28657606638248286 \cdot 10^{-6} \lor \neg \left(z \le 1.7877667366727078 \cdot 10^{-79}\right):\\
\;\;\;\;\frac{x \cdot \left(\sin y \cdot \frac{1}{y}\right)}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\frac{z}{\frac{\sin y}{y}}}\\
\end{array}double f(double x, double y, double z) {
double r475259 = x;
double r475260 = y;
double r475261 = sin(r475260);
double r475262 = r475261 / r475260;
double r475263 = r475259 * r475262;
double r475264 = z;
double r475265 = r475263 / r475264;
return r475265;
}
double f(double x, double y, double z) {
double r475266 = z;
double r475267 = -2.286576066382483e-06;
bool r475268 = r475266 <= r475267;
double r475269 = 1.7877667366727078e-79;
bool r475270 = r475266 <= r475269;
double r475271 = !r475270;
bool r475272 = r475268 || r475271;
double r475273 = x;
double r475274 = y;
double r475275 = sin(r475274);
double r475276 = 1.0;
double r475277 = r475276 / r475274;
double r475278 = r475275 * r475277;
double r475279 = r475273 * r475278;
double r475280 = r475279 / r475266;
double r475281 = r475275 / r475274;
double r475282 = r475266 / r475281;
double r475283 = r475273 / r475282;
double r475284 = r475272 ? r475280 : r475283;
return r475284;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 2.6 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
if z < -2.286576066382483e-06 or 1.7877667366727078e-79 < z Initial program 0.3
rmApplied div-inv0.4
if -2.286576066382483e-06 < z < 1.7877667366727078e-79Initial program 6.5
rmApplied associate-/l*0.2
Final simplification0.3
herbie shell --seed 2020100
(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))