Average Error: 0.2 → 0.0
Time: 16.7s
Precision: 64
\[\frac{6 \cdot \left(x - 1\right)}{\left(x + 1\right) + 4 \cdot \sqrt{x}}\]
\[6 \cdot \frac{x - 1}{\mathsf{fma}\left(\sqrt{x}, 4, x + 1\right)}\]
\frac{6 \cdot \left(x - 1\right)}{\left(x + 1\right) + 4 \cdot \sqrt{x}}
6 \cdot \frac{x - 1}{\mathsf{fma}\left(\sqrt{x}, 4, x + 1\right)}
double f(double x) {
        double r480318 = 6.0;
        double r480319 = x;
        double r480320 = 1.0;
        double r480321 = r480319 - r480320;
        double r480322 = r480318 * r480321;
        double r480323 = r480319 + r480320;
        double r480324 = 4.0;
        double r480325 = sqrt(r480319);
        double r480326 = r480324 * r480325;
        double r480327 = r480323 + r480326;
        double r480328 = r480322 / r480327;
        return r480328;
}

double f(double x) {
        double r480329 = 6.0;
        double r480330 = x;
        double r480331 = 1.0;
        double r480332 = r480330 - r480331;
        double r480333 = sqrt(r480330);
        double r480334 = 4.0;
        double r480335 = r480330 + r480331;
        double r480336 = fma(r480333, r480334, r480335);
        double r480337 = r480332 / r480336;
        double r480338 = r480329 * r480337;
        return r480338;
}

Error

Bits error versus x

Target

Original0.2
Target0.0
Herbie0.0
\[\frac{6}{\frac{\left(x + 1\right) + 4 \cdot \sqrt{x}}{x - 1}}\]

Derivation

  1. Initial program 0.2

    \[\frac{6 \cdot \left(x - 1\right)}{\left(x + 1\right) + 4 \cdot \sqrt{x}}\]
  2. Simplified0.0

    \[\leadsto \color{blue}{\frac{6}{\frac{\mathsf{fma}\left(\sqrt{x}, 4, x + 1\right)}{x - 1}}}\]
  3. Using strategy rm
  4. Applied div-inv0.1

    \[\leadsto \color{blue}{6 \cdot \frac{1}{\frac{\mathsf{fma}\left(\sqrt{x}, 4, x + 1\right)}{x - 1}}}\]
  5. Simplified0.0

    \[\leadsto 6 \cdot \color{blue}{\frac{x - 1}{\mathsf{fma}\left(\sqrt{x}, 4, x + 1\right)}}\]
  6. Final simplification0.0

    \[\leadsto 6 \cdot \frac{x - 1}{\mathsf{fma}\left(\sqrt{x}, 4, x + 1\right)}\]

Reproduce

herbie shell --seed 2019323 +o rules:numerics
(FPCore (x)
  :name "Data.Approximate.Numerics:blog from approximate-0.2.2.1"
  :precision binary64

  :herbie-target
  (/ 6 (/ (+ (+ x 1) (* 4 (sqrt x))) (- x 1)))

  (/ (* 6 (- x 1)) (+ (+ x 1) (* 4 (sqrt x)))))