\frac{x \cdot \frac{\sin y}{y}}{z}\begin{array}{l}
\mathbf{if}\;x \cdot \frac{\sin y}{y} \le 2.083597813045566445531085328327042967006 \cdot 10^{-202}:\\
\;\;\;\;x \cdot \frac{\frac{1}{\frac{y}{\sin y}}}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x \cdot \left(\sin y \cdot \frac{1}{y}\right)}{z}\\
\end{array}double f(double x, double y, double z) {
double r311993 = x;
double r311994 = y;
double r311995 = sin(r311994);
double r311996 = r311995 / r311994;
double r311997 = r311993 * r311996;
double r311998 = z;
double r311999 = r311997 / r311998;
return r311999;
}
double f(double x, double y, double z) {
double r312000 = x;
double r312001 = y;
double r312002 = sin(r312001);
double r312003 = r312002 / r312001;
double r312004 = r312000 * r312003;
double r312005 = 2.0835978130455664e-202;
bool r312006 = r312004 <= r312005;
double r312007 = 1.0;
double r312008 = r312001 / r312002;
double r312009 = r312007 / r312008;
double r312010 = z;
double r312011 = r312009 / r312010;
double r312012 = r312000 * r312011;
double r312013 = r312007 / r312001;
double r312014 = r312002 * r312013;
double r312015 = r312000 * r312014;
double r312016 = r312015 / r312010;
double r312017 = r312006 ? r312012 : r312016;
return r312017;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 2.8 |
|---|---|
| Target | 0.3 |
| Herbie | 1.7 |
if (* x (/ (sin y) y)) < 2.0835978130455664e-202Initial program 4.2
rmApplied *-un-lft-identity4.2
Applied times-frac2.4
Simplified2.4
rmApplied clear-num2.4
if 2.0835978130455664e-202 < (* x (/ (sin y) y)) Initial program 0.2
rmApplied div-inv0.2
Final simplification1.7
herbie shell --seed 2019208
(FPCore (x y z)
:name "Linear.Quaternion:$ctanh from linear-1.19.1.3"
:precision binary64
:herbie-target
(if (< z -4.21737202034271466e-29) (/ (* x (/ 1 (/ y (sin y)))) z) (if (< z 4.44670236911381103e64) (/ x (* z (/ y (sin y)))) (/ (* x (/ 1 (/ y (sin y)))) z)))
(/ (* x (/ (sin y) y)) z))