Average Error: 33.7 → 0.5
Time: 17.8s
Precision: 64
\[\frac{x \cdot x}{y \cdot y} + \frac{z \cdot z}{t \cdot t}\]
\[{\left(\left|\frac{x}{y}\right|\right)}^{\frac{3}{2}} \cdot \sqrt{\left|\frac{x}{y}\right|} + \frac{z}{t} \cdot \frac{z}{t}\]
\frac{x \cdot x}{y \cdot y} + \frac{z \cdot z}{t \cdot t}
{\left(\left|\frac{x}{y}\right|\right)}^{\frac{3}{2}} \cdot \sqrt{\left|\frac{x}{y}\right|} + \frac{z}{t} \cdot \frac{z}{t}
double f(double x, double y, double z, double t) {
        double r549247 = x;
        double r549248 = r549247 * r549247;
        double r549249 = y;
        double r549250 = r549249 * r549249;
        double r549251 = r549248 / r549250;
        double r549252 = z;
        double r549253 = r549252 * r549252;
        double r549254 = t;
        double r549255 = r549254 * r549254;
        double r549256 = r549253 / r549255;
        double r549257 = r549251 + r549256;
        return r549257;
}

double f(double x, double y, double z, double t) {
        double r549258 = x;
        double r549259 = y;
        double r549260 = r549258 / r549259;
        double r549261 = fabs(r549260);
        double r549262 = 1.5;
        double r549263 = pow(r549261, r549262);
        double r549264 = sqrt(r549261);
        double r549265 = r549263 * r549264;
        double r549266 = z;
        double r549267 = t;
        double r549268 = r549266 / r549267;
        double r549269 = r549268 * r549268;
        double r549270 = r549265 + r549269;
        return r549270;
}

Error

Bits error versus x

Bits error versus y

Bits error versus z

Bits error versus t

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original33.7
Target0.4
Herbie0.5
\[{\left(\frac{x}{y}\right)}^{2} + {\left(\frac{z}{t}\right)}^{2}\]

Derivation

  1. Initial program 33.7

    \[\frac{x \cdot x}{y \cdot y} + \frac{z \cdot z}{t \cdot t}\]
  2. Using strategy rm
  3. Applied add-sqr-sqrt33.8

    \[\leadsto \color{blue}{\sqrt{\frac{x \cdot x}{y \cdot y}} \cdot \sqrt{\frac{x \cdot x}{y \cdot y}}} + \frac{z \cdot z}{t \cdot t}\]
  4. Simplified33.8

    \[\leadsto \color{blue}{\left|\frac{x}{y}\right|} \cdot \sqrt{\frac{x \cdot x}{y \cdot y}} + \frac{z \cdot z}{t \cdot t}\]
  5. Simplified18.8

    \[\leadsto \left|\frac{x}{y}\right| \cdot \color{blue}{\left|\frac{x}{y}\right|} + \frac{z \cdot z}{t \cdot t}\]
  6. Using strategy rm
  7. Applied times-frac0.4

    \[\leadsto \left|\frac{x}{y}\right| \cdot \left|\frac{x}{y}\right| + \color{blue}{\frac{z}{t} \cdot \frac{z}{t}}\]
  8. Using strategy rm
  9. Applied add-sqr-sqrt0.5

    \[\leadsto \left|\frac{x}{y}\right| \cdot \color{blue}{\left(\sqrt{\left|\frac{x}{y}\right|} \cdot \sqrt{\left|\frac{x}{y}\right|}\right)} + \frac{z}{t} \cdot \frac{z}{t}\]
  10. Applied associate-*r*0.5

    \[\leadsto \color{blue}{\left(\left|\frac{x}{y}\right| \cdot \sqrt{\left|\frac{x}{y}\right|}\right) \cdot \sqrt{\left|\frac{x}{y}\right|}} + \frac{z}{t} \cdot \frac{z}{t}\]
  11. Simplified0.6

    \[\leadsto \color{blue}{{\left(\sqrt{\left|\frac{x}{y}\right|}\right)}^{3}} \cdot \sqrt{\left|\frac{x}{y}\right|} + \frac{z}{t} \cdot \frac{z}{t}\]
  12. Using strategy rm
  13. Applied pow1/20.6

    \[\leadsto {\color{blue}{\left({\left(\left|\frac{x}{y}\right|\right)}^{\frac{1}{2}}\right)}}^{3} \cdot \sqrt{\left|\frac{x}{y}\right|} + \frac{z}{t} \cdot \frac{z}{t}\]
  14. Applied pow-pow0.5

    \[\leadsto \color{blue}{{\left(\left|\frac{x}{y}\right|\right)}^{\left(\frac{1}{2} \cdot 3\right)}} \cdot \sqrt{\left|\frac{x}{y}\right|} + \frac{z}{t} \cdot \frac{z}{t}\]
  15. Simplified0.5

    \[\leadsto {\left(\left|\frac{x}{y}\right|\right)}^{\color{blue}{\frac{3}{2}}} \cdot \sqrt{\left|\frac{x}{y}\right|} + \frac{z}{t} \cdot \frac{z}{t}\]
  16. Final simplification0.5

    \[\leadsto {\left(\left|\frac{x}{y}\right|\right)}^{\frac{3}{2}} \cdot \sqrt{\left|\frac{x}{y}\right|} + \frac{z}{t} \cdot \frac{z}{t}\]

Reproduce

herbie shell --seed 2019326 
(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))))