


Bits error versus N
if N < 8308.083087599556Initial program 0.1
Simplified0.1
rmApplied log1p-udef0.1
Applied diff-log0.1
if 8308.083087599556 < N Initial program 59.4
Simplified59.4
rmApplied log1p-udef59.4
Applied diff-log59.2
Taylor expanded around -inf 0.0
Simplified0.0
Final simplification0.1
herbie shell --seed 2019016 +o rules:numerics
(FPCore (N)
:name "2log (problem 3.3.6)"
(- (log (+ N 1)) (log N)))
Time bar (total: 14.1s)Debug log
| 573× | (pre true 80) |
| 316× | (body nan 80) |
| 137× | (body real 80) |
| 60× | (body real 1280) |
| 39× | (body real 640) |
| 13× | (body real 320) |
| 8× | (body real 160) |
| 8.0ms | (- (log (+ N 1)) (log N)) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 28.1b
Found 1 expressions with local error:
| 2.5b | (- (log1p N) (log N)) |
| 10× | *-un-lft-identity |
| 10× | add-sqr-sqrt |
| 9× | prod-diff |
| 8× | add-cube-cbrt |
| 3× | fma-neg |
| 2× | add-log-exp |
| 2× | diff-log |
| 1× | difference-of-squares |
| 1× | distribute-lft-out-- |
| 1× | flip-- |
| 1× | log1p-expm1-u |
| 1× | add-exp-log |
| 1× | add-cbrt-cube |
| 1× | flip3-- |
| 1× | sub-neg |
| 1× | log1p-udef |
| 1× | pow1 |
| 1× | expm1-log1p-u |
| 8.0ms | (- (log1p N) (log N)) |
| 73.0ms | (- (log1p N) (log N)) |
| 172.0ms | (- (+ (* 1/3 (/ 1 (pow N 3))) (/ 1 N)) (* 1/2 (/ 1 (pow N 2)))) |
| 170.0ms | (- (+ (* 1/3 (/ 1 (pow N 3))) (/ 1 N)) (* 1/2 (/ 1 (pow N 2)))) |
| 89.0ms | (- N (+ (log N) (* 1/2 (pow N 2)))) |
| 37.0ms | (fma 1 (log1p N) (- (* (log N) 1))) |
| 32.0ms | (fma (sqrt (log1p N)) (sqrt (log1p N)) (- (* (sqrt (log N)) (sqrt (log N))))) |
4 alts after pruning (4 fresh and 0 done)
Merged error: 0.0b
Found 2 expressions with local error:
| 2.3b | (log (/ (+ 1 N) N)) |
| 0.0b | (/ (+ 1 N) N) |
| 4× | add-cube-cbrt |
| 4× | *-un-lft-identity |
| 4× | log-prod |
| 4× | add-sqr-sqrt |
| 3× | associate-/l* |
| 3× | add-exp-log |
| 3× | pow1 |
| 2× | associate-/l/ |
| 2× | add-log-exp |
| 2× | div-inv |
| 2× | log1p-expm1-u |
| 2× | add-cbrt-cube |
| 2× | expm1-log1p-u |
| 1× | flip-+ |
| 1× | log-pow |
| 1× | rem-log-exp |
| 1× | flip3-+ |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | log-div |
| 5.0ms | (/ (+ 1 N) N) |
| 2.0ms | (log (/ (+ 1 N) N)) |
| 40.0ms | (log (/ (+ 1 N) N)) |
| 19.0ms | (/ (+ 1 N) N) |
| 202.0ms | (- (+ (* 1/3 (/ 1 (pow N 3))) (/ 1 N)) (* 1/2 (/ 1 (pow N 2)))) |
| 196.0ms | (- (+ (* 1/3 (/ 1 (pow N 3))) (/ 1 N)) (* 1/2 (/ 1 (pow N 2)))) |
| 96.0ms | (- N (+ (log N) (* 1/2 (pow N 2)))) |
| 6.0ms | (- (* 1 1) (* N N)) |
| 5.0ms | (+ (pow 1 3) (pow N 3)) |
4 alts after pruning (3 fresh and 1 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 2.4b | (log (cbrt (/ (+ 1 N) N))) |
| 2.3b | (log (* (cbrt (/ (+ 1 N) N)) (cbrt (/ (+ 1 N) N)))) |
| 0.3b | (cbrt (/ (+ 1 N) N)) |
| 0.3b | (cbrt (/ (+ 1 N) N)) |
| 12× | cbrt-prod |
| 11× | pow1 |
| 9× | log-pow |
| 8× | add-cube-cbrt |
| 8× | add-exp-log |
| 8× | *-un-lft-identity |
| 8× | log-prod |
| 8× | add-sqr-sqrt |
| 7× | pow1/3 |
| 7× | cbrt-div |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | add-cbrt-cube |
| 4× | log-div |
| 4× | expm1-log1p-u |
| 3× | div-inv |
| 3× | rem-log-exp |
| 2× | pow-prod-up |
| 2× | pow-prod-down |
| 1× | associate-*r/ |
| 1× | prod-exp |
| 1× | associate-*l/ |
| 1× | pow-plus |
| 1× | frac-times |
| 1× | pow2 |
| 10.0ms | (log (* (cbrt (/ (+ 1 N) N)) (cbrt (/ (+ 1 N) N)))) |
| 3.0ms | (log (cbrt (/ (+ 1 N) N))) |
| 1.0ms | (cbrt (/ (+ 1 N) N)) |
| 1.0ms | (cbrt (/ (+ 1 N) N)) |
| 99.0ms | (log (cbrt (/ (+ 1 N) N))) |
| 80.0ms | (log (* (cbrt (/ (+ 1 N) N)) (cbrt (/ (+ 1 N) N)))) |
| 59.0ms | (cbrt (/ (+ 1 N) N)) |
| 59.0ms | (cbrt (/ (+ 1 N) N)) |
| 341.0ms | (- (+ (log (* (cbrt -1) (pow -1 1/3))) (* 1/3 (/ 1 N))) (* 1/6 (/ 1 (pow N 2)))) |
| 229.0ms | (- (+ (* (cbrt -1) (pow -1 1/3)) (* 1/3 (* (/ (cbrt -1) N) (pow -1 1/3)))) (* 1/9 (* (/ (cbrt -1) (pow N 2)) (pow -1 1/3)))) |
| 219.0ms | (- (+ (* 1/9 (/ 1 (pow N 3))) (* 1/3 (/ 1 N))) (* 1/6 (/ 1 (pow N 2)))) |
| 207.0ms | (- (+ (* 2/9 (/ 1 (pow N 3))) (* 2/3 (/ 1 N))) (* 1/3 (/ 1 (pow N 2)))) |
| 203.0ms | (- (+ (* 2/3 (/ 1 N)) (log (pow (cbrt -1) 2))) (* 1/3 (/ 1 (pow N 2)))) |
4 alts after pruning (3 fresh and 1 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 28.2b | (fma (* (cbrt (log1p N)) (cbrt (log1p N))) (cbrt (log1p N)) (- (log N))) |
| 0.5b | (cbrt (log1p N)) |
| 0.5b | (cbrt (log1p N)) |
| 0.5b | (cbrt (log1p N)) |
| 9× | cbrt-prod |
| 7× | add-cube-cbrt |
| 7× | *-un-lft-identity |
| 7× | add-sqr-sqrt |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | add-exp-log |
| 4× | add-cbrt-cube |
| 4× | pow1 |
| 4× | expm1-log1p-u |
| 3× | pow1/3 |
| 1× | fma-udef |
| 1.0ms | (cbrt (log1p N)) |
| 1.0ms | (cbrt (log1p N)) |
| 1.0ms | (cbrt (log1p N)) |
| 0.0ms | (fma (* (cbrt (log1p N)) (cbrt (log1p N))) (cbrt (log1p N)) (- (log N))) |
| 322.0ms | (fma (* (cbrt (log1p N)) (cbrt (log1p N))) (cbrt (log1p N)) (- (log N))) |
| 57.0ms | (cbrt (log1p N)) |
| 46.0ms | (cbrt (log1p N)) |
| 46.0ms | (cbrt (log1p N)) |
| 618.0ms | (- (+ (pow (- (log -1) (log (/ -1 N))) 1/3) (* 1/3 (* (pow (/ 1 (pow (- (log -1) (log (/ -1 N))) 2)) 1/3) (/ 1 N)))) (+ (* 1/9 (* (pow (/ 1 (pow (- (log -1) (log (/ -1 N))) 5)) 1/3) (/ 1 (pow N 2)))) (* 1/6 (* (pow (/ 1 (pow (- (log -1) (log (/ -1 N))) 2)) 1/3) (/ 1 (pow N 2)))))) |
| 550.0ms | (- (+ (pow (- (log -1) (log (/ -1 N))) 1/3) (* 1/3 (* (pow (/ 1 (pow (- (log -1) (log (/ -1 N))) 2)) 1/3) (/ 1 N)))) (+ (* 1/9 (* (pow (/ 1 (pow (- (log -1) (log (/ -1 N))) 5)) 1/3) (/ 1 (pow N 2)))) (* 1/6 (* (pow (/ 1 (pow (- (log -1) (log (/ -1 N))) 2)) 1/3) (/ 1 (pow N 2)))))) |
| 529.0ms | (- (+ (pow (- (log -1) (log (/ -1 N))) 1/3) (* 1/3 (* (pow (/ 1 (pow (- (log -1) (log (/ -1 N))) 2)) 1/3) (/ 1 N)))) (+ (* 1/9 (* (pow (/ 1 (pow (- (log -1) (log (/ -1 N))) 5)) 1/3) (/ 1 (pow N 2)))) (* 1/6 (* (pow (/ 1 (pow (- (log -1) (log (/ -1 N))) 2)) 1/3) (/ 1 (pow N 2)))))) |
| 434.0ms | (- (+ (pow (- (log (/ 1 N))) 1/3) (* 1/6 (* (pow (/ -1 (pow (log (/ 1 N)) 2)) 1/3) (/ 1 (pow N 2))))) (+ (* 1/9 (* (pow (/ -1 (pow (log (/ 1 N)) 5)) 1/3) (/ 1 (pow N 2)))) (* 1/3 (* (pow (/ -1 (pow (log (/ 1 N)) 2)) 1/3) (/ 1 N))))) |
| 425.0ms | (- (+ (pow (- (log (/ 1 N))) 1/3) (* 1/6 (* (pow (/ -1 (pow (log (/ 1 N)) 2)) 1/3) (/ 1 (pow N 2))))) (+ (* 1/9 (* (pow (/ -1 (pow (log (/ 1 N)) 5)) 1/3) (/ 1 (pow N 2)))) (* 1/3 (* (pow (/ -1 (pow (log (/ 1 N)) 2)) 1/3) (/ 1 N))))) |
4 alts after pruning (2 fresh and 2 done)
Merged error: 0.0b
100% (0.0b remaining)
Error of 0.1b against oracle of 0.0b and baseline of 29.1b
| 16094× | (pre true 80) |
| 8093× | (body nan 80) |
| 4114× | (body real 80) |
| 1765× | (body real 1280) |
| 1214× | (body real 640) |
| 612× | (body real 320) |
| 296× | (body real 160) |