Average Error: 29.0 → 0.0
Time: 16.5s
Precision: 64
Internal Precision: 1600
\[\log \left(N + 1\right) - \log N\]
\[\log_* (1 + \frac{1}{N})\]

Error

Bits error versus N

Derivation

  1. Initial program 29.0

    \[\log \left(N + 1\right) - \log N\]
  2. Applied simplify29.0

    \[\leadsto \color{blue}{\log_* (1 + N) - \log N}\]
  3. Using strategy rm
  4. Applied log1p-udef29.0

    \[\leadsto \color{blue}{\log \left(1 + N\right)} - \log N\]
  5. Applied diff-log28.9

    \[\leadsto \color{blue}{\log \left(\frac{1 + N}{N}\right)}\]
  6. Taylor expanded around 0 28.9

    \[\leadsto \log \color{blue}{\left(1 + \frac{1}{N}\right)}\]
  7. Applied simplify0.0

    \[\leadsto \color{blue}{\log_* (1 + \frac{1}{N})}\]

Runtime

Time bar (total: 16.5s)Debug logProfile

herbie shell --seed '#(1071373924 2949776965 1885069702 3247780810 90874544 2263903749)' +o rules:numerics
(FPCore (N)
  :name "2log (problem 3.3.6)"
  (- (log (+ N 1)) (log N)))