Average Error: 33.7 → 0.5
Time: 14.4s
Precision: 64
\[\frac{x \cdot x}{y \cdot y} + \frac{z \cdot z}{t \cdot t}\]
\[\frac{x}{y} \cdot \frac{x}{y} + {\left(\left|\frac{z}{t}\right|\right)}^{\frac{3}{2}} \cdot \sqrt{\left|\frac{z}{t}\right|}\]
\frac{x \cdot x}{y \cdot y} + \frac{z \cdot z}{t \cdot t}
\frac{x}{y} \cdot \frac{x}{y} + {\left(\left|\frac{z}{t}\right|\right)}^{\frac{3}{2}} \cdot \sqrt{\left|\frac{z}{t}\right|}
double f(double x, double y, double z, double t) {
        double r437011 = x;
        double r437012 = r437011 * r437011;
        double r437013 = y;
        double r437014 = r437013 * r437013;
        double r437015 = r437012 / r437014;
        double r437016 = z;
        double r437017 = r437016 * r437016;
        double r437018 = t;
        double r437019 = r437018 * r437018;
        double r437020 = r437017 / r437019;
        double r437021 = r437015 + r437020;
        return r437021;
}

double f(double x, double y, double z, double t) {
        double r437022 = x;
        double r437023 = y;
        double r437024 = r437022 / r437023;
        double r437025 = r437024 * r437024;
        double r437026 = z;
        double r437027 = t;
        double r437028 = r437026 / r437027;
        double r437029 = fabs(r437028);
        double r437030 = 1.5;
        double r437031 = pow(r437029, r437030);
        double r437032 = sqrt(r437029);
        double r437033 = r437031 * r437032;
        double r437034 = r437025 + r437033;
        return r437034;
}

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 \frac{x \cdot x}{y \cdot y} + \color{blue}{\sqrt{\frac{z \cdot z}{t \cdot t}} \cdot \sqrt{\frac{z \cdot z}{t \cdot t}}}\]
  4. Simplified33.8

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

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

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

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

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

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

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

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

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

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

Reproduce

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