Average Error: 20.0 → 0.3
Time: 20.6s
Precision: 64
\[\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}\]
\[\frac{\sqrt[3]{1} \cdot \sqrt[3]{1}}{\sqrt{x}} \cdot \frac{\sqrt[3]{1}}{\mathsf{fma}\left(\sqrt{x + 1}, \sqrt{x} \cdot 1, 1 \cdot \left(x + 1\right)\right)}\]
\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}
\frac{\sqrt[3]{1} \cdot \sqrt[3]{1}}{\sqrt{x}} \cdot \frac{\sqrt[3]{1}}{\mathsf{fma}\left(\sqrt{x + 1}, \sqrt{x} \cdot 1, 1 \cdot \left(x + 1\right)\right)}
double f(double x) {
        double r6817580 = 1.0;
        double r6817581 = x;
        double r6817582 = sqrt(r6817581);
        double r6817583 = r6817580 / r6817582;
        double r6817584 = r6817581 + r6817580;
        double r6817585 = sqrt(r6817584);
        double r6817586 = r6817580 / r6817585;
        double r6817587 = r6817583 - r6817586;
        return r6817587;
}

double f(double x) {
        double r6817588 = 1.0;
        double r6817589 = cbrt(r6817588);
        double r6817590 = r6817589 * r6817589;
        double r6817591 = x;
        double r6817592 = sqrt(r6817591);
        double r6817593 = r6817590 / r6817592;
        double r6817594 = r6817591 + r6817588;
        double r6817595 = sqrt(r6817594);
        double r6817596 = r6817592 * r6817588;
        double r6817597 = r6817588 * r6817594;
        double r6817598 = fma(r6817595, r6817596, r6817597);
        double r6817599 = r6817589 / r6817598;
        double r6817600 = r6817593 * r6817599;
        return r6817600;
}

Error

Bits error versus x

Target

Original20.0
Target0.8
Herbie0.3
\[\frac{1}{\left(x + 1\right) \cdot \sqrt{x} + x \cdot \sqrt{x + 1}}\]

Derivation

  1. Initial program 20.0

    \[\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}\]
  2. Using strategy rm
  3. Applied frac-sub20.0

    \[\leadsto \color{blue}{\frac{1 \cdot \sqrt{x + 1} - \sqrt{x} \cdot 1}{\sqrt{x} \cdot \sqrt{x + 1}}}\]
  4. Using strategy rm
  5. Applied flip--19.8

    \[\leadsto \frac{\color{blue}{\frac{\left(1 \cdot \sqrt{x + 1}\right) \cdot \left(1 \cdot \sqrt{x + 1}\right) - \left(\sqrt{x} \cdot 1\right) \cdot \left(\sqrt{x} \cdot 1\right)}{1 \cdot \sqrt{x + 1} + \sqrt{x} \cdot 1}}}{\sqrt{x} \cdot \sqrt{x + 1}}\]
  6. Taylor expanded around 0 0.4

    \[\leadsto \frac{\frac{\color{blue}{1}}{1 \cdot \sqrt{x + 1} + \sqrt{x} \cdot 1}}{\sqrt{x} \cdot \sqrt{x + 1}}\]
  7. Using strategy rm
  8. Applied *-un-lft-identity0.4

    \[\leadsto \frac{\frac{1}{\color{blue}{1 \cdot \left(1 \cdot \sqrt{x + 1} + \sqrt{x} \cdot 1\right)}}}{\sqrt{x} \cdot \sqrt{x + 1}}\]
  9. Applied add-cube-cbrt0.4

    \[\leadsto \frac{\frac{\color{blue}{\left(\sqrt[3]{1} \cdot \sqrt[3]{1}\right) \cdot \sqrt[3]{1}}}{1 \cdot \left(1 \cdot \sqrt{x + 1} + \sqrt{x} \cdot 1\right)}}{\sqrt{x} \cdot \sqrt{x + 1}}\]
  10. Applied times-frac0.4

    \[\leadsto \frac{\color{blue}{\frac{\sqrt[3]{1} \cdot \sqrt[3]{1}}{1} \cdot \frac{\sqrt[3]{1}}{1 \cdot \sqrt{x + 1} + \sqrt{x} \cdot 1}}}{\sqrt{x} \cdot \sqrt{x + 1}}\]
  11. Applied times-frac0.4

    \[\leadsto \color{blue}{\frac{\frac{\sqrt[3]{1} \cdot \sqrt[3]{1}}{1}}{\sqrt{x}} \cdot \frac{\frac{\sqrt[3]{1}}{1 \cdot \sqrt{x + 1} + \sqrt{x} \cdot 1}}{\sqrt{x + 1}}}\]
  12. Simplified0.4

    \[\leadsto \color{blue}{\frac{\sqrt[3]{1} \cdot \sqrt[3]{1}}{\sqrt{x}}} \cdot \frac{\frac{\sqrt[3]{1}}{1 \cdot \sqrt{x + 1} + \sqrt{x} \cdot 1}}{\sqrt{x + 1}}\]
  13. Simplified0.3

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

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

Reproduce

herbie shell --seed 2019172 +o rules:numerics
(FPCore (x)
  :name "2isqrt (example 3.6)"

  :herbie-target
  (/ 1.0 (+ (* (+ x 1.0) (sqrt x)) (* x (sqrt (+ x 1.0)))))

  (- (/ 1.0 (sqrt x)) (/ 1.0 (sqrt (+ x 1.0)))))