


Bits error versus x.re



Bits error versus x.im



Bits error versus y.re



Bits error versus y.im
Results
if (* (exp (- (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.re) (* (atan2 x.im x.re) y.im))) (sin (+ (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) (* (atan2 x.im x.re) y.re)))) < 3.432377918335032e-39Initial program 0.1
if 3.432377918335032e-39 < (* (exp (- (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.re) (* (atan2 x.im x.re) y.im))) (sin (+ (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) (* (atan2 x.im x.re) y.re)))) Initial program 61.0
Taylor expanded around -inf 21.5
Simplified21.5
Taylor expanded around -inf 21.3
Simplified21.3
Final simplification10.8
herbie shell --seed 2019016
(FPCore (x.re x.im y.re y.im)
:name "powComplex, imaginary part"
(* (exp (- (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.re) (* (atan2 x.im x.re) y.im))) (sin (+ (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) (* (atan2 x.im x.re) y.re)))))
Time bar (total: 3.8m)Debug log
| 1645× | (pre true 80) |
| 1389× | (body exit 10240) |
| 256× | (body real 80) |
| 96.0ms | (* (exp (- (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.re) (* (atan2 x.im x.re) y.im))) (sin (+ (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) (* (atan2 x.im x.re) y.re)))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 28.4b
Found 4 expressions with local error:
| 36.5b | (sin (+ (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) (* (atan2 x.im x.re) y.re))) |
| 27.0b | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 27.0b | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 0.3b | (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) |
| 9× | add-sqr-sqrt |
| 7× | add-cube-cbrt |
| 7× | *-un-lft-identity |
| 6× | sqrt-prod |
| 5× | associate-*l* |
| 5× | pow1 |
| 4× | add-log-exp |
| 4× | add-exp-log |
| 4× | sqrt-div |
| 4× | add-cbrt-cube |
| 3× | pow1/2 |
| 2× | flip-+ |
| 2× | log-pow |
| 2× | flip3-+ |
| 2× | rem-sqrt-square |
| 1× | *-commutative |
| 1× | sin-sum |
| 20.0ms | (sin (+ (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) (* (atan2 x.im x.re) y.re))) |
| 3.0ms | (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) |
| 2.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 2.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 156.0ms | (sin (+ (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) (* (atan2 x.im x.re) y.re))) |
| 88.0ms | (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.im) |
| 31.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 31.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 147.0ms | (sqrt (- (* (* x.re x.re) (* x.re x.re)) (* (* x.im x.im) (* x.im x.im)))) |
| 106.0ms | (sqrt (- (* (* x.re x.re) (* x.re x.re)) (* (* x.im x.im) (* x.im x.im)))) |
| 89.0ms | (* -1 (* y.im (log (/ 1 x.re)))) |
| 61.0ms | (sqrt (+ (pow (* x.re x.re) 3) (pow (* x.im x.im) 3))) |
| 58.0ms | (* -1 (* y.im (log (/ -1 x.re)))) |
6 alts after pruning (5 fresh and 1 done)
Merged error: 10.2b
Found 4 expressions with local error:
| 36.5b | (sin (+ (* (log (- x.re)) y.im) (* (atan2 x.im x.re) y.re))) |
| 27.0b | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 0.3b | (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.re) |
| 0.3b | (* (log (- x.re)) y.im) |
| 9× | associate-*l* |
| 8× | add-sqr-sqrt |
| 7× | add-cube-cbrt |
| 7× | *-un-lft-identity |
| 6× | pow1 |
| 4× | add-log-exp |
| 4× | add-exp-log |
| 4× | add-cbrt-cube |
| 3× | sqrt-prod |
| 3× | log-pow |
| 2× | *-commutative |
| 2× | sqrt-div |
| 2× | pow1/2 |
| 1× | flip-+ |
| 1× | sin-sum |
| 1× | flip3-+ |
| 1× | rem-sqrt-square |
| 17.0ms | (sin (+ (* (log (- x.re)) y.im) (* (atan2 x.im x.re) y.re))) |
| 6.0ms | (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.re) |
| 6.0ms | (* (log (- x.re)) y.im) |
| 4.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 158.0ms | (sin (+ (* (log (- x.re)) y.im) (* (atan2 x.im x.re) y.re))) |
| 93.0ms | (* (log (- x.re)) y.im) |
| 75.0ms | (* (log (sqrt (+ (* x.re x.re) (* x.im x.im)))) y.re) |
| 31.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 153.0ms | (sqrt (- (* (* x.re x.re) (* x.re x.re)) (* (* x.im x.im) (* x.im x.im)))) |
| 105.0ms | (sin (- (+ (* (atan2 x.im x.re) y.re) (* y.im (log -1))) (* y.im (log (/ 1 x.re))))) |
| 93.0ms | (* -1 (* y.im (log (/ -1 x.re)))) |
| 68.0ms | (* -1 (* y.re (log (/ -1 x.re)))) |
| 62.0ms | (* -1 (* y.re (log (/ 1 x.re)))) |
7 alts after pruning (6 fresh and 1 done)
Merged error: 4.2b
Found 4 expressions with local error:
| 36.6b | (sin (+ (* (* (cbrt (log (- x.re))) (cbrt (log (- x.re)))) (* (cbrt (log (- x.re))) y.im)) (* (atan2 x.im x.re) y.re))) |
| 27.0b | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 0.5b | (* (cbrt (log (- x.re))) (cbrt (log (- x.re)))) |
| 0.5b | (cbrt (log (- x.re))) |
| 12× | pow1 |
| 12× | cbrt-prod |
| 11× | add-sqr-sqrt |
| 10× | add-cube-cbrt |
| 10× | *-un-lft-identity |
| 7× | associate-*l* |
| 7× | associate-*r* |
| 6× | add-exp-log |
| 5× | pow1/3 |
| 4× | add-log-exp |
| 4× | add-cbrt-cube |
| 3× | sqrt-prod |
| 3× | log-pow |
| 2× | pow-prod-up |
| 2× | pow-prod-down |
| 2× | sqrt-div |
| 1× | flip-+ |
| 1× | cbrt-unprod |
| 1× | *-commutative |
| 1× | prod-exp |
| 1× | sin-sum |
| 1× | pow1/2 |
| 1× | pow-plus |
| 1× | flip3-+ |
| 1× | rem-sqrt-square |
| 1× | pow2 |
| 43.0ms | (sin (+ (* (* (cbrt (log (- x.re))) (cbrt (log (- x.re)))) (* (cbrt (log (- x.re))) y.im)) (* (atan2 x.im x.re) y.re))) |
| 10.0ms | (* (cbrt (log (- x.re))) (cbrt (log (- x.re)))) |
| 3.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 1.0ms | (cbrt (log (- x.re))) |
| 411.0ms | (* (cbrt (log (- x.re))) (cbrt (log (- x.re)))) |
| 333.0ms | (cbrt (log (- x.re))) |
| 126.0ms | (sin (+ (* (* (cbrt (log (- x.re))) (cbrt (log (- x.re)))) (* (cbrt (log (- x.re))) y.im)) (* (atan2 x.im x.re) y.re))) |
| 31.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 176.0ms | (sqrt (- (* (* x.re x.re) (* x.re x.re)) (* (* x.im x.im) (* x.im x.im)))) |
| 67.0ms | (pow (pow (- (log -1) (log (/ 1 x.re))) 2) 1/3) |
| 62.0ms | (sin (- (* (atan2 x.im x.re) y.re) (* y.im (log (/ -1 x.re))))) |
| 58.0ms | (sin (- (+ (* (atan2 x.im x.re) y.re) (* y.im (log -1))) (* y.im (log (/ 1 x.re))))) |
| 38.0ms | (pow (pow (+ (log -1) (log x.re)) 2) 1/3) |
10 alts after pruning (9 fresh and 1 done)
Merged error: 4.2b
Found 4 expressions with local error:
| 36.6b | (sin (+ (* (cbrt (* (log (- x.re)) (log (- x.re)))) (* (cbrt (log (- x.re))) y.im)) (* (atan2 x.im x.re) y.re))) |
| 27.0b | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 0.5b | (* (log (- x.re)) (log (- x.re))) |
| 0.5b | (cbrt (* (log (- x.re)) (log (- x.re)))) |
| 11× | pow1 |
| 10× | add-sqr-sqrt |
| 9× | add-cube-cbrt |
| 9× | *-un-lft-identity |
| 8× | log-prod |
| 6× | add-exp-log |
| 6× | add-cbrt-cube |
| 4× | add-log-exp |
| 4× | associate-*l* |
| 4× | associate-*r* |
| 4× | distribute-lft-in |
| 4× | distribute-rgt-in |
| 3× | sqrt-prod |
| 2× | log-pow |
| 2× | sqrt-div |
| 2× | neg-mul-1 |
| 1× | flip-+ |
| 1× | cbrt-unprod |
| 1× | pow-prod-up |
| 1× | *-commutative |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | pow1/3 |
| 1× | sin-sum |
| 1× | pow1/2 |
| 1× | pow-plus |
| 1× | flip3-+ |
| 1× | rem-sqrt-square |
| 1× | pow2 |
| 1× | cbrt-prod |
| 48.0ms | (sin (+ (* (cbrt (* (log (- x.re)) (log (- x.re)))) (* (cbrt (log (- x.re))) y.im)) (* (atan2 x.im x.re) y.re))) |
| 5.0ms | (* (log (- x.re)) (log (- x.re))) |
| 2.0ms | (cbrt (* (log (- x.re)) (log (- x.re)))) |
| 2.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 407.0ms | (cbrt (* (log (- x.re)) (log (- x.re)))) |
| 235.0ms | (* (log (- x.re)) (log (- x.re))) |
| 130.0ms | (sin (+ (* (cbrt (* (log (- x.re)) (log (- x.re)))) (* (cbrt (log (- x.re))) y.im)) (* (atan2 x.im x.re) y.re))) |
| 25.0ms | (sqrt (+ (* x.re x.re) (* x.im x.im))) |
| 108.0ms | (pow (- (log -1) (log (/ 1 x.re))) 2) |
| 106.0ms | (sin (- (+ (* (atan2 x.im x.re) y.re) (* y.im (log -1))) (* y.im (log (/ 1 x.re))))) |
| 90.0ms | (sqrt (- (* (* x.re x.re) (* x.re x.re)) (* (* x.im x.im) (* x.im x.im)))) |
| 89.0ms | (sin (- (* (atan2 x.im x.re) y.re) (* y.im (log (/ -1 x.re))))) |
| 81.0ms | (pow (pow (- (log -1) (log (/ 1 x.re))) 2) 1/3) |
10 alts after pruning (9 fresh and 1 done)
Merged error: 4.1b
46% (5.7b remaining)
Error of 10.8b against oracle of 5.1b and baseline of 15.7b
| 55647× | (pre true 80) |
| 47646× | (body exit 10240) |
| 8001× | (body real 80) |