x \cdot x - \left(y \cdot 4\right) \cdot \left(z \cdot z - t\right)
\begin{array}{l}
\mathbf{if}\;z \cdot z \le 2.1296068017078334 \cdot 10^{302}:\\
\;\;\;\;\mathsf{fma}\left(x, x, \left(y \cdot 4\right) \cdot \left(t - z \cdot z\right) + \left(y \cdot 4\right) \cdot \mathsf{fma}\left(-z, z, z \cdot z\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(x, x, \left(\left(y \cdot 4\right) \cdot \left(\sqrt{t} + z\right)\right) \cdot \left(\sqrt{t} - z\right)\right)\\
\end{array}double f(double x, double y, double z, double t) {
double r576524 = x;
double r576525 = r576524 * r576524;
double r576526 = y;
double r576527 = 4.0;
double r576528 = r576526 * r576527;
double r576529 = z;
double r576530 = r576529 * r576529;
double r576531 = t;
double r576532 = r576530 - r576531;
double r576533 = r576528 * r576532;
double r576534 = r576525 - r576533;
return r576534;
}
double f(double x, double y, double z, double t) {
double r576535 = z;
double r576536 = r576535 * r576535;
double r576537 = 2.1296068017078334e+302;
bool r576538 = r576536 <= r576537;
double r576539 = x;
double r576540 = y;
double r576541 = 4.0;
double r576542 = r576540 * r576541;
double r576543 = t;
double r576544 = r576543 - r576536;
double r576545 = r576542 * r576544;
double r576546 = -r576535;
double r576547 = fma(r576546, r576535, r576536);
double r576548 = r576542 * r576547;
double r576549 = r576545 + r576548;
double r576550 = fma(r576539, r576539, r576549);
double r576551 = sqrt(r576543);
double r576552 = r576551 + r576535;
double r576553 = r576542 * r576552;
double r576554 = r576551 - r576535;
double r576555 = r576553 * r576554;
double r576556 = fma(r576539, r576539, r576555);
double r576557 = r576538 ? r576550 : r576556;
return r576557;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 6.3 |
|---|---|
| Target | 6.3 |
| Herbie | 3.4 |
if (* z z) < 2.1296068017078334e+302Initial program 0.1
Simplified0.1
rmApplied add-sqr-sqrt31.8
Applied prod-diff31.8
Applied distribute-lft-in31.8
Simplified0.1
if 2.1296068017078334e+302 < (* z z) Initial program 61.6
Simplified61.6
rmApplied add-sqr-sqrt62.7
Applied difference-of-squares62.7
Applied associate-*r*32.3
Final simplification3.4
herbie shell --seed 2020039 +o rules:numerics
(FPCore (x y z t)
:name "Graphics.Rasterific.Shading:$sradialGradientWithFocusShader from Rasterific-0.6.1, B"
:precision binary64
:herbie-target
(- (* x x) (* 4 (* y (- (* z z) t))))
(- (* x x) (* (* y 4) (- (* z z) t))))