\frac{x \cdot x}{y \cdot y} + \frac{z \cdot z}{t \cdot t}\mathsf{fma}\left(\frac{z}{t}, \frac{z}{t}, \frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\sqrt[3]{y} \cdot \sqrt[3]{y}} \cdot \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}} \cdot \frac{x}{y}\right)\right)double f(double x, double y, double z, double t) {
double r30076478 = x;
double r30076479 = r30076478 * r30076478;
double r30076480 = y;
double r30076481 = r30076480 * r30076480;
double r30076482 = r30076479 / r30076481;
double r30076483 = z;
double r30076484 = r30076483 * r30076483;
double r30076485 = t;
double r30076486 = r30076485 * r30076485;
double r30076487 = r30076484 / r30076486;
double r30076488 = r30076482 + r30076487;
return r30076488;
}
double f(double x, double y, double z, double t) {
double r30076489 = z;
double r30076490 = t;
double r30076491 = r30076489 / r30076490;
double r30076492 = x;
double r30076493 = cbrt(r30076492);
double r30076494 = r30076493 * r30076493;
double r30076495 = y;
double r30076496 = cbrt(r30076495);
double r30076497 = r30076496 * r30076496;
double r30076498 = r30076494 / r30076497;
double r30076499 = r30076493 / r30076496;
double r30076500 = r30076492 / r30076495;
double r30076501 = r30076499 * r30076500;
double r30076502 = r30076498 * r30076501;
double r30076503 = fma(r30076491, r30076491, r30076502);
return r30076503;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
| Original | 31.9 |
|---|---|
| Target | 0.4 |
| Herbie | 0.9 |
Initial program 31.9
Simplified0.4
rmApplied add-cube-cbrt0.8
Applied add-cube-cbrt0.9
Applied times-frac0.9
Applied associate-*l*0.9
Final simplification0.9
herbie shell --seed 2019158 +o rules:numerics
(FPCore (x y z t)
:name "Graphics.Rasterific.Svg.PathConverter:arcToSegments from rasterific-svg-0.2.3.1"
:herbie-target
(+ (pow (/ x y) 2) (pow (/ z t) 2))
(+ (/ (* x x) (* y y)) (/ (* z z) (* t t))))