


Bits error versus re



Bits error versus im
Results
Initial program 31.2
Initial simplification0.6
rmApplied add-sqr-sqrt0.6
Applied *-un-lft-identity0.6
Applied times-frac0.6
rmApplied div-inv0.4
Applied associate-*r*0.4
Final simplification0.4
herbie shell --seed 2018362 +o rules:numerics
(FPCore (re im)
:name "math.log10 on complex, real part"
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10)))
Time bar (total: 17.8s)Debug log
1 alts after pruning (1 fresh and 0 done)
Merged error: 0.6b
Found 2 expressions with local error:
| 0.6b | (/ (log (hypot re im)) (log 10)) |
| 0.0b | (hypot re im) |
2 calls. Slowest were:
| 11.0ms | (/ (log (hypot re im)) (log 10)) |
| 0.0ms | (hypot re im) |
2 calls. Slowest were:
| 136.0ms | (/ (log (hypot re im)) (log 10)) |
| 26.0ms | (hypot re im) |
37 calls. Slowest were:
| 173.0ms | (/ (* (* (log (hypot re im)) (log (hypot re im))) (log (hypot re im))) (* (* (log 10) (log 10)) (log 10))) |
| 94.0ms | (* -1 (/ (log (/ -1 re)) (log 10))) |
| 94.0ms | (* -1 (/ (log (/ 1 re)) (log 10))) |
13 alts after pruning (13 fresh and 0 done)
Merged error: 0.1b
Found 3 expressions with local error:
| 0.5b | (/ (log (hypot re im)) (sqrt (log 10))) |
| 0.3b | (* (/ 1 (sqrt (log 10))) (/ (log (hypot re im)) (sqrt (log 10)))) |
| 0.0b | (hypot re im) |
3 calls. Slowest were:
| 8.0ms | (* (/ 1 (sqrt (log 10))) (/ (log (hypot re im)) (sqrt (log 10)))) |
| 6.0ms | (/ (log (hypot re im)) (sqrt (log 10))) |
| 0.0ms | (hypot re im) |
3 calls. Slowest were:
| 232.0ms | (/ (log (hypot re im)) (sqrt (log 10))) |
| 168.0ms | (* (/ 1 (sqrt (log 10))) (/ (log (hypot re im)) (sqrt (log 10)))) |
| 41.0ms | (hypot re im) |
108 calls. Slowest were:
| 440.0ms | (* (* (* (/ 1 (sqrt (log 10))) (/ 1 (sqrt (log 10)))) (/ 1 (sqrt (log 10)))) (* (* (/ (log (hypot re im)) (sqrt (log 10))) (/ (log (hypot re im)) (sqrt (log 10)))) (/ (log (hypot re im)) (sqrt (log 10))))) |
| 135.0ms | (* (* (* (/ 1 (sqrt (log 10))) (/ 1 (sqrt (log 10)))) (/ 1 (sqrt (log 10)))) (/ (* (* (log (hypot re im)) (log (hypot re im))) (log (hypot re im))) (* (* (sqrt (log 10)) (sqrt (log 10))) (sqrt (log 10))))) |
| 132.0ms | (+ (log (/ 1 (sqrt (log 10)))) (log (/ (log (hypot re im)) (sqrt (log 10))))) |
15 alts after pruning (15 fresh and 0 done)
Merged error: 0.0b
Found 3 expressions with local error:
| 0.3b | (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (/ 1 (sqrt (log 10)))) |
| 0.2b | (* (/ 1 (sqrt (log 10))) (log (hypot re im))) |
| 0.0b | (hypot re im) |
3 calls. Slowest were:
| 15.0ms | (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (/ 1 (sqrt (log 10)))) |
| 6.0ms | (* (/ 1 (sqrt (log 10))) (log (hypot re im))) |
| 0.0ms | (hypot re im) |
3 calls. Slowest were:
| 186.0ms | (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (/ 1 (sqrt (log 10)))) |
| 182.0ms | (* (/ 1 (sqrt (log 10))) (log (hypot re im))) |
| 24.0ms | (hypot re im) |
46 calls. Slowest were:
| 302.0ms | (* (* (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (* (/ 1 (sqrt (log 10))) (log (hypot re im)))) (* (/ 1 (sqrt (log 10))) (log (hypot re im)))) (* (* (/ 1 (sqrt (log 10))) (/ 1 (sqrt (log 10)))) (/ 1 (sqrt (log 10))))) |
| 297.0ms | (* (* (* (/ 1 (sqrt (log 10))) (/ 1 (sqrt (log 10)))) (/ 1 (sqrt (log 10)))) (* (* (log (hypot re im)) (log (hypot re im))) (log (hypot re im)))) |
| 288.0ms | (* (* (* (* (/ 1 (sqrt (log 10))) (/ 1 (sqrt (log 10)))) (/ 1 (sqrt (log 10)))) (* (* (log (hypot re im)) (log (hypot re im))) (log (hypot re im)))) (* (* (/ 1 (sqrt (log 10))) (/ 1 (sqrt (log 10)))) (/ 1 (sqrt (log 10))))) |
11 alts after pruning (10 fresh and 1 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.3b | (* (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (sqrt (/ 1 (sqrt (log 10))))) (sqrt (/ 1 (sqrt (log 10))))) |
| 0.2b | (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (sqrt (/ 1 (sqrt (log 10))))) |
| 0.2b | (* (/ 1 (sqrt (log 10))) (log (hypot re im))) |
| 0.0b | (hypot re im) |
4 calls. Slowest were:
| 55.0ms | (* (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (sqrt (/ 1 (sqrt (log 10))))) (sqrt (/ 1 (sqrt (log 10))))) |
| 17.0ms | (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (sqrt (/ 1 (sqrt (log 10))))) |
| 6.0ms | (* (/ 1 (sqrt (log 10))) (log (hypot re im))) |
4 calls. Slowest were:
| 585.0ms | (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (sqrt (/ 1 (sqrt (log 10))))) |
| 207.0ms | (* (/ 1 (sqrt (log 10))) (log (hypot re im))) |
| 134.0ms | (* (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (sqrt (/ 1 (sqrt (log 10))))) (sqrt (/ 1 (sqrt (log 10))))) |
| 38.0ms | (hypot re im) |
76 calls. Slowest were:
| 603.0ms | (* (* (* (* (/ 1 (sqrt (log 10))) (/ 1 (sqrt (log 10)))) (/ 1 (sqrt (log 10)))) (* (* (log (hypot re im)) (log (hypot re im))) (log (hypot re im)))) (* (* (sqrt (/ 1 (sqrt (log 10)))) (sqrt (/ 1 (sqrt (log 10))))) (sqrt (/ 1 (sqrt (log 10)))))) |
| 510.0ms | (* (* (* (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (* (/ 1 (sqrt (log 10))) (log (hypot re im)))) (* (/ 1 (sqrt (log 10))) (log (hypot re im)))) (* (* (sqrt (/ 1 (sqrt (log 10)))) (sqrt (/ 1 (sqrt (log 10))))) (sqrt (/ 1 (sqrt (log 10)))))) |
| 384.0ms | (* (* (* (/ 1 (sqrt (log 10))) (/ 1 (sqrt (log 10)))) (/ 1 (sqrt (log 10)))) (* (* (log (hypot re im)) (log (hypot re im))) (log (hypot re im)))) |
10 alts after pruning (8 fresh and 2 done)
Merged error: 0b
0% (0.3b remaining)
Error of 0.4b against oracle of 0.0b and baseline of 0.4b