Average Error: 46.2 → 0.0
Time: 10.7s
Precision: 64
Internal Precision: 384
\[\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}\]
\[\begin{array}{l} \mathbf{if}\;i \le 206.34758396926534:\\ \;\;\;\;\frac{\frac{i}{2} \cdot \frac{i}{2}}{(\left(i + i\right) \cdot \left(i + i\right) + \left(-1.0\right))_*}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{16} + \left(\frac{0.00390625}{{i}^{4}} + \frac{\frac{0.015625}{i}}{i}\right)\\ \end{array}\]

Error

Bits error versus i

Derivation

  1. Split input into 2 regimes
  2. if i < 206.34758396926534

    1. Initial program 44.7

      \[\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. Applied simplify0.0

      \[\leadsto \color{blue}{\frac{\frac{i}{2} \cdot \frac{i}{2}}{(\left(i + i\right) \cdot \left(i + i\right) + \left(-1.0\right))_*}}\]

    if 206.34758396926534 < i

    1. Initial program 47.7

      \[\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. Applied simplify31.8

      \[\leadsto \color{blue}{\frac{\frac{i}{2} \cdot \frac{i}{2}}{(\left(i + i\right) \cdot \left(i + i\right) + \left(-1.0\right))_*}}\]
    3. Taylor expanded around inf 0.0

      \[\leadsto \color{blue}{0.00390625 \cdot \frac{1}{{i}^{4}} + \left(\frac{1}{16} + 0.015625 \cdot \frac{1}{{i}^{2}}\right)}\]
    4. Applied simplify0.0

      \[\leadsto \color{blue}{\frac{1}{16} + \left(\frac{0.00390625}{{i}^{4}} + \frac{\frac{0.015625}{i}}{i}\right)}\]
  3. Recombined 2 regimes into one program.

Runtime

Time bar (total: 10.7s)Debug logProfile

herbie shell --seed '#(1064300848 3212030778 2049303162 3567222883 2277747821 1384278011)' +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)))