9.918 * [progress]: [Phase 1 of 3] Setting up. 0.002 * * * [progress]: [1/2] Preparing points 0.103 * * * [progress]: [2/2] Setting up program. 0.105 * [progress]: [Phase 2 of 3] Improving. 0.105 * [simplify]: Simplifying using # : (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) 0.117 * * [simplify]: iteration 0 : 8 enodes (cost 12 ) 0.117 * * [simplify]: iteration 1 : 8 enodes (cost 12 ) 0.118 * [simplify]: Simplified to: (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) 0.120 * * [progress]: iteration 1 / 4 0.120 * * * [progress]: picking best candidate 0.125 * * * * [pick]: Picked # 0.125 * * * [progress]: localizing error 0.130 * * * [progress]: generating rewritten candidates 0.130 * * * * [progress]: [ 1 / 1 ] rewriting at (2) 0.135 * * * [progress]: generating series expansions 0.135 * * * * [progress]: [ 1 / 1 ] generating series at (2) 0.135 * [approximate]: Taking taylor expansion of (sqrt (+ (pow re 2) (pow im 2))) in (re im) around 0 0.135 * [taylor]: Taking taylor expansion of (sqrt (+ (pow re 2) (pow im 2))) in im 0.135 * [taylor]: Taking taylor expansion of (+ (pow re 2) (pow im 2)) in im 0.135 * [taylor]: Taking taylor expansion of (pow re 2) in im 0.135 * [taylor]: Taking taylor expansion of re in im 0.135 * [taylor]: Taking taylor expansion of (pow im 2) in im 0.135 * [taylor]: Taking taylor expansion of im in im 0.135 * [taylor]: Taking taylor expansion of (sqrt (+ (pow re 2) (pow im 2))) in re 0.135 * [taylor]: Taking taylor expansion of (+ (pow re 2) (pow im 2)) in re 0.135 * [taylor]: Taking taylor expansion of (pow re 2) in re 0.135 * [taylor]: Taking taylor expansion of re in re 0.135 * [taylor]: Taking taylor expansion of (pow im 2) in re 0.135 * [taylor]: Taking taylor expansion of im in re 0.136 * [taylor]: Taking taylor expansion of (sqrt (+ (pow re 2) (pow im 2))) in re 0.136 * [taylor]: Taking taylor expansion of (+ (pow re 2) (pow im 2)) in re 0.136 * [taylor]: Taking taylor expansion of (pow re 2) in re 0.136 * [taylor]: Taking taylor expansion of re in re 0.136 * [taylor]: Taking taylor expansion of (pow im 2) in re 0.136 * [taylor]: Taking taylor expansion of im in re 0.136 * [taylor]: Taking taylor expansion of im in im 0.136 * [taylor]: Taking taylor expansion of 0 in im 0.136 * [taylor]: Taking taylor expansion of (/ 1/2 im) in im 0.136 * [taylor]: Taking taylor expansion of 1/2 in im 0.136 * [taylor]: Taking taylor expansion of im in im 0.137 * [taylor]: Taking taylor expansion of 0 in im 0.137 * [approximate]: Taking taylor expansion of (sqrt (+ (/ 1 (pow im 2)) (/ 1 (pow re 2)))) in (re im) around 0 0.137 * [taylor]: Taking taylor expansion of (sqrt (+ (/ 1 (pow im 2)) (/ 1 (pow re 2)))) in im 0.137 * [taylor]: Taking taylor expansion of (+ (/ 1 (pow im 2)) (/ 1 (pow re 2))) in im 0.137 * [taylor]: Taking taylor expansion of (/ 1 (pow im 2)) in im 0.137 * [taylor]: Taking taylor expansion of (pow im 2) in im 0.137 * [taylor]: Taking taylor expansion of im in im 0.137 * [taylor]: Taking taylor expansion of (/ 1 (pow re 2)) in im 0.137 * [taylor]: Taking taylor expansion of (pow re 2) in im 0.137 * [taylor]: Taking taylor expansion of re in im 0.137 * [taylor]: Taking taylor expansion of (sqrt (+ (/ 1 (pow im 2)) (/ 1 (pow re 2)))) in re 0.137 * [taylor]: Taking taylor expansion of (+ (/ 1 (pow im 2)) (/ 1 (pow re 2))) in re 0.137 * [taylor]: Taking taylor expansion of (/ 1 (pow im 2)) in re 0.137 * [taylor]: Taking taylor expansion of (pow im 2) in re 0.137 * [taylor]: Taking taylor expansion of im in re 0.138 * [taylor]: Taking taylor expansion of (/ 1 (pow re 2)) in re 0.138 * [taylor]: Taking taylor expansion of (pow re 2) in re 0.138 * [taylor]: Taking taylor expansion of re in re 0.138 * [taylor]: Taking taylor expansion of (sqrt (+ (/ 1 (pow im 2)) (/ 1 (pow re 2)))) in re 0.138 * [taylor]: Taking taylor expansion of (+ (/ 1 (pow im 2)) (/ 1 (pow re 2))) in re 0.138 * [taylor]: Taking taylor expansion of (/ 1 (pow im 2)) in re 0.138 * [taylor]: Taking taylor expansion of (pow im 2) in re 0.138 * [taylor]: Taking taylor expansion of im in re 0.138 * [taylor]: Taking taylor expansion of (/ 1 (pow re 2)) in re 0.138 * [taylor]: Taking taylor expansion of (pow re 2) in re 0.138 * [taylor]: Taking taylor expansion of re in re 0.138 * [taylor]: Taking taylor expansion of 1 in im 0.138 * [taylor]: Taking taylor expansion of 0 in im 0.139 * [taylor]: Taking taylor expansion of (/ 1/2 (pow im 2)) in im 0.139 * [taylor]: Taking taylor expansion of 1/2 in im 0.139 * [taylor]: Taking taylor expansion of (pow im 2) in im 0.139 * [taylor]: Taking taylor expansion of im in im 0.139 * [taylor]: Taking taylor expansion of 0 in im 0.140 * [approximate]: Taking taylor expansion of (sqrt (+ (/ 1 (pow im 2)) (/ 1 (pow re 2)))) in (re im) around 0 0.140 * [taylor]: Taking taylor expansion of (sqrt (+ (/ 1 (pow im 2)) (/ 1 (pow re 2)))) in im 0.140 * [taylor]: Taking taylor expansion of (+ (/ 1 (pow im 2)) (/ 1 (pow re 2))) in im 0.140 * [taylor]: Taking taylor expansion of (/ 1 (pow im 2)) in im 0.140 * [taylor]: Taking taylor expansion of (pow im 2) in im 0.140 * [taylor]: Taking taylor expansion of im in im 0.140 * [taylor]: Taking taylor expansion of (/ 1 (pow re 2)) in im 0.140 * [taylor]: Taking taylor expansion of (pow re 2) in im 0.140 * [taylor]: Taking taylor expansion of re in im 0.140 * [taylor]: Taking taylor expansion of (sqrt (+ (/ 1 (pow im 2)) (/ 1 (pow re 2)))) in re 0.140 * [taylor]: Taking taylor expansion of (+ (/ 1 (pow im 2)) (/ 1 (pow re 2))) in re 0.140 * [taylor]: Taking taylor expansion of (/ 1 (pow im 2)) in re 0.140 * [taylor]: Taking taylor expansion of (pow im 2) in re 0.140 * [taylor]: Taking taylor expansion of im in re 0.140 * [taylor]: Taking taylor expansion of (/ 1 (pow re 2)) in re 0.140 * [taylor]: Taking taylor expansion of (pow re 2) in re 0.140 * [taylor]: Taking taylor expansion of re in re 0.140 * [taylor]: Taking taylor expansion of (sqrt (+ (/ 1 (pow im 2)) (/ 1 (pow re 2)))) in re 0.140 * [taylor]: Taking taylor expansion of (+ (/ 1 (pow im 2)) (/ 1 (pow re 2))) in re 0.140 * [taylor]: Taking taylor expansion of (/ 1 (pow im 2)) in re 0.140 * [taylor]: Taking taylor expansion of (pow im 2) in re 0.140 * [taylor]: Taking taylor expansion of im in re 0.141 * [taylor]: Taking taylor expansion of (/ 1 (pow re 2)) in re 0.141 * [taylor]: Taking taylor expansion of (pow re 2) in re 0.141 * [taylor]: Taking taylor expansion of re in re 0.141 * [taylor]: Taking taylor expansion of 1 in im 0.141 * [taylor]: Taking taylor expansion of 0 in im 0.141 * [taylor]: Taking taylor expansion of (/ 1/2 (pow im 2)) in im 0.141 * [taylor]: Taking taylor expansion of 1/2 in im 0.141 * [taylor]: Taking taylor expansion of (pow im 2) in im 0.141 * [taylor]: Taking taylor expansion of im in im 0.142 * [taylor]: Taking taylor expansion of 0 in im 0.142 * * * [progress]: simplifying candidates 0.143 * [simplify]: Simplifying using # : (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (exp.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (*.f64 (cbrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (cbrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))))) (cbrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (*.f64 (*.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 (*.f64 (cbrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) (cbrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))))) (sqrt.f64 (cbrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 1) (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) (sqrt.f64 (+.f64 (pow.f64 (*.f64 re re) 3) (pow.f64 (*.f64 im im) 3))) (sqrt.f64 (+.f64 (*.f64 (*.f64 re re) (*.f64 re re)) (-.f64 (*.f64 (*.f64 im im) (*.f64 im im)) (*.f64 (*.f64 re re) (*.f64 im im))))) (sqrt.f64 (-.f64 (*.f64 (*.f64 re re) (*.f64 re re)) (*.f64 (*.f64 im im) (*.f64 im im)))) (sqrt.f64 (-.f64 (*.f64 re re) (*.f64 im im))) (/.f64 1 2) (sqrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) im re (*.f64 -1 re) 0.218 * * [simplify]: iteration 0 : 4907 enodes (cost 250 ) 0.218 * * [simplify]: iteration 1 : 4907 enodes (cost 250 ) 0.220 * [simplify]: Simplified to: (log.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (exp.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (*.f64 (cbrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (cbrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))))) (cbrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (pow.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) 3) (fabs.f64 (cbrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 (cbrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) 1 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) (sqrt.f64 (+.f64 (pow.f64 re 6) (pow.f64 im 6))) (sqrt.f64 (+.f64 (pow.f64 re 4) (-.f64 (pow.f64 im 4) (*.f64 (*.f64 re re) (*.f64 im im))))) (sqrt.f64 (-.f64 (pow.f64 re 4) (pow.f64 im 4))) (sqrt.f64 (-.f64 (*.f64 re re) (*.f64 im im))) 1/2 (sqrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) (sqrt.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im)))) im re (neg.f64 re) 0.220 * * * [progress]: adding candidates to table 0.234 * * [progress]: iteration 2 / 4 0.234 * * * [progress]: picking best candidate 0.238 * * * * [pick]: Picked # 0.238 * * * [progress]: localizing error 0.239 * * * [progress]: generating rewritten candidates 0.239 * * * [progress]: generating series expansions 0.239 * * * [progress]: simplifying candidates 0.240 * [simplify]: Simplifying using # : 0.251 * * [simplify]: iteration 0 : 0 enodes (cost 0 ) 0.251 * [simplify]: Simplified to: 0.251 * * * [progress]: adding candidates to table 0.252 * * [progress]: iteration 3 / 4 0.252 * * * [progress]: picking best candidate 0.254 * * * * [pick]: Picked # 0.255 * * * [progress]: localizing error 0.255 * * * [progress]: generating rewritten candidates 0.255 * * * [progress]: generating series expansions 0.255 * * * [progress]: simplifying candidates 0.255 * [simplify]: Simplifying using # : 0.269 * * [simplify]: iteration 0 : 0 enodes (cost 0 ) 0.269 * [simplify]: Simplified to: 0.269 * * * [progress]: adding candidates to table 0.270 * * [progress]: iteration 4 / 4 0.270 * * * [progress]: picking best candidate 0.271 * * * * [pick]: Picked # 0.271 * * * [progress]: localizing error 0.272 * * * [progress]: generating rewritten candidates 0.272 * * * [progress]: generating series expansions 0.272 * * * [progress]: simplifying candidates 0.272 * [simplify]: Simplifying using # : 0.284 * * [simplify]: iteration 0 : 0 enodes (cost 0 ) 0.284 * [simplify]: Simplified to: 0.284 * * * [progress]: adding candidates to table 0.285 * [progress]: [Phase 3 of 3] Extracting. 0.285 * * [regime]: Finding splitpoints for: (# # # #) 0.285 * * * [regime-changes]: Trying 6 branch expressions: ((*.f64 im im) (*.f64 re re) (+.f64 (*.f64 re re) (*.f64 im im)) (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) im re) 0.285 * * * * [regimes]: Trying to branch on (*.f64 im im) from (# # # #) 0.309 * * * * [regimes]: Trying to branch on (*.f64 im im) from (# # #) 0.333 * * * * [regimes]: Trying to branch on (*.f64 re re) from (# # # #) 0.363 * * * * [regimes]: Trying to branch on (*.f64 re re) from (# #) 0.386 * * * * [regimes]: Trying to branch on (+.f64 (*.f64 re re) (*.f64 im im)) from (# # # #) 0.416 * * * * [regimes]: Trying to branch on (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) from (# # # #) 0.446 * * * * [regimes]: Trying to branch on im from (# # # #) 0.487 * * * * [regimes]: Trying to branch on re from (# # # #) 0.529 * * * [regime]: Found split indices: #