\frac{x \cdot x}{y \cdot y} + \frac{z \cdot z}{t \cdot t}\left({\left(\left|\frac{x}{y}\right|\right)}^{\frac{3}{2}} \cdot \sqrt{\sqrt{\left|\frac{x}{y}\right|}}\right) \cdot \sqrt{\sqrt{\left|\frac{x}{y}\right|}} + \left|\frac{z}{t}\right| \cdot \left|\frac{z}{t}\right|double f(double x, double y, double z, double t) {
double r603092 = x;
double r603093 = r603092 * r603092;
double r603094 = y;
double r603095 = r603094 * r603094;
double r603096 = r603093 / r603095;
double r603097 = z;
double r603098 = r603097 * r603097;
double r603099 = t;
double r603100 = r603099 * r603099;
double r603101 = r603098 / r603100;
double r603102 = r603096 + r603101;
return r603102;
}
double f(double x, double y, double z, double t) {
double r603103 = x;
double r603104 = y;
double r603105 = r603103 / r603104;
double r603106 = fabs(r603105);
double r603107 = 1.5;
double r603108 = pow(r603106, r603107);
double r603109 = sqrt(r603106);
double r603110 = sqrt(r603109);
double r603111 = r603108 * r603110;
double r603112 = r603111 * r603110;
double r603113 = z;
double r603114 = t;
double r603115 = r603113 / r603114;
double r603116 = fabs(r603115);
double r603117 = r603116 * r603116;
double r603118 = r603112 + r603117;
return r603118;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 33.2 |
|---|---|
| Target | 0.4 |
| Herbie | 0.5 |
Initial program 33.2
rmApplied add-sqr-sqrt33.2
Simplified33.2
Simplified18.7
rmApplied add-sqr-sqrt18.8
Simplified18.8
Simplified0.4
rmApplied add-sqr-sqrt0.5
Applied associate-*r*0.5
Simplified0.5
rmApplied add-sqr-sqrt0.5
Applied sqrt-prod0.5
Applied associate-*r*0.5
Final simplification0.5
herbie shell --seed 2020034
(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))))