\frac{x \cdot \frac{\sin y}{y}}{z}\begin{array}{l}
\mathbf{if}\;\frac{x \cdot \frac{\sin y}{y}}{z} \le -4.797944114414283853740653503155849375579 \cdot 10^{-317} \lor \neg \left(\frac{x \cdot \frac{\sin y}{y}}{z} \le -0.0\right):\\
\;\;\;\;\frac{x \cdot \frac{\sin y}{y}}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\frac{\frac{z}{x}}{\frac{\sin y}{y}}}\\
\end{array}double f(double x, double y, double z) {
double r353218 = x;
double r353219 = y;
double r353220 = sin(r353219);
double r353221 = r353220 / r353219;
double r353222 = r353218 * r353221;
double r353223 = z;
double r353224 = r353222 / r353223;
return r353224;
}
double f(double x, double y, double z) {
double r353225 = x;
double r353226 = y;
double r353227 = sin(r353226);
double r353228 = r353227 / r353226;
double r353229 = r353225 * r353228;
double r353230 = z;
double r353231 = r353229 / r353230;
double r353232 = -4.7979441144143e-317;
bool r353233 = r353231 <= r353232;
double r353234 = -0.0;
bool r353235 = r353231 <= r353234;
double r353236 = !r353235;
bool r353237 = r353233 || r353236;
double r353238 = 1.0;
double r353239 = r353230 / r353225;
double r353240 = r353239 / r353228;
double r353241 = r353238 / r353240;
double r353242 = r353237 ? r353231 : r353241;
return r353242;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 2.6 |
|---|---|
| Target | 0.3 |
| Herbie | 0.4 |
if (/ (* x (/ (sin y) y)) z) < -4.7979441144143e-317 or -0.0 < (/ (* x (/ (sin y) y)) z) Initial program 0.4
if -4.7979441144143e-317 < (/ (* x (/ (sin y) y)) z) < -0.0Initial program 8.9
rmApplied clear-num9.0
rmApplied associate-/r*0.5
Final simplification0.4
herbie shell --seed 2019326
(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))