x \cdot \frac{\sin y}{y}
\frac{x}{\frac{1}{\frac{\sin y}{y}}}
(FPCore (x y) :precision binary64 (* x (/ (sin y) y)))
(FPCore (x y) :precision binary64 (/ x (/ 1.0 (/ (sin y) y))))
double code(double x, double y) {
return x * (sin(y) / y);
}
double code(double x, double y) {
return x / (1.0 / (sin(y) / y));
}



Bits error versus x



Bits error versus y
Results
Initial program 0.1
Applied clear-num_binary640.2
Applied un-div-inv_binary640.1
Applied clear-num_binary640.2
Final simplification0.2
herbie shell --seed 2021275
(FPCore (x y)
:name "Linear.Quaternion:$cexp from linear-1.19.1.3"
:precision binary64
(* x (/ (sin y) y)))