


Bits error versus re



Bits error versus im



Bits error versus base
Results
if im < -3.1081298705219617e+147 or -1.40953206047104e-24 < im < 1.5692519200089908e-156 or 30377.714423513702 < im < 5827938310.190218Initial program 35.6
Simplified35.6
rmApplied times-frac35.5
Simplified35.5
rmApplied add-sqr-sqrt35.5
Taylor expanded around -inf 21.4
Simplified21.4
if -3.1081298705219617e+147 < im < -1.40953206047104e-24 or 1.5692519200089908e-156 < im < 30377.714423513702 or 5827938310.190218 < im < 8.022256849779051e+143Initial program 15.9
Simplified15.9
rmApplied times-frac15.8
Simplified15.8
rmApplied add-sqr-sqrt15.8
if 8.022256849779051e+143 < im Initial program 58.8
Simplified58.8
Taylor expanded around 0 6.8
Final simplification17.3
herbie shell --seed 2019016
(FPCore (re im base)
:name "math.log/2 on complex, real part"
(/ (+ (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (* (atan2 im re) 0)) (+ (* (log base) (log base)) (* 0 0))))
Time bar (total: 1.1m)Debug log
| 941× | (pre true 80) |
| 457× | (body nan 80) |
| 256× | (body real 80) |
| 228× | (body exit 10240) |
| 12.0ms | (/ (+ (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (* (atan2 im re) 0)) (+ (* (log base) (log base)) (* 0 0))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 27.6b
Found 4 expressions with local error:
| 26.2b | (sqrt (+ (* re re) (* im im))) |
| 0.5b | (* (log base) (log base)) |
| 0.4b | (* (log (sqrt (+ (* re re) (* im im)))) (log base)) |
| 0.3b | (/ (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (* (log base) (log base))) |
| 20× | add-exp-log |
| 20× | add-cbrt-cube |
| 12× | pow1 |
| 10× | add-sqr-sqrt |
| 9× | add-cube-cbrt |
| 9× | *-un-lft-identity |
| 8× | associate-*l* |
| 6× | cbrt-unprod |
| 6× | prod-exp |
| 6× | associate-*r* |
| 4× | add-log-exp |
| 4× | div-exp |
| 4× | cbrt-undiv |
| 3× | sqrt-prod |
| 2× | *-commutative |
| 2× | log-pow |
| 2× | pow-prod-down |
| 2× | sqrt-div |
| 2× | pow1/2 |
| 1× | associate-/l* |
| 1× | div-inv |
| 1× | flip-+ |
| 1× | pow-prod-up |
| 1× | pow-plus |
| 1× | times-frac |
| 1× | flip3-+ |
| 1× | frac-2neg |
| 1× | associate-/r* |
| 1× | clear-num |
| 1× | rem-sqrt-square |
| 1× | pow2 |
| 10.0ms | (/ (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (* (log base) (log base))) |
| 5.0ms | (* (log (sqrt (+ (* re re) (* im im)))) (log base)) |
| 4.0ms | (* (log base) (log base)) |
| 2.0ms | (sqrt (+ (* re re) (* im im))) |
| 173.0ms | (* (log base) (log base)) |
| 106.0ms | (/ (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (* (log base) (log base))) |
| 90.0ms | (* (log (sqrt (+ (* re re) (* im im)))) (log base)) |
| 27.0ms | (sqrt (+ (* re re) (* im im))) |
| 357.0ms | (- (+ (log (log (sqrt (+ (* re re) (* im im))))) (log (log base))) (+ (log (log base)) (log (log base)))) |
| 346.0ms | (- (+ (log (log (sqrt (+ (* re re) (* im im))))) (log (log base))) (log (* (log base) (log base)))) |
| 283.0ms | (* -1 (* (log (/ -1 re)) (- (log -1) (log (/ -1 base))))) |
| 261.0ms | (- (log (* (log (sqrt (+ (* re re) (* im im)))) (log base))) (log (* (log base) (log base)))) |
| 253.0ms | (- (log (* (log (sqrt (+ (* re re) (* im im)))) (log base))) (+ (log (log base)) (log (log base)))) |
16 alts after pruning (16 fresh and 0 done)
Merged error: 6.1b
Found 2 expressions with local error:
| 26.2b | (sqrt (+ (* re re) (* im im))) |
| 0.3b | (/ (log (sqrt (+ (* re re) (* im im)))) (log base)) |
| 15× | times-frac |
| 14× | add-sqr-sqrt |
| 13× | add-cube-cbrt |
| 13× | *-un-lft-identity |
| 8× | log-pow |
| 6× | pow1 |
| 5× | associate-/l* |
| 5× | pow1/2 |
| 4× | add-exp-log |
| 4× | sqrt-div |
| 4× | add-cbrt-cube |
| 3× | sqrt-prod |
| 3× | associate-/r* |
| 2× | add-log-exp |
| 2× | flip-+ |
| 2× | div-sub |
| 2× | flip3-+ |
| 2× | log-div |
| 1× | div-inv |
| 1× | div-exp |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | rem-sqrt-square |
| 1× | cbrt-undiv |
| 9.0ms | (/ (log (sqrt (+ (* re re) (* im im)))) (log base)) |
| 2.0ms | (sqrt (+ (* re re) (* im im))) |
| 88.0ms | (/ (log (sqrt (+ (* re re) (* im im)))) (log base)) |
| 19.0ms | (sqrt (+ (* re re) (* im im))) |
| 169.0ms | (/ (log (sqrt (- (* (* re re) (* re re)) (* (* im im) (* im im))))) (log base)) |
| 130.0ms | (* -1 (/ (log (/ -1 re)) (- (log -1) (log (/ -1 base))))) |
| 106.0ms | (/ (* (* (log (sqrt (+ (* re re) (* im im)))) (log (sqrt (+ (* re re) (* im im))))) (log (sqrt (+ (* re re) (* im im))))) (* (* (log base) (log base)) (log base))) |
| 100.0ms | (sqrt (- (* (* re re) (* re re)) (* (* im im) (* im im)))) |
| 59.0ms | (/ (log (sqrt (+ (pow (* re re) 3) (pow (* im im) 3)))) (log base)) |
15 alts after pruning (15 fresh and 0 done)
Merged error: 6.1b
Found 4 expressions with local error:
| 26.2b | (sqrt (+ (* re re) (* im im))) |
| 26.2b | (sqrt (+ (* re re) (* im im))) |
| 0.4b | (* (sqrt (sqrt (+ (* re re) (* im im)))) (sqrt (sqrt (+ (* re re) (* im im))))) |
| 0.3b | (/ (log (* (sqrt (sqrt (+ (* re re) (* im im)))) (sqrt (sqrt (+ (* re re) (* im im)))))) (log base)) |
| 52× | sqrt-div |
| 33× | pow1 |
| 30× | times-frac |
| 29× | add-sqr-sqrt |
| 28× | log-pow |
| 27× | add-cube-cbrt |
| 27× | *-un-lft-identity |
| 24× | sqrt-prod |
| 22× | pow1/2 |
| 14× | flip-+ |
| 14× | flip3-+ |
| 10× | associate-/l* |
| 10× | pow-prod-up |
| 10× | pow-prod-down |
| 9× | associate-*l* |
| 9× | associate-*r* |
| 8× | add-exp-log |
| 8× | div-sub |
| 8× | add-cbrt-cube |
| 8× | log-div |
| 8× | frac-times |
| 5× | pow-plus |
| 5× | pow2 |
| 4× | add-log-exp |
| 4× | associate-*r/ |
| 4× | associate-*l/ |
| 3× | associate-/r* |
| 2× | rem-sqrt-square |
| 1× | div-inv |
| 1× | cbrt-unprod |
| 1× | *-commutative |
| 1× | prod-exp |
| 1× | div-exp |
| 1× | sqrt-unprod |
| 1× | frac-2neg |
| 1× | rem-square-sqrt |
| 1× | clear-num |
| 1× | cbrt-undiv |
| 47.0ms | (/ (log (* (sqrt (sqrt (+ (* re re) (* im im)))) (sqrt (sqrt (+ (* re re) (* im im)))))) (log base)) |
| 20.0ms | (* (sqrt (sqrt (+ (* re re) (* im im)))) (sqrt (sqrt (+ (* re re) (* im im))))) |
| 4.0ms | (sqrt (+ (* re re) (* im im))) |
| 4.0ms | (sqrt (+ (* re re) (* im im))) |
| 113.0ms | (/ (log (* (sqrt (sqrt (+ (* re re) (* im im)))) (sqrt (sqrt (+ (* re re) (* im im)))))) (log base)) |
| 31.0ms | (sqrt (+ (* re re) (* im im))) |
| 29.0ms | (* (sqrt (sqrt (+ (* re re) (* im im)))) (sqrt (sqrt (+ (* re re) (* im im))))) |
| 28.0ms | (sqrt (+ (* re re) (* im im))) |
| 343.0ms | (/ (* (* (log (* (sqrt (sqrt (+ (* re re) (* im im)))) (sqrt (sqrt (+ (* re re) (* im im)))))) (log (* (sqrt (sqrt (+ (* re re) (* im im)))) (sqrt (sqrt (+ (* re re) (* im im))))))) (log (* (sqrt (sqrt (+ (* re re) (* im im)))) (sqrt (sqrt (+ (* re re) (* im im))))))) (* (* (log base) (log base)) (log base))) |
| 205.0ms | (/ (log (* (sqrt (sqrt (+ (pow (* re re) 3) (pow (* im im) 3)))) (sqrt (sqrt (- (* (* re re) (* re re)) (* (* im im) (* im im))))))) (log base)) |
| 199.0ms | (* (sqrt (sqrt (+ (* (* re re) (* re re)) (- (* (* im im) (* im im)) (* (* re re) (* im im)))))) (sqrt (sqrt (- (* re re) (* im im))))) |
| 188.0ms | (* (sqrt (sqrt (+ (* (* re re) (* re re)) (- (* (* im im) (* im im)) (* (* re re) (* im im)))))) (sqrt (sqrt (+ (* (* re re) (* re re)) (- (* (* im im) (* im im)) (* (* re re) (* im im))))))) |
| 177.0ms | (* (sqrt (sqrt (- (* (* re re) (* re re)) (* (* im im) (* im im))))) (sqrt (sqrt (+ (pow (* re re) 3) (pow (* im im) 3))))) |
15 alts after pruning (14 fresh and 1 done)
Merged error: 6.1b
Found 4 expressions with local error:
| 26.2b | (sqrt (+ (* re re) (* im im))) |
| 0.5b | (* (log base) (log base)) |
| 0.4b | (* (log (sqrt (+ (* re re) (* im im)))) (log base)) |
| 0.4b | (* (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (/ 1 (* (log base) (log base)))) |
| 25× | add-exp-log |
| 17× | pow1 |
| 13× | prod-exp |
| 13× | add-cbrt-cube |
| 11× | add-sqr-sqrt |
| 10× | add-cube-cbrt |
| 10× | associate-*r* |
| 10× | *-un-lft-identity |
| 9× | associate-*l* |
| 5× | cbrt-unprod |
| 5× | pow-prod-down |
| 4× | add-log-exp |
| 4× | rec-exp |
| 3× | sqrt-prod |
| 3× | *-commutative |
| 2× | log-pow |
| 2× | sqrt-div |
| 2× | pow1/2 |
| 1× | div-inv |
| 1× | flip-+ |
| 1× | pow-prod-up |
| 1× | un-div-inv |
| 1× | associate-*r/ |
| 1× | pow-plus |
| 1× | flip3-+ |
| 1× | rem-sqrt-square |
| 1× | pow2 |
| 22.0ms | (* (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (/ 1 (* (log base) (log base)))) |
| 5.0ms | (* (log (sqrt (+ (* re re) (* im im)))) (log base)) |
| 4.0ms | (* (log base) (log base)) |
| 2.0ms | (sqrt (+ (* re re) (* im im))) |
| 178.0ms | (* (log base) (log base)) |
| 119.0ms | (* (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (/ 1 (* (log base) (log base)))) |
| 105.0ms | (* (log (sqrt (+ (* re re) (* im im)))) (log base)) |
| 19.0ms | (sqrt (+ (* re re) (* im im))) |
| 1.9s | (* (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (/ 1 (* (log base) (log base)))) |
| 1.4s | (* (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (/ 1 (* (log base) (log base)))) |
| 749.0ms | (* (* (* (* (log (sqrt (+ (* re re) (* im im)))) (log base)) (* (log (sqrt (+ (* re re) (* im im)))) (log base))) (* (log (sqrt (+ (* re re) (* im im)))) (log base))) (* (* (/ 1 (* (log base) (log base))) (/ 1 (* (log base) (log base)))) (/ 1 (* (log base) (log base))))) |
| 503.0ms | (+ (log (* (log (sqrt (+ (* re re) (* im im)))) (log base))) (- (log (* (log base) (log base))))) |
| 372.0ms | (pow (- (log -1) (log (/ -1 base))) 2) |
15 alts after pruning (13 fresh and 2 done)
Merged error: 6.1b
58.1% (10.1b remaining)
Error of 17.3b against oracle of 7.2b and baseline of 31.3b
| 31577× | (pre true 80) |
| 15613× | (body nan 80) |
| 8000× | (body real 80) |
| 7964× | (body exit 10240) |