\frac{x \cdot \frac{\sin y}{y}}{z}\begin{array}{l}
\mathbf{if}\;z \le -67691958370526.5391:\\
\;\;\;\;\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 r609059 = x;
double r609060 = y;
double r609061 = sin(r609060);
double r609062 = r609061 / r609060;
double r609063 = r609059 * r609062;
double r609064 = z;
double r609065 = r609063 / r609064;
return r609065;
}
double f(double x, double y, double z) {
double r609066 = z;
double r609067 = -67691958370526.54;
bool r609068 = r609066 <= r609067;
double r609069 = x;
double r609070 = y;
double r609071 = sin(r609070);
double r609072 = 1.0;
double r609073 = r609072 / r609070;
double r609074 = r609071 * r609073;
double r609075 = r609069 * r609074;
double r609076 = r609075 / r609066;
double r609077 = r609071 / r609070;
double r609078 = r609066 / r609077;
double r609079 = r609069 / r609078;
double r609080 = r609068 ? r609076 : r609079;
return r609080;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 2.7 |
|---|---|
| Target | 0.3 |
| Herbie | 1.7 |
if z < -67691958370526.54Initial program 0.1
rmApplied div-inv0.2
if -67691958370526.54 < z Initial program 3.6
rmApplied associate-/l*2.2
Final simplification1.7
herbie shell --seed 2020027
(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))