


Bits error versus re



Bits error versus im
Results
Initial program 30.9
Initial simplification0.6
rmApplied add-sqr-sqrt0.6
Applied pow10.6
Applied log-pow0.6
Applied times-frac0.5
rmApplied associate-*r/0.5
Final simplification0.5
herbie shell --seed 2018360 +o rules:numerics
(FPCore (re im)
:name "math.log10 on complex, real part"
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10)))
Time bar (total: 12.1s)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:
| 27.0ms | (/ (log (hypot re im)) (log 10)) |
| 0.0ms | (hypot re im) |
2 calls. Slowest were:
| 139.0ms | (/ (log (hypot re im)) (log 10)) |
| 26.0ms | (hypot re im) |
37 calls. Slowest were:
| 136.0ms | (/ (* (* (log (hypot re im)) (log (hypot re im))) (log (hypot re im))) (* (* (log 10) (log 10)) (log 10))) |
| 95.0ms | (* -1 (/ (log (/ -1 re)) (log 10))) |
| 76.0ms | (* -1 (/ (log (/ 1 re)) (log 10))) |
12 alts after pruning (12 fresh and 0 done)
Merged error: 0.1b
Found 3 expressions with local error:
| 0.5b | (/ (log (hypot re im)) (sqrt (log 10))) |
| 0.2b | (* (/ 1 (sqrt (log 10))) (/ (log (hypot re im)) (sqrt (log 10)))) |
| 0.0b | (hypot re im) |
3 calls. Slowest were:
| 7.0ms | (* (/ 1 (sqrt (log 10))) (/ (log (hypot re im)) (sqrt (log 10)))) |
| 5.0ms | (/ (log (hypot re im)) (sqrt (log 10))) |
| 0.0ms | (hypot re im) |
3 calls. Slowest were:
| 183.0ms | (/ (log (hypot re im)) (sqrt (log 10))) |
| 177.0ms | (* (/ 1 (sqrt (log 10))) (/ (log (hypot re im)) (sqrt (log 10)))) |
| 39.0ms | (hypot re im) |
108 calls. Slowest were:
| 269.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))))) |
| 182.0ms | (/ (* (* (log (hypot re im)) (log (hypot re im))) (log (hypot re im))) (* (* (sqrt (log 10)) (sqrt (log 10))) (sqrt (log 10)))) |
| 124.0ms | (* -1 (/ (log (/ 1 re)) (log 10))) |
12 alts after pruning (12 fresh and 0 done)
Merged error: 0.0b
Found 3 expressions with local error:
| 0.5b | (/ (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (sqrt (log 10))) |
| 0.3b | (* (/ 1 (sqrt (log 10))) (log (hypot re im))) |
| 0.0b | (hypot re im) |
3 calls. Slowest were:
| 18.0ms | (/ (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (sqrt (log 10))) |
| 6.0ms | (* (/ 1 (sqrt (log 10))) (log (hypot re im))) |
| 0.0ms | (hypot re im) |
3 calls. Slowest were:
| 243.0ms | (* (/ 1 (sqrt (log 10))) (log (hypot re im))) |
| 166.0ms | (/ (* (/ 1 (sqrt (log 10))) (log (hypot re im))) (sqrt (log 10))) |
| 23.0ms | (hypot re im) |
51 calls. Slowest were:
| 977.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 (log 10)) (sqrt (log 10))) (sqrt (log 10)))) |
| 749.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)))) |
| 284.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)))) |
13 alts after pruning (12 fresh and 1 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.5b | (cbrt (hypot re im)) |
| 0.5b | (cbrt (hypot re im)) |
| 0.5b | (cbrt (hypot re im)) |
| 0.5b | (* (cbrt (hypot re im)) (cbrt (hypot re im))) |
4 calls. Slowest were:
| 6.0ms | (* (cbrt (hypot re im)) (cbrt (hypot re im))) |
| 1.0ms | (cbrt (hypot re im)) |
| 1.0ms | (cbrt (hypot re im)) |
4 calls. Slowest were:
| 153.0ms | (cbrt (hypot re im)) |
| 135.0ms | (cbrt (hypot re im)) |
| 131.0ms | (* (cbrt (hypot re im)) (cbrt (hypot re im))) |
| 127.0ms | (cbrt (hypot re im)) |
41 calls. Slowest were:
| 43.0ms | (+ (* 1/6 (* (pow re 2) (pow (/ 1 (pow im 5)) 1/3))) (pow im 1/3)) |
| 33.0ms | (+ (* 1/6 (* (pow re 2) (pow (/ 1 (pow im 5)) 1/3))) (pow im 1/3)) |
| 32.0ms | (+ (pow im 2/3) (* 1/3 (* (pow re 2) (pow (/ 1 (pow im 4)) 1/3)))) |
13 alts after pruning (11 fresh and 2 done)
Merged error: 0.0b
0% (0.5b remaining)
Error of 0.5b against oracle of 0.0b and baseline of 0.5b