\frac{x \cdot x}{y \cdot y} + \frac{z \cdot z}{t \cdot t}\mathsf{hypot}\left(\frac{x}{y}, \frac{z}{t}\right) \cdot \left(\left(\sqrt{\sqrt{\mathsf{hypot}\left(\frac{x}{y}, \frac{z}{t}\right)}} \cdot \sqrt{\left|\sqrt[3]{\mathsf{hypot}\left(\frac{x}{y}, \frac{z}{t}\right)}\right| \cdot \sqrt{\sqrt[3]{\mathsf{hypot}\left(\frac{x}{y}, \frac{z}{t}\right)}}}\right) \cdot \sqrt{\mathsf{hypot}\left(\frac{x}{y}, \frac{z}{t}\right)}\right)double f(double x, double y, double z, double t) {
double r757435 = x;
double r757436 = r757435 * r757435;
double r757437 = y;
double r757438 = r757437 * r757437;
double r757439 = r757436 / r757438;
double r757440 = z;
double r757441 = r757440 * r757440;
double r757442 = t;
double r757443 = r757442 * r757442;
double r757444 = r757441 / r757443;
double r757445 = r757439 + r757444;
return r757445;
}
double f(double x, double y, double z, double t) {
double r757446 = x;
double r757447 = y;
double r757448 = r757446 / r757447;
double r757449 = z;
double r757450 = t;
double r757451 = r757449 / r757450;
double r757452 = hypot(r757448, r757451);
double r757453 = sqrt(r757452);
double r757454 = sqrt(r757453);
double r757455 = cbrt(r757452);
double r757456 = fabs(r757455);
double r757457 = sqrt(r757455);
double r757458 = r757456 * r757457;
double r757459 = sqrt(r757458);
double r757460 = r757454 * r757459;
double r757461 = r757460 * r757453;
double r757462 = r757452 * r757461;
return r757462;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 33.9 |
|---|---|
| Target | 0.4 |
| Herbie | 0.7 |
Initial program 33.9
Simplified19.4
rmApplied add-sqr-sqrt19.4
Simplified19.4
Simplified0.4
rmApplied add-sqr-sqrt0.6
rmApplied add-sqr-sqrt0.6
Applied sqrt-prod0.7
rmApplied add-cube-cbrt0.7
Applied sqrt-prod0.7
Simplified0.7
Final simplification0.7
herbie shell --seed 2020047 +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))))