\frac{x \cdot \left(y - z\right)}{t - z}\begin{array}{l}
\mathbf{if}\;z \le 1.369752526671511722658526908528908232804 \cdot 10^{-295} \lor \neg \left(z \le 1.627532321675118910729324718829559319672 \cdot 10^{-108}\right):\\
\;\;\;\;\frac{x}{\frac{t - z}{y - z}}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\frac{t - z}{x \cdot \left(y - z\right)}}\\
\end{array}double f(double x, double y, double z, double t) {
double r592681 = x;
double r592682 = y;
double r592683 = z;
double r592684 = r592682 - r592683;
double r592685 = r592681 * r592684;
double r592686 = t;
double r592687 = r592686 - r592683;
double r592688 = r592685 / r592687;
return r592688;
}
double f(double x, double y, double z, double t) {
double r592689 = z;
double r592690 = 1.3697525266715117e-295;
bool r592691 = r592689 <= r592690;
double r592692 = 1.627532321675119e-108;
bool r592693 = r592689 <= r592692;
double r592694 = !r592693;
bool r592695 = r592691 || r592694;
double r592696 = x;
double r592697 = t;
double r592698 = r592697 - r592689;
double r592699 = y;
double r592700 = r592699 - r592689;
double r592701 = r592698 / r592700;
double r592702 = r592696 / r592701;
double r592703 = 1.0;
double r592704 = r592696 * r592700;
double r592705 = r592698 / r592704;
double r592706 = r592703 / r592705;
double r592707 = r592695 ? r592702 : r592706;
return r592707;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 11.7 |
|---|---|
| Target | 2.4 |
| Herbie | 2.3 |
if z < 1.3697525266715117e-295 or 1.627532321675119e-108 < z Initial program 12.6
rmApplied associate-/l*1.7
rmApplied div-inv1.9
rmApplied un-div-inv1.7
if 1.3697525266715117e-295 < z < 1.627532321675119e-108Initial program 5.6
rmApplied clear-num5.9
Final simplification2.3
herbie shell --seed 2019353 +o rules:numerics
(FPCore (x y z t)
:name "Graphics.Rendering.Chart.Plot.AreaSpots:renderAreaSpots4D from Chart-1.5.3"
:precision binary64
:herbie-target
(/ x (/ (- t z) (- y z)))
(/ (* x (- y z)) (- t z)))