x \cdot x - \left(y \cdot 4\right) \cdot \left(z \cdot z - t\right)
\mathsf{fma}\left(x, x, y \cdot \left(4 \cdot t\right) + \left(y \cdot z\right) \cdot \left(\left(-z\right) \cdot 4\right)\right)double code(double x, double y, double z, double t) {
return ((x * x) - ((y * 4.0) * ((z * z) - t)));
}
double code(double x, double y, double z, double t) {
return fma(x, x, ((y * (4.0 * t)) + ((y * z) * (-z * 4.0))));
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 5.7 |
|---|---|
| Target | 5.7 |
| Herbie | 0.1 |
Initial program 5.7
Simplified5.7
rmApplied associate-*l*5.7
rmApplied sub-neg5.7
Applied distribute-lft-in5.7
Applied distribute-lft-in5.7
Simplified5.7
rmApplied distribute-rgt-neg-in5.7
Applied associate-*l*5.7
Applied associate-*r*0.1
Final simplification0.1
herbie shell --seed 2020078 +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))))