\frac{x \cdot x}{y \cdot y} + \frac{z \cdot z}{t \cdot t}\mathsf{fma}\left(\frac{z}{t}, \frac{z}{t}, \left|\frac{x}{y}\right| \cdot \left|\frac{x}{y}\right|\right)double f(double x, double y, double z, double t) {
double r640832 = x;
double r640833 = r640832 * r640832;
double r640834 = y;
double r640835 = r640834 * r640834;
double r640836 = r640833 / r640835;
double r640837 = z;
double r640838 = r640837 * r640837;
double r640839 = t;
double r640840 = r640839 * r640839;
double r640841 = r640838 / r640840;
double r640842 = r640836 + r640841;
return r640842;
}
double f(double x, double y, double z, double t) {
double r640843 = z;
double r640844 = t;
double r640845 = r640843 / r640844;
double r640846 = x;
double r640847 = y;
double r640848 = r640846 / r640847;
double r640849 = fabs(r640848);
double r640850 = r640849 * r640849;
double r640851 = fma(r640845, r640845, r640850);
return r640851;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 33.8 |
|---|---|
| Target | 0.4 |
| Herbie | 0.4 |
Initial program 33.8
Simplified19.0
rmApplied add-sqr-sqrt19.0
Simplified19.0
Simplified0.4
Final simplification0.4
herbie shell --seed 2020056 +o rules:numerics
(FPCore (x y z t)
:name "Graphics.Rasterific.Svg.PathConverter:arcToSegments from rasterific-svg-0.2.3.1"
:precision binary64
:herbie-target
(+ (pow (/ x y) 2) (pow (/ z t) 2))
(+ (/ (* x x) (* y y)) (/ (* z z) (* t t))))