\frac{x}{y} \cdot \left(z - t\right) + t\begin{array}{l}
\mathbf{if}\;z \le -1.84981784046249300200636436486704057411 \cdot 10^{-181} \lor \neg \left(z \le 1.036800313662513774601491787735915867558 \cdot 10^{-190}\right):\\
\;\;\;\;\mathsf{fma}\left(\frac{x}{y}, z - t, t\right)\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{x \cdot z}{y} - \frac{t \cdot x}{y}\right) + t\\
\end{array}double f(double x, double y, double z, double t) {
double r536976 = x;
double r536977 = y;
double r536978 = r536976 / r536977;
double r536979 = z;
double r536980 = t;
double r536981 = r536979 - r536980;
double r536982 = r536978 * r536981;
double r536983 = r536982 + r536980;
return r536983;
}
double f(double x, double y, double z, double t) {
double r536984 = z;
double r536985 = -1.849817840462493e-181;
bool r536986 = r536984 <= r536985;
double r536987 = 1.0368003136625138e-190;
bool r536988 = r536984 <= r536987;
double r536989 = !r536988;
bool r536990 = r536986 || r536989;
double r536991 = x;
double r536992 = y;
double r536993 = r536991 / r536992;
double r536994 = t;
double r536995 = r536984 - r536994;
double r536996 = fma(r536993, r536995, r536994);
double r536997 = r536991 * r536984;
double r536998 = r536997 / r536992;
double r536999 = r536994 * r536991;
double r537000 = r536999 / r536992;
double r537001 = r536998 - r537000;
double r537002 = r537001 + r536994;
double r537003 = r536990 ? r536996 : r537002;
return r537003;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 2.0 |
|---|---|
| Target | 2.1 |
| Herbie | 2.1 |
if z < -1.849817840462493e-181 or 1.0368003136625138e-190 < z Initial program 1.6
Simplified1.6
if -1.849817840462493e-181 < z < 1.0368003136625138e-190Initial program 3.5
rmApplied div-inv3.5
Applied associate-*l*4.6
Simplified4.5
rmApplied add-cube-cbrt4.9
Applied *-un-lft-identity4.9
Applied times-frac4.9
Applied associate-*r*2.9
Simplified2.9
Taylor expanded around 0 3.9
Final simplification2.1
herbie shell --seed 2019350 +o rules:numerics
(FPCore (x y z t)
:name "Numeric.Signal.Multichannel:$cget from hsignal-0.2.7.1"
:precision binary64
:herbie-target
(if (< z 2.759456554562692e-282) (+ (* (/ x y) (- z t)) t) (if (< z 2.326994450874436e-110) (+ (* x (/ (- z t) y)) t) (+ (* (/ x y) (- z t)) t)))
(+ (* (/ x y) (- z t)) t))