


Bits error versus re



Bits error versus im
Results
if re < -3.423353045456592e+72Initial program 46.6
rmApplied pow1/246.6
Applied log-pow46.6
Applied associate-/l*46.6
rmApplied *-un-lft-identity46.6
Applied add-sqr-sqrt46.6
Applied times-frac46.7
Applied associate-/r*46.6
Taylor expanded around -inf 10.8
Simplified10.8
if -3.423353045456592e+72 < re < -2.722618750454037e-200 or -2.471056064955377e-233 < re < 1.2329804060890975e+141Initial program 20.9
rmApplied pow1/220.9
Applied log-pow20.9
Applied associate-/l*20.9
rmApplied *-un-lft-identity20.9
Applied add-sqr-sqrt20.9
Applied times-frac21.1
Applied associate-/r*20.9
rmApplied div-inv20.9
Applied add-sqr-sqrt20.9
Applied times-frac20.8
Simplified20.8
Simplified20.7
rmApplied associate-*l/20.8
Simplified20.9
if -2.722618750454037e-200 < re < -2.471056064955377e-233Initial program 29.8
rmApplied pow1/229.8
Applied log-pow29.8
Applied associate-/l*29.8
rmApplied *-un-lft-identity29.8
Applied add-sqr-sqrt29.8
Applied times-frac30.0
Applied associate-/r*29.8
rmApplied div-inv29.8
Applied add-sqr-sqrt29.8
Applied times-frac29.7
Simplified29.7
Simplified29.7
Taylor expanded around -inf 36.5
Simplified36.5
if 1.2329804060890975e+141 < re Initial program 58.5
rmApplied pow1/258.5
Applied log-pow58.5
Applied associate-/l*58.5
rmApplied *-un-lft-identity58.5
Applied add-sqr-sqrt58.5
Applied times-frac58.5
Applied associate-/r*58.5
rmApplied div-inv58.5
Applied add-sqr-sqrt58.5
Applied times-frac58.5
Simplified58.5
Simplified58.5
Taylor expanded around 0 6.8
Final simplification17.6
herbie shell --seed 2019018
(FPCore (re im)
:name "math.log10 on complex, real part"
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10)))
Time bar (total: 39.7s)Debug log
| 44.0ms | 256× | body | 80 | valid |
| 19.0ms | (/ (log (sqrt (+ (* re re) (* im im)))) (log 10)) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 27.5b
Found 3 expressions with local error:
| 26.2b | (sqrt (+ (* re re) (* im im))) |
| 0.6b | (/ (log (sqrt (+ (* re re) (* im im)))) (log 10)) |
| 0.0b | (+ (* re re) (* im im)) |
| 15× | times-frac |
| 15× | add-sqr-sqrt |
| 14× | add-cube-cbrt |
| 14× | *-un-lft-identity |
| 8× | log-pow |
| 7× | pow1 |
| 5× | add-log-exp |
| 5× | associate-/l* |
| 5× | add-exp-log |
| 5× | pow1/2 |
| 5× | add-cbrt-cube |
| 4× | sqrt-div |
| 3× | flip-+ |
| 3× | sqrt-prod |
| 3× | flip3-+ |
| 3× | associate-/r* |
| 2× | div-sub |
| 2× | log-div |
| 1× | div-inv |
| 1× | div-exp |
| 1× | frac-2neg |
| 1× | sum-log |
| 1× | clear-num |
| 1× | rem-sqrt-square |
| 1× | +-commutative |
| 1× | cbrt-undiv |
| 9.0ms | (/ (log (sqrt (+ (* re re) (* im im)))) (log 10)) |
| 3.0ms | (sqrt (+ (* re re) (* im im))) |
| 2.0ms | (+ (* re re) (* im im)) |
| 132.0ms | (/ (log (sqrt (+ (* re re) (* im im)))) (log 10)) |
| 29.0ms | (sqrt (+ (* re re) (* im im))) |
| 20.0ms | (+ (* re re) (* im im)) |
| 158.0ms | (/ (* (* (log (sqrt (+ (* re re) (* im im)))) (log (sqrt (+ (* re re) (* im im))))) (log (sqrt (+ (* re re) (* im im))))) (* (* (log 10) (log 10)) (log 10))) |
| 149.0ms | (sqrt (- (* (* re re) (* re re)) (* (* im im) (* im im)))) |
| 143.0ms | (/ (log (sqrt (- (* (* re re) (* re re)) (* (* im im) (* im im))))) (log 10)) |
| 84.0ms | (* -1 (/ (log (/ 1 re)) (log 10))) |
| 75.0ms | (* -1 (/ (log (/ -1 re)) (log 10))) |
13 alts after pruning (13 fresh and 0 done)
Merged error: 6.8b
Found 4 expressions with local error:
| 27.2b | (log (+ (* re re) (* im im))) |
| 0.5b | (/ (log 10) (log (+ (* re re) (* im im)))) |
| 0.3b | (/ 1/2 (/ (log 10) (log (+ (* re re) (* im im))))) |
| 0.0b | (+ (* re re) (* im im)) |
| 24× | times-frac |
| 22× | add-cube-cbrt |
| 22× | *-un-lft-identity |
| 22× | add-sqr-sqrt |
| 20× | associate-/r* |
| 12× | pow1 |
| 8× | log-pow |
| 7× | add-exp-log |
| 6× | add-log-exp |
| 6× | add-cbrt-cube |
| 3× | associate-/l* |
| 3× | div-inv |
| 3× | log-prod |
| 2× | flip-+ |
| 2× | flip3-+ |
| 2× | frac-2neg |
| 2× | clear-num |
| 2× | log-div |
| 1× | associate-/r/ |
| 1× | rem-log-exp |
| 1× | div-exp |
| 1× | sum-log |
| 1× | +-commutative |
| 1× | cbrt-undiv |
| 7.0ms | (/ (log 10) (log (+ (* re re) (* im im)))) |
| 3.0ms | (log (+ (* re re) (* im im))) |
| 2.0ms | (+ (* re re) (* im im)) |
| 1.0ms | (/ 1/2 (/ (log 10) (log (+ (* re re) (* im im))))) |
| 151.0ms | (/ (log 10) (log (+ (* re re) (* im im)))) |
| 134.0ms | (/ 1/2 (/ (log 10) (log (+ (* re re) (* im im))))) |
| 49.0ms | (log (+ (* re re) (* im im))) |
| 15.0ms | (+ (* re re) (* im im)) |
| 120.0ms | (/ (* (* (log 10) (log 10)) (log 10)) (* (* (log (+ (* re re) (* im im))) (log (+ (* re re) (* im im)))) (log (+ (* re re) (* im im))))) |
| 119.0ms | (* -1 (/ (log (/ 1 re)) (log 10))) |
| 115.0ms | (log (- (* (* re re) (* re re)) (* (* im im) (* im im)))) |
| 91.0ms | (* -1 (/ (log (/ -1 re)) (log 10))) |
| 50.0ms | (log (+ (pow (* re re) 3) (pow (* im im) 3))) |
15 alts after pruning (15 fresh and 0 done)
Merged error: 6.7b
Found 4 expressions with local error:
| 27.2b | (log (+ (* re re) (* im im))) |
| 0.4b | (/ (sqrt (log 10)) (log (+ (* re re) (* im im)))) |
| 0.3b | (/ (/ 1/2 (/ (sqrt (log 10)) 1)) (/ (sqrt (log 10)) (log (+ (* re re) (* im im))))) |
| 0.0b | (+ (* re re) (* im im)) |
| 308× | times-frac |
| 141× | add-cube-cbrt |
| 141× | *-un-lft-identity |
| 141× | add-sqr-sqrt |
| 87× | sqrt-prod |
| 48× | pow1 |
| 44× | log-pow |
| 37× | div-inv |
| 32× | associate-/r* |
| 30× | associate-/r/ |
| 12× | add-exp-log |
| 11× | associate-/l* |
| 11× | add-cbrt-cube |
| 6× | add-log-exp |
| 4× | div-exp |
| 4× | cbrt-undiv |
| 3× | log-prod |
| 2× | flip-+ |
| 2× | flip3-+ |
| 2× | frac-2neg |
| 2× | clear-num |
| 2× | log-div |
| 1× | associate-/l/ |
| 1× | rem-log-exp |
| 1× | sum-log |
| 1× | +-commutative |
| 9.0ms | (/ (/ 1/2 (/ (sqrt (log 10)) 1)) (/ (sqrt (log 10)) (log (+ (* re re) (* im im))))) |
| 7.0ms | (/ (sqrt (log 10)) (log (+ (* re re) (* im im)))) |
| 4.0ms | (+ (* re re) (* im im)) |
| 3.0ms | (log (+ (* re re) (* im im))) |
| 198.0ms | (/ (/ 1/2 (/ (sqrt (log 10)) 1)) (/ (sqrt (log 10)) (log (+ (* re re) (* im im))))) |
| 192.0ms | (/ (sqrt (log 10)) (log (+ (* re re) (* im im)))) |
| 64.0ms | (log (+ (* re re) (* im im))) |
| 25.0ms | (+ (* re re) (* im im)) |
| 680.0ms | (/ (/ 1/2 (sqrt (log 10))) (/ (sqrt 1) (* (cbrt (log (+ (* re re) (* im im)))) (cbrt (log (+ (* re re) (* im im))))))) |
| 437.0ms | (/ (/ 1/2 (sqrt (log 10))) (/ (* (cbrt (sqrt (log 10))) (cbrt (sqrt (log 10)))) (* (cbrt (log (+ (* re re) (* im im)))) (cbrt (log (+ (* re re) (* im im))))))) |
| 401.0ms | (/ (* (cbrt (/ 1/2 (/ (sqrt (log 10)) 1))) (cbrt (/ 1/2 (/ (sqrt (log 10)) 1)))) (/ (sqrt 1) (* (cbrt (log (+ (* re re) (* im im)))) (cbrt (log (+ (* re re) (* im im))))))) |
| 392.0ms | (/ (/ 1/2 (sqrt (log 10))) (/ 1 (* (cbrt (log (+ (* re re) (* im im)))) (cbrt (log (+ (* re re) (* im im))))))) |
| 349.0ms | (/ (* (cbrt (/ 1/2 (/ (sqrt (log 10)) 1))) (cbrt (/ 1/2 (/ (sqrt (log 10)) 1)))) (/ (* (cbrt (sqrt (log 10))) (cbrt (sqrt (log 10)))) (* (cbrt (log (+ (* re re) (* im im)))) (cbrt (log (+ (* re re) (* im im))))))) |
14 alts after pruning (14 fresh and 0 done)
Merged error: 6.7b
Found 4 expressions with local error:
| 27.2b | (log (+ (* im im) (* re re))) |
| 0.4b | (* (log (+ (* im im) (* re re))) (sqrt (/ 1/2 (sqrt (log 10))))) |
| 0.4b | (* (/ (sqrt (/ 1/2 (sqrt (log 10)))) (sqrt (log 10))) (* (log (+ (* im im) (* re re))) (sqrt (/ 1/2 (sqrt (log 10)))))) |
| 0.0b | (+ (* im im) (* re re)) |
| 50× | associate-*l* |
| 49× | sqrt-prod |
| 42× | times-frac |
| 35× | add-cube-cbrt |
| 35× | *-un-lft-identity |
| 35× | add-sqr-sqrt |
| 19× | add-exp-log |
| 18× | add-cbrt-cube |
| 13× | pow1 |
| 8× | div-inv |
| 8× | associate-*r* |
| 7× | cbrt-unprod |
| 7× | prod-exp |
| 6× | add-log-exp |
| 4× | associate-*r/ |
| 4× | pow-prod-down |
| 3× | sqrt-div |
| 3× | log-prod |
| 2× | flip-+ |
| 2× | *-commutative |
| 2× | log-pow |
| 2× | div-exp |
| 2× | flip3-+ |
| 2× | log-div |
| 2× | cbrt-undiv |
| 1× | associate-*l/ |
| 1× | rem-log-exp |
| 1× | sum-log |
| 1× | +-commutative |
| 1× | frac-times |
| 24.0ms | (* (/ (sqrt (/ 1/2 (sqrt (log 10)))) (sqrt (log 10))) (* (log (+ (* im im) (* re re))) (sqrt (/ 1/2 (sqrt (log 10)))))) |
| 5.0ms | (* (log (+ (* im im) (* re re))) (sqrt (/ 1/2 (sqrt (log 10))))) |
| 4.0ms | (+ (* im im) (* re re)) |
| 2.0ms | (log (+ (* im im) (* re re))) |
| 376.0ms | (* (log (+ (* im im) (* re re))) (sqrt (/ 1/2 (sqrt (log 10))))) |
| 177.0ms | (* (/ (sqrt (/ 1/2 (sqrt (log 10)))) (sqrt (log 10))) (* (log (+ (* im im) (* re re))) (sqrt (/ 1/2 (sqrt (log 10)))))) |
| 67.0ms | (log (+ (* im im) (* re re))) |
| 15.0ms | (+ (* im im) (* re re)) |
| 622.0ms | (* (* (* (/ (sqrt (/ 1/2 (sqrt (log 10)))) (sqrt (log 10))) (/ (sqrt (/ 1/2 (sqrt (log 10)))) (sqrt (log 10)))) (/ (sqrt (/ 1/2 (sqrt (log 10)))) (sqrt (log 10)))) (* (* (* (log (+ (* im im) (* re re))) (sqrt (/ 1/2 (sqrt (log 10))))) (* (log (+ (* im im) (* re re))) (sqrt (/ 1/2 (sqrt (log 10)))))) (* (log (+ (* im im) (* re re))) (sqrt (/ 1/2 (sqrt (log 10))))))) |
| 376.0ms | (* -2 (/ (* (log (/ -1 im)) (pow (sqrt 1/2) 2)) (log 10))) |
| 286.0ms | (* -2 (* (pow (/ 1 (log 10)) 1/4) (* (log (/ 1 im)) (sqrt 1/2)))) |
| 272.0ms | (* 2 (/ (* (log re) (pow (sqrt 1/2) 2)) (log 10))) |
| 240.0ms | (* (* (* (log (+ (* im im) (* re re))) (log (+ (* im im) (* re re)))) (log (+ (* im im) (* re re)))) (* (* (sqrt (/ 1/2 (sqrt (log 10)))) (sqrt (/ 1/2 (sqrt (log 10))))) (sqrt (/ 1/2 (sqrt (log 10)))))) |
16 alts after pruning (16 fresh and 0 done)
Merged error: 0.5b
43% (17.3b remaining)
Error of 17.6b against oracle of 0.3b and baseline of 30.7b
| 1.3s | 8000× | body | 80 | valid |