0.002 * [progress]: [Phase 1 of 3] Setting up. 0.002 * * * [progress]: [1/2] Preparing points 0.002 * * * * [points]: Sampling 256 additional inputs, on iter 0 have 0 / 256 0.005 * * * * [points]: Computing exacts on every 16 of 256 points to ramp up precision 0.007 * * * * [points]: Setting MPFR precision to 64 0.009 * * * * [points]: Setting MPFR precision to 320 0.011 * * * * [points]: Computing exacts on every 8 of 256 points to ramp up precision 0.013 * * * * [points]: Setting MPFR precision to 64 0.016 * * * * [points]: Setting MPFR precision to 320 0.019 * * * * [points]: Computing exacts on every 4 of 256 points to ramp up precision 0.021 * * * * [points]: Setting MPFR precision to 64 0.027 * * * * [points]: Setting MPFR precision to 320 0.033 * * * * [points]: Computing exacts on every 2 of 256 points to ramp up precision 0.035 * * * * [points]: Setting MPFR precision to 64 0.044 * * * * [points]: Setting MPFR precision to 320 0.067 * * * * [points]: Computing exacts for 256 points 0.069 * * * * [points]: Setting MPFR precision to 64 0.098 * * * * [points]: Setting MPFR precision to 320 0.131 * * * * [points]: Filtering points with unrepresentable outputs 0.133 * * * * [points]: Sampled 256 points with exact outputs 0.133 * * * [progress]: [2/2] Setting up program. 0.145 * [progress]: [Phase 2 of 3] Improving. 0.145 * * * * [progress]: [ 1 / 1 ] simplifiying candidate # 0.145 * [simplify]: Simplifying (/.p16 (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 0.145 * * [simplify]: iters left: 3 (11 enodes) 0.150 * * [simplify]: iters left: 2 (29 enodes) 0.160 * * [simplify]: iters left: 1 (57 enodes) 0.171 * * [simplify]: Extracting #0: cost 1 inf + 0 0.171 * * [simplify]: Extracting #1: cost 10 inf + 0 0.171 * * [simplify]: Extracting #2: cost 31 inf + 0 0.172 * * [simplify]: Extracting #3: cost 44 inf + 0 0.172 * * [simplify]: Extracting #4: cost 58 inf + 647 0.172 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.175 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.179 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.183 * [simplify]: Simplified to (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 0.183 * [simplify]: Simplified (2) to (λ (x.re x.im y.re y.im) (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 0.194 * * [progress]: iteration 1 / 4 0.194 * * * [progress]: picking best candidate 0.202 * * * * [pick]: Picked # 0.202 * * * [progress]: localizing error 0.365 * * * [progress]: generating rewritten candidates 0.365 * * * * [progress]: [ 1 / 3 ] rewriting at (2) 0.368 * * * * [progress]: [ 2 / 3 ] rewriting at (2 1) 0.370 * * * * [progress]: [ 3 / 3 ] rewriting at (2 2) 0.374 * * * [progress]: generating series expansions 0.374 * * * * [progress]: [ 1 / 3 ] generating series at (2) 0.374 * * * * [progress]: [ 2 / 3 ] generating series at (2 1) 0.374 * * * * [progress]: [ 3 / 3 ] generating series at (2 2) 0.374 * * * [progress]: simplifying candidates 0.374 * * * * [progress]: [ 1 / 7 ] simplifiying candidate # 0.374 * [simplify]: Simplifying (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))) 0.374 * * [simplify]: iters left: 3 (9 enodes) 0.376 * * [simplify]: iters left: 2 (37 enodes) 0.383 * * [simplify]: iters left: 1 (90 enodes) 0.404 * * [simplify]: Extracting #0: cost 1 inf + 0 0.405 * * [simplify]: Extracting #1: cost 21 inf + 0 0.405 * * [simplify]: Extracting #2: cost 55 inf + 0 0.405 * * [simplify]: Extracting #3: cost 88 inf + 2654 0.406 * * [simplify]: Extracting #4: cost 69 inf + 28908 0.410 * * [simplify]: Extracting #5: cost 2 inf + 127256 0.415 * * [simplify]: Extracting #6: cost 0 inf + 129622 0.419 * [simplify]: Simplified to (*.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re x.im) (*.p16 x.re y.im))) 0.420 * [simplify]: Simplified (2 1) to (λ (x.re x.im y.re y.im) (/.p16 (*.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re x.im) (*.p16 x.re y.im))) (*.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))) 0.420 * * * * [progress]: [ 2 / 7 ] simplifiying candidate # 0.420 * * * * [progress]: [ 3 / 7 ] simplifiying candidate # 0.420 * * * * [progress]: [ 4 / 7 ] simplifiying candidate # 0.420 * * * * [progress]: [ 5 / 7 ] simplifiying candidate # 0.420 * [simplify]: Simplifying (/.p16 (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 0.420 * * [simplify]: iters left: 3 (11 enodes) 0.422 * * [simplify]: iters left: 2 (29 enodes) 0.427 * * [simplify]: iters left: 1 (57 enodes) 0.437 * * [simplify]: Extracting #0: cost 1 inf + 0 0.438 * * [simplify]: Extracting #1: cost 10 inf + 0 0.438 * * [simplify]: Extracting #2: cost 31 inf + 0 0.438 * * [simplify]: Extracting #3: cost 44 inf + 0 0.438 * * [simplify]: Extracting #4: cost 58 inf + 647 0.439 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.788 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.790 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.792 * [simplify]: Simplified to (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 0.792 * [simplify]: Simplified (2) to (λ (x.re x.im y.re y.im) (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 0.792 * * * * [progress]: [ 6 / 7 ] simplifiying candidate # 0.792 * [simplify]: Simplifying (/.p16 (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 0.792 * * [simplify]: iters left: 3 (11 enodes) 0.794 * * [simplify]: iters left: 2 (29 enodes) 0.802 * * [simplify]: iters left: 1 (57 enodes) 0.823 * * [simplify]: Extracting #0: cost 1 inf + 0 0.823 * * [simplify]: Extracting #1: cost 10 inf + 0 0.823 * * [simplify]: Extracting #2: cost 31 inf + 0 0.823 * * [simplify]: Extracting #3: cost 44 inf + 0 0.823 * * [simplify]: Extracting #4: cost 58 inf + 647 0.824 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.826 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.828 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.830 * [simplify]: Simplified to (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 0.830 * [simplify]: Simplified (2) to (λ (x.re x.im y.re y.im) (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 0.830 * * * * [progress]: [ 7 / 7 ] simplifiying candidate # 0.830 * [simplify]: Simplifying (/.p16 (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 0.830 * * [simplify]: iters left: 3 (11 enodes) 0.832 * * [simplify]: iters left: 2 (29 enodes) 0.837 * * [simplify]: iters left: 1 (57 enodes) 0.847 * * [simplify]: Extracting #0: cost 1 inf + 0 0.847 * * [simplify]: Extracting #1: cost 10 inf + 0 0.847 * * [simplify]: Extracting #2: cost 31 inf + 0 0.847 * * [simplify]: Extracting #3: cost 44 inf + 0 0.847 * * [simplify]: Extracting #4: cost 58 inf + 647 0.848 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.849 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.851 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.853 * [simplify]: Simplified to (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 0.853 * [simplify]: Simplified (2) to (λ (x.re x.im y.re y.im) (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 0.853 * * * [progress]: adding candidates to table 0.967 * * [progress]: iteration 2 / 4 0.967 * * * [progress]: picking best candidate 0.986 * * * * [pick]: Picked # 0.986 * * * [progress]: localizing error 1.208 * * * [progress]: generating rewritten candidates 1.208 * * * * [progress]: [ 1 / 4 ] rewriting at (2 1) 1.215 * * * * [progress]: [ 2 / 4 ] rewriting at (2) 1.223 * * * * [progress]: [ 3 / 4 ] rewriting at (2 1 2) 1.227 * * * * [progress]: [ 4 / 4 ] rewriting at (2 2) 1.232 * * * [progress]: generating series expansions 1.232 * * * * [progress]: [ 1 / 4 ] generating series at (2 1) 1.232 * * * * [progress]: [ 2 / 4 ] generating series at (2) 1.232 * * * * [progress]: [ 3 / 4 ] generating series at (2 1 2) 1.232 * * * * [progress]: [ 4 / 4 ] generating series at (2 2) 1.232 * * * [progress]: simplifying candidates 1.232 * * * * [progress]: [ 1 / 9 ] simplifiying candidate # 1.232 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.232 * * [simplify]: iters left: 2 (7 enodes) 1.234 * * [simplify]: iters left: 1 (18 enodes) 1.236 * * [simplify]: Extracting #0: cost 1 inf + 0 1.236 * * [simplify]: Extracting #1: cost 3 inf + 0 1.236 * * [simplify]: Extracting #2: cost 7 inf + 0 1.236 * * [simplify]: Extracting #3: cost 2 inf + 326 1.236 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.236 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.236 * [simplify]: Simplified (2 1 1) to (λ (x.re x.im y.re y.im) (/.p16 (/.p16 (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 1.236 * * * * [progress]: [ 2 / 9 ] simplifiying candidate # 1.236 * [simplify]: Simplifying (-.p16 (*.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re))) (*.p16 (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)))) 1.237 * * [simplify]: iters left: 4 (11 enodes) 1.244 * * [simplify]: iters left: 3 (47 enodes) 1.255 * * [simplify]: iters left: 2 (143 enodes) 1.295 * * [simplify]: Extracting #0: cost 1 inf + 0 1.295 * * [simplify]: Extracting #1: cost 25 inf + 0 1.295 * * [simplify]: Extracting #2: cost 73 inf + 0 1.295 * * [simplify]: Extracting #3: cost 142 inf + 2332 1.297 * * [simplify]: Extracting #4: cost 134 inf + 55820 1.304 * * [simplify]: Extracting #5: cost 28 inf + 228590 1.319 * * [simplify]: Extracting #6: cost 1 inf + 283752 1.339 * * [simplify]: Extracting #7: cost 0 inf + 287356 1.351 * [simplify]: Simplified to (*.p16 (+.p16 (*.p16 (*.p16 y.re x.im) (*.p16 y.re x.im)) (*.p16 (*.p16 y.im x.re) (*.p16 y.im x.re))) (-.p16 (*.p16 (*.p16 y.re x.im) (*.p16 y.re x.im)) (*.p16 (*.p16 y.im x.re) (*.p16 y.im x.re)))) 1.351 * [simplify]: Simplified (2 1 1) to (λ (x.re x.im y.re y.im) (/.p16 (/.p16 (*.p16 (+.p16 (*.p16 (*.p16 y.re x.im) (*.p16 y.re x.im)) (*.p16 (*.p16 y.im x.re) (*.p16 y.im x.re))) (-.p16 (*.p16 (*.p16 y.re x.im) (*.p16 y.re x.im)) (*.p16 (*.p16 y.im x.re) (*.p16 y.im x.re)))) (*.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (+.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))))) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 1.351 * * * * [progress]: [ 3 / 9 ] simplifiying candidate # 1.351 * [simplify]: Simplifying (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))) 1.351 * * [simplify]: iters left: 3 (9 enodes) 1.353 * * [simplify]: iters left: 2 (37 enodes) 1.359 * * [simplify]: iters left: 1 (90 enodes) 1.383 * * [simplify]: Extracting #0: cost 1 inf + 0 1.383 * * [simplify]: Extracting #1: cost 21 inf + 0 1.383 * * [simplify]: Extracting #2: cost 55 inf + 0 1.384 * * [simplify]: Extracting #3: cost 88 inf + 2654 1.386 * * [simplify]: Extracting #4: cost 69 inf + 28908 1.394 * * [simplify]: Extracting #5: cost 2 inf + 127256 1.403 * * [simplify]: Extracting #6: cost 0 inf + 129622 1.412 * [simplify]: Simplified to (*.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re x.im) (*.p16 x.re y.im))) 1.412 * [simplify]: Simplified (2 1) to (λ (x.re x.im y.re y.im) (/.p16 (*.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re x.im) (*.p16 x.re y.im))) (*.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))) 1.412 * * * * [progress]: [ 4 / 9 ] simplifiying candidate # 1.413 * * * * [progress]: [ 5 / 9 ] simplifiying candidate # 1.413 * * * * [progress]: [ 6 / 9 ] simplifiying candidate # 1.413 * * * * [progress]: [ 7 / 9 ] simplifiying candidate # 1.413 * * * * [progress]: [ 8 / 9 ] simplifiying candidate # 1.413 * * * * [progress]: [ 9 / 9 ] simplifiying candidate # 1.413 * * * [progress]: adding candidates to table 1.577 * * [progress]: iteration 3 / 4 1.577 * * * [progress]: picking best candidate 1.615 * * * * [pick]: Picked # 1.616 * * * [progress]: localizing error 1.961 * * * [progress]: generating rewritten candidates 1.961 * * * * [progress]: [ 1 / 4 ] rewriting at (2) 1.969 * * * * [progress]: [ 2 / 4 ] rewriting at (2 1 2) 1.972 * * * * [progress]: [ 3 / 4 ] rewriting at (2 1 2 1) 1.989 * * * * [progress]: [ 4 / 4 ] rewriting at (2 1 1) 1.996 * * * [progress]: generating series expansions 1.996 * * * * [progress]: [ 1 / 4 ] generating series at (2) 1.996 * * * * [progress]: [ 2 / 4 ] generating series at (2 1 2) 1.996 * * * * [progress]: [ 3 / 4 ] generating series at (2 1 2 1) 1.996 * * * * [progress]: [ 4 / 4 ] generating series at (2 1 1) 1.996 * * * [progress]: simplifying candidates 1.996 * * * * [progress]: [ 1 / 9 ] simplifiying candidate # 1.997 * [simplify]: Simplifying (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))) 1.997 * * [simplify]: iters left: 3 (8 enodes) 2.002 * * [simplify]: iters left: 2 (21 enodes) 2.008 * * [simplify]: iters left: 1 (22 enodes) 2.015 * * [simplify]: Extracting #0: cost 1 inf + 0 2.015 * * [simplify]: Extracting #1: cost 3 inf + 0 2.015 * * [simplify]: Extracting #2: cost 4 inf + 1 2.015 * * [simplify]: Extracting #3: cost 7 inf + 2 2.016 * * [simplify]: Extracting #4: cost 2 inf + 328 2.016 * * [simplify]: Extracting #5: cost 0 inf + 1334 2.016 * [simplify]: Simplified to (real->posit16 1.0) 2.016 * [simplify]: Simplified (2 1) to (λ (x.re x.im y.re y.im) (/.p16 (real->posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))) 2.016 * * * * [progress]: [ 2 / 9 ] simplifiying candidate # 2.016 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.017 * * [simplify]: iters left: 2 (7 enodes) 2.019 * * [simplify]: iters left: 1 (18 enodes) 2.024 * * [simplify]: Extracting #0: cost 1 inf + 0 2.024 * * [simplify]: Extracting #1: cost 3 inf + 0 2.024 * * [simplify]: Extracting #2: cost 7 inf + 0 2.024 * * [simplify]: Extracting #3: cost 2 inf + 326 2.025 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.025 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.025 * [simplify]: Simplified (2 1) to (λ (x.re x.im y.re y.im) (/.p16 (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) (*.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))) 2.025 * * * * [progress]: [ 3 / 9 ] simplifiying candidate # 2.025 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.025 * * [simplify]: iters left: 2 (7 enodes) 2.026 * * [simplify]: iters left: 1 (18 enodes) 2.029 * * [simplify]: Extracting #0: cost 1 inf + 0 2.029 * * [simplify]: Extracting #1: cost 3 inf + 0 2.029 * * [simplify]: Extracting #2: cost 7 inf + 0 2.029 * * [simplify]: Extracting #3: cost 2 inf + 326 2.029 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.029 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.029 * [simplify]: Simplified (2 1 2 2) to (λ (x.re x.im y.re y.im) (/.p16 (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (*.p16 (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)))) (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)))) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 2.029 * * * * [progress]: [ 4 / 9 ] simplifiying candidate # 2.029 * * * * [progress]: [ 5 / 9 ] simplifiying candidate # 2.029 * * * * [progress]: [ 6 / 9 ] simplifiying candidate # 2.029 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.029 * * [simplify]: iters left: 2 (7 enodes) 2.031 * * [simplify]: iters left: 1 (18 enodes) 2.033 * * [simplify]: Extracting #0: cost 1 inf + 0 2.033 * * [simplify]: Extracting #1: cost 3 inf + 0 2.033 * * [simplify]: Extracting #2: cost 7 inf + 0 2.033 * * [simplify]: Extracting #3: cost 2 inf + 326 2.033 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.033 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.033 * [simplify]: Simplified (2 1 1) to (λ (x.re x.im y.re y.im) (/.p16 (/.p16 (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 2.033 * * * * [progress]: [ 7 / 9 ] simplifiying candidate # 2.034 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.034 * * [simplify]: iters left: 2 (7 enodes) 2.035 * * [simplify]: iters left: 1 (18 enodes) 2.037 * * [simplify]: Extracting #0: cost 1 inf + 0 2.037 * * [simplify]: Extracting #1: cost 3 inf + 0 2.037 * * [simplify]: Extracting #2: cost 7 inf + 0 2.037 * * [simplify]: Extracting #3: cost 2 inf + 326 2.037 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.037 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.037 * [simplify]: Simplified (2 1 1) to (λ (x.re x.im y.re y.im) (/.p16 (/.p16 (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 2.038 * * * * [progress]: [ 8 / 9 ] simplifiying candidate # 2.038 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.038 * * [simplify]: iters left: 2 (7 enodes) 2.039 * * [simplify]: iters left: 1 (18 enodes) 2.041 * * [simplify]: Extracting #0: cost 1 inf + 0 2.041 * * [simplify]: Extracting #1: cost 3 inf + 0 2.041 * * [simplify]: Extracting #2: cost 7 inf + 0 2.041 * * [simplify]: Extracting #3: cost 2 inf + 326 2.042 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.042 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.042 * [simplify]: Simplified (2 1 1) to (λ (x.re x.im y.re y.im) (/.p16 (/.p16 (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 2.042 * * * * [progress]: [ 9 / 9 ] simplifiying candidate # 2.042 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.042 * * [simplify]: iters left: 2 (7 enodes) 2.043 * * [simplify]: iters left: 1 (18 enodes) 2.046 * * [simplify]: Extracting #0: cost 1 inf + 0 2.046 * * [simplify]: Extracting #1: cost 3 inf + 0 2.046 * * [simplify]: Extracting #2: cost 7 inf + 0 2.046 * * [simplify]: Extracting #3: cost 2 inf + 326 2.046 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.046 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.046 * [simplify]: Simplified (2 1 1) to (λ (x.re x.im y.re y.im) (/.p16 (/.p16 (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 2.046 * * * [progress]: adding candidates to table 2.204 * * [progress]: iteration 4 / 4 2.204 * * * [progress]: picking best candidate 2.278 * * * * [pick]: Picked #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> 2.278 * * * [progress]: localizing error 2.498 * * * [progress]: generating rewritten candidates 2.498 * * * * [progress]: [ 1 / 4 ] rewriting at (2 2) 2.504 * * * * [progress]: [ 2 / 4 ] rewriting at (2) 2.506 * * * * [progress]: [ 3 / 4 ] rewriting at (2 2 2) 2.508 * * * * [progress]: [ 4 / 4 ] rewriting at (2 2 1) 2.512 * * * [progress]: generating series expansions 2.513 * * * * [progress]: [ 1 / 4 ] generating series at (2 2) 2.513 * * * * [progress]: [ 2 / 4 ] generating series at (2) 2.513 * * * * [progress]: [ 3 / 4 ] generating series at (2 2 2) 2.513 * * * * [progress]: [ 4 / 4 ] generating series at (2 2 1) 2.513 * * * [progress]: simplifying candidates 2.513 * * * * [progress]: [ 1 / 10 ] simplifiying candidate #posit16 1.0) (*.p16 (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> 2.513 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.513 * * [simplify]: iters left: 2 (7 enodes) 2.514 * * [simplify]: iters left: 1 (18 enodes) 2.517 * * [simplify]: Extracting #0: cost 1 inf + 0 2.517 * * [simplify]: Extracting #1: cost 3 inf + 0 2.517 * * [simplify]: Extracting #2: cost 7 inf + 0 2.517 * * [simplify]: Extracting #3: cost 2 inf + 326 2.517 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.517 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.517 * [simplify]: Simplified (2 2 2) to (λ (x.re x.im y.re y.im) (/.p16 (real->posit16 1.0) (*.p16 (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)))) (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im))))) 2.517 * * * * [progress]: [ 2 / 10 ] simplifiying candidate #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> 2.517 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.517 * * [simplify]: iters left: 2 (7 enodes) 2.519 * * [simplify]: iters left: 1 (18 enodes) 2.521 * * [simplify]: Extracting #0: cost 1 inf + 0 2.521 * * [simplify]: Extracting #1: cost 3 inf + 0 2.521 * * [simplify]: Extracting #2: cost 7 inf + 0 2.521 * * [simplify]: Extracting #3: cost 2 inf + 326 2.521 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.521 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.521 * [simplify]: Simplified (2 2) to (λ (x.re x.im y.re y.im) (/.p16 (/.p16 (real->posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))))) (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)))) 2.522 * * * * [progress]: [ 3 / 10 ] simplifiying candidate #posit16 1.0) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> 2.522 * [simplify]: Simplifying (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.522 * * [simplify]: iters left: 2 (7 enodes) 2.523 * * [simplify]: iters left: 1 (24 enodes) 2.528 * * [simplify]: Extracting #0: cost 1 inf + 0 2.528 * * [simplify]: Extracting #1: cost 6 inf + 0 2.528 * * [simplify]: Extracting #2: cost 15 inf + 0 2.528 * * [simplify]: Extracting #3: cost 19 inf + 728 2.528 * * [simplify]: Extracting #4: cost 3 inf + 11524 2.529 * * [simplify]: Extracting #5: cost 0 inf + 15936 2.529 * [simplify]: Simplified to (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) 2.529 * [simplify]: Simplified (2 2) to (λ (x.re x.im y.re y.im) (*.p16 (/.p16 (real->posit16 1.0) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)))) 2.529 * * * * [progress]: [ 4 / 10 ] simplifiying candidate #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (+.p16 (*.p16 x.im y.re) (neg.p16 (*.p16 x.re y.im))))))> 2.529 * * * * [progress]: [ 5 / 10 ] simplifiying candidate #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (/.p16 (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))))> 2.529 * * * * [progress]: [ 6 / 10 ] simplifiying candidate #posit16 1.0) (/.p16 (+.p16 (*.p16 y.im y.im) (*.p16 y.re y.re)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> 2.529 * * * * [progress]: [ 7 / 10 ] simplifiying candidate #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> 2.530 * [simplify]: Simplifying (/.p16 (real->posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) 2.530 * * [simplify]: iters left: 4 (14 enodes) 2.539 * * [simplify]: iters left: 3 (35 enodes) 2.545 * * [simplify]: iters left: 2 (74 enodes) 2.565 * * [simplify]: iters left: 1 (208 enodes) 2.658 * * [simplify]: Extracting #0: cost 1 inf + 0 2.658 * * [simplify]: Extracting #1: cost 24 inf + 0 2.659 * * [simplify]: Extracting #2: cost 157 inf + 0 2.659 * * [simplify]: Extracting #3: cost 232 inf + 646 2.661 * * [simplify]: Extracting #4: cost 277 inf + 15215 2.668 * * [simplify]: Extracting #5: cost 108 inf + 261189 2.690 * * [simplify]: Extracting #6: cost 10 inf + 467107 2.711 * * [simplify]: Extracting #7: cost 0 inf + 497790 2.738 * [simplify]: Simplified to (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 2.738 * [simplify]: Simplified (2) to (λ (x.re x.im y.re y.im) (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 2.738 * * * * [progress]: [ 8 / 10 ] simplifiying candidate #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> 2.738 * [simplify]: Simplifying (/.p16 (real->posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) 2.738 * * [simplify]: iters left: 4 (14 enodes) 2.742 * * [simplify]: iters left: 3 (35 enodes) 2.748 * * [simplify]: iters left: 2 (74 enodes) 2.763 * * [simplify]: iters left: 1 (208 enodes) 2.858 * * [simplify]: Extracting #0: cost 1 inf + 0 2.858 * * [simplify]: Extracting #1: cost 24 inf + 0 2.859 * * [simplify]: Extracting #2: cost 157 inf + 0 2.861 * * [simplify]: Extracting #3: cost 232 inf + 646 2.863 * * [simplify]: Extracting #4: cost 277 inf + 15215 2.883 * * [simplify]: Extracting #5: cost 108 inf + 261189 2.915 * * [simplify]: Extracting #6: cost 10 inf + 467107 2.942 * * [simplify]: Extracting #7: cost 0 inf + 497790 2.973 * [simplify]: Simplified to (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 2.973 * [simplify]: Simplified (2) to (λ (x.re x.im y.re y.im) (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 2.973 * * * * [progress]: [ 9 / 10 ] simplifiying candidate #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> 2.974 * [simplify]: Simplifying (/.p16 (real->posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) 2.974 * * [simplify]: iters left: 4 (14 enodes) 2.979 * * [simplify]: iters left: 3 (35 enodes) 2.985 * * [simplify]: iters left: 2 (74 enodes) 2.999 * * [simplify]: iters left: 1 (208 enodes) 3.111 * * [simplify]: Extracting #0: cost 1 inf + 0 3.111 * * [simplify]: Extracting #1: cost 24 inf + 0 3.112 * * [simplify]: Extracting #2: cost 157 inf + 0 3.113 * * [simplify]: Extracting #3: cost 232 inf + 646 3.114 * * [simplify]: Extracting #4: cost 277 inf + 15215 3.126 * * [simplify]: Extracting #5: cost 108 inf + 261189 3.143 * * [simplify]: Extracting #6: cost 10 inf + 467107 3.162 * * [simplify]: Extracting #7: cost 0 inf + 497790 3.193 * [simplify]: Simplified to (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 3.193 * [simplify]: Simplified (2) to (λ (x.re x.im y.re y.im) (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 3.193 * * * * [progress]: [ 10 / 10 ] simplifiying candidate #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> 3.194 * [simplify]: Simplifying (/.p16 (real->posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) 3.194 * * [simplify]: iters left: 4 (14 enodes) 3.202 * * [simplify]: iters left: 3 (35 enodes) 3.208 * * [simplify]: iters left: 2 (74 enodes) 3.222 * * [simplify]: iters left: 1 (208 enodes) 3.309 * * [simplify]: Extracting #0: cost 1 inf + 0 3.309 * * [simplify]: Extracting #1: cost 24 inf + 0 3.310 * * [simplify]: Extracting #2: cost 157 inf + 0 3.311 * * [simplify]: Extracting #3: cost 232 inf + 646 3.314 * * [simplify]: Extracting #4: cost 277 inf + 15215 3.325 * * [simplify]: Extracting #5: cost 108 inf + 261189 3.340 * * [simplify]: Extracting #6: cost 10 inf + 467107 3.361 * * [simplify]: Extracting #7: cost 0 inf + 497790 3.380 * [simplify]: Simplified to (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) 3.380 * [simplify]: Simplified (2) to (λ (x.re x.im y.re y.im) (/.p16 (-.p16 (*.p16 y.re x.im) (*.p16 x.re y.im)) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)))) 3.380 * * * [progress]: adding candidates to table 3.627 * [progress]: [Phase 3 of 3] Extracting. 3.627 * * [regime]: Finding splitpoints for: (# # # # #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> # #posit16 1.0) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> #posit16 1.0) (*.p16 (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #) 3.630 * * * [regime-changes]: Trying 4 branch expressions: (y.im x.re y.re x.im) 3.630 * * * * [regimes]: Trying to branch on y.im from (# # # # #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> # #posit16 1.0) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> #posit16 1.0) (*.p16 (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #) 3.793 * * * * [regimes]: Trying to branch on x.re from (# # # # #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> # #posit16 1.0) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> #posit16 1.0) (*.p16 (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #) 3.980 * * * * [regimes]: Trying to branch on y.re from (# # # # #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> # #posit16 1.0) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> #posit16 1.0) (*.p16 (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #) 4.138 * * * * [regimes]: Trying to branch on x.im from (# # # # #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im))))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> # #posit16 1.0) (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im))) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im))))> #posit16 1.0) (*.p16 (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 (*.p16 x.im y.re) (*.p16 x.im y.re)) (*.p16 (*.p16 x.re y.im) (*.p16 x.re y.im)))) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #posit16 1.0) (/.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im y.im)) (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))))> #) 4.331 * * * [regime]: Found split indices: #