Average Error: 46.0 → 0.1
Time: 11.3s
Precision: 64
\[i \gt 0\]
\[\frac{\frac{\left(i \cdot i\right) \cdot \left(i \cdot i\right)}{\left(2 \cdot i\right) \cdot \left(2 \cdot i\right)}}{\left(2 \cdot i\right) \cdot \left(2 \cdot i\right) - 1.0}\]
\[\frac{\frac{1}{4}}{2 - \frac{\sqrt{1.0}}{i}} \cdot \frac{1}{2 + \frac{\sqrt{1.0}}{i}}\]
\frac{\frac{\left(i \cdot i\right) \cdot \left(i \cdot i\right)}{\left(2 \cdot i\right) \cdot \left(2 \cdot i\right)}}{\left(2 \cdot i\right) \cdot \left(2 \cdot i\right) - 1.0}
\frac{\frac{1}{4}}{2 - \frac{\sqrt{1.0}}{i}} \cdot \frac{1}{2 + \frac{\sqrt{1.0}}{i}}
double f(double i) {
        double r943808 = i;
        double r943809 = r943808 * r943808;
        double r943810 = r943809 * r943809;
        double r943811 = 2.0;
        double r943812 = r943811 * r943808;
        double r943813 = r943812 * r943812;
        double r943814 = r943810 / r943813;
        double r943815 = 1.0;
        double r943816 = r943813 - r943815;
        double r943817 = r943814 / r943816;
        return r943817;
}

double f(double i) {
        double r943818 = 0.25;
        double r943819 = 2.0;
        double r943820 = 1.0;
        double r943821 = sqrt(r943820);
        double r943822 = i;
        double r943823 = r943821 / r943822;
        double r943824 = r943819 - r943823;
        double r943825 = r943818 / r943824;
        double r943826 = 1.0;
        double r943827 = r943819 + r943823;
        double r943828 = r943826 / r943827;
        double r943829 = r943825 * r943828;
        return r943829;
}

Error

Bits error versus i

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Derivation

  1. Initial program 46.0

    \[\frac{\frac{\left(i \cdot i\right) \cdot \left(i \cdot i\right)}{\left(2 \cdot i\right) \cdot \left(2 \cdot i\right)}}{\left(2 \cdot i\right) \cdot \left(2 \cdot i\right) - 1.0}\]
  2. Simplified0.3

    \[\leadsto \color{blue}{\frac{\frac{1}{4}}{4 - \frac{1.0}{i \cdot i}}}\]
  3. Using strategy rm
  4. Applied add-sqr-sqrt0.3

    \[\leadsto \frac{\frac{1}{4}}{4 - \frac{\color{blue}{\sqrt{1.0} \cdot \sqrt{1.0}}}{i \cdot i}}\]
  5. Applied times-frac0.4

    \[\leadsto \frac{\frac{1}{4}}{4 - \color{blue}{\frac{\sqrt{1.0}}{i} \cdot \frac{\sqrt{1.0}}{i}}}\]
  6. Applied add-sqr-sqrt0.4

    \[\leadsto \frac{\frac{1}{4}}{\color{blue}{\sqrt{4} \cdot \sqrt{4}} - \frac{\sqrt{1.0}}{i} \cdot \frac{\sqrt{1.0}}{i}}\]
  7. Applied difference-of-squares0.4

    \[\leadsto \frac{\frac{1}{4}}{\color{blue}{\left(\sqrt{4} + \frac{\sqrt{1.0}}{i}\right) \cdot \left(\sqrt{4} - \frac{\sqrt{1.0}}{i}\right)}}\]
  8. Applied *-un-lft-identity0.4

    \[\leadsto \frac{\color{blue}{1 \cdot \frac{1}{4}}}{\left(\sqrt{4} + \frac{\sqrt{1.0}}{i}\right) \cdot \left(\sqrt{4} - \frac{\sqrt{1.0}}{i}\right)}\]
  9. Applied times-frac0.1

    \[\leadsto \color{blue}{\frac{1}{\sqrt{4} + \frac{\sqrt{1.0}}{i}} \cdot \frac{\frac{1}{4}}{\sqrt{4} - \frac{\sqrt{1.0}}{i}}}\]
  10. Final simplification0.1

    \[\leadsto \frac{\frac{1}{4}}{2 - \frac{\sqrt{1.0}}{i}} \cdot \frac{1}{2 + \frac{\sqrt{1.0}}{i}}\]

Reproduce

herbie shell --seed 2019128 +o rules:numerics
(FPCore (i)
  :name "Octave 3.8, jcobi/4, as called"
  :pre (and (> i 0))
  (/ (/ (* (* i i) (* i i)) (* (* 2 i) (* 2 i))) (- (* (* 2 i) (* 2 i)) 1.0)))