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.004 * * * * [points]: Computing exacts on every 16 of 256 points to ramp up precision 0.009 * * * * [points]: Setting MPFR precision to 64 0.011 * * * * [points]: Setting MPFR precision to 320 0.012 * * * * [points]: Computing exacts on every 8 of 256 points to ramp up precision 0.014 * * * * [points]: Setting MPFR precision to 64 0.017 * * * * [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.025 * * * * [points]: Setting MPFR precision to 320 0.030 * * * * [points]: Computing exacts on every 2 of 256 points to ramp up precision 0.031 * * * * [points]: Setting MPFR precision to 64 0.038 * * * * [points]: Setting MPFR precision to 320 0.043 * * * * [points]: Computing exacts for 256 points 0.044 * * * * [points]: Setting MPFR precision to 64 0.064 * * * * [points]: Setting MPFR precision to 320 0.087 * * * * [points]: Filtering points with unrepresentable outputs 0.089 * * * * [points]: Sampled 256 points with exact outputs 0.089 * * * [progress]: [2/2] Setting up program. 0.097 * [progress]: [Phase 2 of 3] Improving. 0.097 * * * * [progress]: [ 1 / 1 ] simplifiying candidate # 0.097 * [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.097 * * [simplify]: iters left: 3 (11 enodes) 0.101 * * [simplify]: iters left: 2 (29 enodes) 0.108 * * [simplify]: iters left: 1 (57 enodes) 0.124 * * [simplify]: Extracting #0: cost 1 inf + 0 0.124 * * [simplify]: Extracting #1: cost 10 inf + 0 0.125 * * [simplify]: Extracting #2: cost 31 inf + 0 0.125 * * [simplify]: Extracting #3: cost 44 inf + 0 0.125 * * [simplify]: Extracting #4: cost 58 inf + 647 0.126 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.128 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.131 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.133 * [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.133 * [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.155 * * [progress]: iteration 1 / 4 0.155 * * * [progress]: picking best candidate 0.161 * * * * [pick]: Picked # 0.161 * * * [progress]: localizing error 0.609 * * * [progress]: generating rewritten candidates 0.610 * * * * [progress]: [ 1 / 3 ] rewriting at (2) 0.612 * * * * [progress]: [ 2 / 3 ] rewriting at (2 1) 0.614 * * * * [progress]: [ 3 / 3 ] rewriting at (2 2) 0.618 * * * [progress]: generating series expansions 0.618 * * * * [progress]: [ 1 / 3 ] generating series at (2) 0.618 * * * * [progress]: [ 2 / 3 ] generating series at (2 1) 0.618 * * * * [progress]: [ 3 / 3 ] generating series at (2 2) 0.618 * * * [progress]: simplifying candidates 0.618 * * * * [progress]: [ 1 / 7 ] simplifiying candidate # 0.618 * [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.618 * * [simplify]: iters left: 3 (9 enodes) 0.620 * * [simplify]: iters left: 2 (37 enodes) 0.627 * * [simplify]: iters left: 1 (90 enodes) 0.649 * * [simplify]: Extracting #0: cost 1 inf + 0 0.649 * * [simplify]: Extracting #1: cost 21 inf + 0 0.649 * * [simplify]: Extracting #2: cost 55 inf + 0 0.649 * * [simplify]: Extracting #3: cost 88 inf + 2654 0.650 * * [simplify]: Extracting #4: cost 69 inf + 28908 0.656 * * [simplify]: Extracting #5: cost 2 inf + 127256 0.661 * * [simplify]: Extracting #6: cost 0 inf + 129622 0.666 * [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.666 * [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.666 * * * * [progress]: [ 2 / 7 ] simplifiying candidate # 0.666 * * * * [progress]: [ 3 / 7 ] simplifiying candidate # 0.666 * * * * [progress]: [ 4 / 7 ] simplifiying candidate # 0.666 * * * * [progress]: [ 5 / 7 ] simplifiying candidate # 0.666 * [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.666 * * [simplify]: iters left: 3 (11 enodes) 0.670 * * [simplify]: iters left: 2 (29 enodes) 0.681 * * [simplify]: iters left: 1 (57 enodes) 0.693 * * [simplify]: Extracting #0: cost 1 inf + 0 0.693 * * [simplify]: Extracting #1: cost 10 inf + 0 0.693 * * [simplify]: Extracting #2: cost 31 inf + 0 0.693 * * [simplify]: Extracting #3: cost 44 inf + 0 0.693 * * [simplify]: Extracting #4: cost 58 inf + 647 0.694 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.695 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.697 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.699 * [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.699 * [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.699 * * * * [progress]: [ 6 / 7 ] simplifiying candidate # 0.699 * [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.699 * * [simplify]: iters left: 3 (11 enodes) 0.702 * * [simplify]: iters left: 2 (29 enodes) 0.707 * * [simplify]: iters left: 1 (57 enodes) 0.720 * * [simplify]: Extracting #0: cost 1 inf + 0 0.720 * * [simplify]: Extracting #1: cost 10 inf + 0 0.720 * * [simplify]: Extracting #2: cost 31 inf + 0 0.720 * * [simplify]: Extracting #3: cost 44 inf + 0 0.721 * * [simplify]: Extracting #4: cost 58 inf + 647 0.721 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.723 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.724 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.726 * [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.726 * [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.726 * * * * [progress]: [ 7 / 7 ] simplifiying candidate # 0.726 * [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.726 * * [simplify]: iters left: 3 (11 enodes) 0.729 * * [simplify]: iters left: 2 (29 enodes) 0.734 * * [simplify]: iters left: 1 (57 enodes) 0.744 * * [simplify]: Extracting #0: cost 1 inf + 0 0.744 * * [simplify]: Extracting #1: cost 10 inf + 0 0.745 * * [simplify]: Extracting #2: cost 31 inf + 0 0.745 * * [simplify]: Extracting #3: cost 44 inf + 0 0.745 * * [simplify]: Extracting #4: cost 58 inf + 647 0.745 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.747 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.749 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.751 * [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.751 * [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.751 * * * [progress]: adding candidates to table 0.847 * * [progress]: iteration 2 / 4 0.847 * * * [progress]: picking best candidate 0.870 * * * * [pick]: Picked # 0.870 * * * [progress]: localizing error 1.185 * * * [progress]: generating rewritten candidates 1.185 * * * * [progress]: [ 1 / 4 ] rewriting at (2 1) 1.191 * * * * [progress]: [ 2 / 4 ] rewriting at (2) 1.206 * * * * [progress]: [ 3 / 4 ] rewriting at (2 1 2) 1.210 * * * * [progress]: [ 4 / 4 ] rewriting at (2 1 1 2) 1.215 * * * [progress]: generating series expansions 1.215 * * * * [progress]: [ 1 / 4 ] generating series at (2 1) 1.215 * * * * [progress]: [ 2 / 4 ] generating series at (2) 1.215 * * * * [progress]: [ 3 / 4 ] generating series at (2 1 2) 1.215 * * * * [progress]: [ 4 / 4 ] generating series at (2 1 1 2) 1.215 * * * [progress]: simplifying candidates 1.215 * * * * [progress]: [ 1 / 11 ] simplifiying candidate # 1.216 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.216 * * [simplify]: iters left: 2 (7 enodes) 1.217 * * [simplify]: iters left: 1 (18 enodes) 1.220 * * [simplify]: Extracting #0: cost 1 inf + 0 1.220 * * [simplify]: Extracting #1: cost 3 inf + 0 1.220 * * [simplify]: Extracting #2: cost 7 inf + 0 1.220 * * [simplify]: Extracting #3: cost 2 inf + 326 1.220 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.220 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.220 * [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.220 * * * * [progress]: [ 2 / 11 ] simplifiying candidate # 1.220 * [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.220 * * [simplify]: iters left: 4 (11 enodes) 1.223 * * [simplify]: iters left: 3 (47 enodes) 1.233 * * [simplify]: iters left: 2 (143 enodes) 1.306 * * [simplify]: Extracting #0: cost 1 inf + 0 1.306 * * [simplify]: Extracting #1: cost 25 inf + 0 1.307 * * [simplify]: Extracting #2: cost 73 inf + 0 1.307 * * [simplify]: Extracting #3: cost 142 inf + 2332 1.311 * * [simplify]: Extracting #4: cost 134 inf + 55820 1.323 * * [simplify]: Extracting #5: cost 28 inf + 228590 1.341 * * [simplify]: Extracting #6: cost 1 inf + 283752 1.358 * * [simplify]: Extracting #7: cost 0 inf + 287356 1.375 * [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.375 * [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.375 * * * * [progress]: [ 3 / 11 ] simplifiying candidate # 1.376 * [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.376 * * [simplify]: iters left: 3 (9 enodes) 1.379 * * [simplify]: iters left: 2 (37 enodes) 1.390 * * [simplify]: iters left: 1 (90 enodes) 1.417 * * [simplify]: Extracting #0: cost 1 inf + 0 1.417 * * [simplify]: Extracting #1: cost 21 inf + 0 1.417 * * [simplify]: Extracting #2: cost 55 inf + 0 1.418 * * [simplify]: Extracting #3: cost 88 inf + 2654 1.419 * * [simplify]: Extracting #4: cost 69 inf + 28908 1.424 * * [simplify]: Extracting #5: cost 2 inf + 127256 1.433 * * [simplify]: Extracting #6: cost 0 inf + 129622 1.442 * [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.442 * [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.442 * * * * [progress]: [ 4 / 11 ] simplifiying candidate # 1.442 * * * * [progress]: [ 5 / 11 ] simplifiying candidate # 1.442 * * * * [progress]: [ 6 / 11 ] simplifiying candidate # 1.442 * * * * [progress]: [ 7 / 11 ] simplifiying candidate # 1.442 * * * * [progress]: [ 8 / 11 ] simplifiying candidate # 1.442 * * * * [progress]: [ 9 / 11 ] simplifiying candidate # 1.442 * * * * [progress]: [ 10 / 11 ] simplifiying candidate # 1.442 * * * * [progress]: [ 11 / 11 ] simplifiying candidate # 1.443 * * * [progress]: adding candidates to table 1.632 * * [progress]: iteration 3 / 4 1.632 * * * [progress]: picking best candidate 1.668 * * * * [pick]: Picked # 1.668 * * * [progress]: localizing error 1.916 * * * [progress]: generating rewritten candidates 1.916 * * * * [progress]: [ 1 / 4 ] rewriting at (2) 1.921 * * * * [progress]: [ 2 / 4 ] rewriting at (2 1 2) 1.923 * * * * [progress]: [ 3 / 4 ] rewriting at (2 1 2 1) 1.928 * * * * [progress]: [ 4 / 4 ] rewriting at (2 1 1) 1.933 * * * [progress]: generating series expansions 1.933 * * * * [progress]: [ 1 / 4 ] generating series at (2) 1.933 * * * * [progress]: [ 2 / 4 ] generating series at (2 1 2) 1.933 * * * * [progress]: [ 3 / 4 ] generating series at (2 1 2 1) 1.933 * * * * [progress]: [ 4 / 4 ] generating series at (2 1 1) 1.933 * * * [progress]: simplifying candidates 1.933 * * * * [progress]: [ 1 / 9 ] simplifiying candidate # 1.933 * [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.933 * * [simplify]: iters left: 3 (8 enodes) 1.937 * * [simplify]: iters left: 2 (21 enodes) 1.942 * * [simplify]: iters left: 1 (22 enodes) 1.946 * * [simplify]: Extracting #0: cost 1 inf + 0 1.946 * * [simplify]: Extracting #1: cost 3 inf + 0 1.946 * * [simplify]: Extracting #2: cost 4 inf + 1 1.946 * * [simplify]: Extracting #3: cost 7 inf + 2 1.947 * * [simplify]: Extracting #4: cost 2 inf + 328 1.947 * * [simplify]: Extracting #5: cost 0 inf + 1334 1.947 * [simplify]: Simplified to (real->posit16 1.0) 1.947 * [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))))) 1.947 * * * * [progress]: [ 2 / 9 ] simplifiying candidate # 1.947 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.947 * * [simplify]: iters left: 2 (7 enodes) 1.949 * * [simplify]: iters left: 1 (18 enodes) 1.953 * * [simplify]: Extracting #0: cost 1 inf + 0 1.953 * * [simplify]: Extracting #1: cost 3 inf + 0 1.953 * * [simplify]: Extracting #2: cost 7 inf + 0 1.953 * * [simplify]: Extracting #3: cost 2 inf + 326 1.953 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.953 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.953 * [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)))))) 1.953 * * * * [progress]: [ 3 / 9 ] simplifiying candidate # 1.953 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.953 * * [simplify]: iters left: 2 (7 enodes) 1.955 * * [simplify]: iters left: 1 (18 enodes) 1.959 * * [simplify]: Extracting #0: cost 1 inf + 0 1.959 * * [simplify]: Extracting #1: cost 3 inf + 0 1.959 * * [simplify]: Extracting #2: cost 7 inf + 0 1.959 * * [simplify]: Extracting #3: cost 2 inf + 326 1.959 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.959 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.959 * [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)))) 1.959 * * * * [progress]: [ 4 / 9 ] simplifiying candidate # 1.959 * * * * [progress]: [ 5 / 9 ] simplifiying candidate # 1.959 * * * * [progress]: [ 6 / 9 ] simplifiying candidate # 1.960 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.960 * * [simplify]: iters left: 2 (7 enodes) 1.962 * * [simplify]: iters left: 1 (18 enodes) 1.965 * * [simplify]: Extracting #0: cost 1 inf + 0 1.965 * * [simplify]: Extracting #1: cost 3 inf + 0 1.965 * * [simplify]: Extracting #2: cost 7 inf + 0 1.965 * * [simplify]: Extracting #3: cost 2 inf + 326 1.965 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.965 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.965 * [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.965 * * * * [progress]: [ 7 / 9 ] simplifiying candidate # 1.966 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.966 * * [simplify]: iters left: 2 (7 enodes) 1.968 * * [simplify]: iters left: 1 (18 enodes) 1.971 * * [simplify]: Extracting #0: cost 1 inf + 0 1.971 * * [simplify]: Extracting #1: cost 3 inf + 0 1.971 * * [simplify]: Extracting #2: cost 7 inf + 0 1.971 * * [simplify]: Extracting #3: cost 2 inf + 326 1.971 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.971 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.971 * [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.972 * * * * [progress]: [ 8 / 9 ] simplifiying candidate # 1.972 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.972 * * [simplify]: iters left: 2 (7 enodes) 1.974 * * [simplify]: iters left: 1 (18 enodes) 1.977 * * [simplify]: Extracting #0: cost 1 inf + 0 1.977 * * [simplify]: Extracting #1: cost 3 inf + 0 1.977 * * [simplify]: Extracting #2: cost 7 inf + 0 1.977 * * [simplify]: Extracting #3: cost 2 inf + 326 1.977 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.977 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.978 * [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.978 * * * * [progress]: [ 9 / 9 ] simplifiying candidate # 1.978 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.978 * * [simplify]: iters left: 2 (7 enodes) 1.980 * * [simplify]: iters left: 1 (18 enodes) 1.983 * * [simplify]: Extracting #0: cost 1 inf + 0 1.983 * * [simplify]: Extracting #1: cost 3 inf + 0 1.983 * * [simplify]: Extracting #2: cost 7 inf + 0 1.983 * * [simplify]: Extracting #3: cost 2 inf + 326 1.983 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.984 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.984 * [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.984 * * * [progress]: adding candidates to table 2.108 * * [progress]: iteration 4 / 4 2.108 * * * [progress]: picking best candidate 2.175 * * * * [pick]: Picked # 2.175 * * * [progress]: localizing error 2.432 * * * [progress]: generating rewritten candidates 2.432 * * * * [progress]: [ 1 / 4 ] rewriting at (2) 2.436 * * * * [progress]: [ 2 / 4 ] rewriting at (2 2 2) 2.438 * * * * [progress]: [ 3 / 4 ] rewriting at (2 2 2 1) 2.442 * * * * [progress]: [ 4 / 4 ] rewriting at (2 1) 2.447 * * * [progress]: generating series expansions 2.447 * * * * [progress]: [ 1 / 4 ] generating series at (2) 2.447 * * * * [progress]: [ 2 / 4 ] generating series at (2 2 2) 2.447 * * * * [progress]: [ 3 / 4 ] generating series at (2 2 2 1) 2.447 * * * * [progress]: [ 4 / 4 ] generating series at (2 1) 2.447 * * * [progress]: simplifying candidates 2.447 * * * * [progress]: [ 1 / 9 ] simplifiying candidate # 2.448 * [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))) 2.448 * * [simplify]: iters left: 3 (9 enodes) 2.450 * * [simplify]: iters left: 2 (26 enodes) 2.456 * * [simplify]: iters left: 1 (53 enodes) 2.470 * * [simplify]: Extracting #0: cost 1 inf + 0 2.470 * * [simplify]: Extracting #1: cost 10 inf + 0 2.470 * * [simplify]: Extracting #2: cost 26 inf + 0 2.470 * * [simplify]: Extracting #3: cost 39 inf + 0 2.471 * * [simplify]: Extracting #4: cost 56 inf + 728 2.472 * * [simplify]: Extracting #5: cost 21 inf + 32616 2.474 * * [simplify]: Extracting #6: cost 1 inf + 61996 2.476 * * [simplify]: Extracting #7: cost 0 inf + 63840 2.478 * [simplify]: Simplified to (/.p16 (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re))) 2.479 * [simplify]: Simplified (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 y.re y.re) (*.p16 y.im y.im))) (/.p16 (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re))))) 2.479 * * * * [progress]: [ 2 / 9 ] simplifiying candidate # 2.479 * [simplify]: Simplifying (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.479 * * [simplify]: iters left: 2 (7 enodes) 2.481 * * [simplify]: iters left: 1 (24 enodes) 2.486 * * [simplify]: Extracting #0: cost 1 inf + 0 2.486 * * [simplify]: Extracting #1: cost 6 inf + 0 2.486 * * [simplify]: Extracting #2: cost 15 inf + 0 2.487 * * [simplify]: Extracting #3: cost 19 inf + 728 2.487 * * [simplify]: Extracting #4: cost 3 inf + 11524 2.487 * * [simplify]: Extracting #5: cost 0 inf + 15936 2.488 * [simplify]: Simplified to (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) 2.488 * [simplify]: Simplified (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 y.re y.re) (*.p16 y.im y.im)) (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)))) (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)))) 2.488 * * * * [progress]: [ 3 / 9 ] simplifiying candidate # 2.488 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.488 * * [simplify]: iters left: 2 (7 enodes) 2.490 * * [simplify]: iters left: 1 (18 enodes) 2.494 * * [simplify]: Extracting #0: cost 1 inf + 0 2.494 * * [simplify]: Extracting #1: cost 3 inf + 0 2.494 * * [simplify]: Extracting #2: cost 7 inf + 0 2.494 * * [simplify]: Extracting #3: cost 2 inf + 326 2.494 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.494 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.494 * [simplify]: Simplified (2 2 2 2) to (λ (x.re x.im y.re y.im) (/.p16 (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) (*.p16 (+.p16 (*.p16 y.re y.re) (*.p16 y.im 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)))))) 2.494 * * * * [progress]: [ 4 / 9 ] simplifiying candidate # 2.494 * * * * [progress]: [ 5 / 9 ] simplifiying candidate # 2.494 * * * * [progress]: [ 6 / 9 ] simplifiying candidate # 2.494 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.495 * * [simplify]: iters left: 2 (7 enodes) 2.497 * * [simplify]: iters left: 1 (18 enodes) 2.500 * * [simplify]: Extracting #0: cost 1 inf + 0 2.500 * * [simplify]: Extracting #1: cost 3 inf + 0 2.500 * * [simplify]: Extracting #2: cost 7 inf + 0 2.500 * * [simplify]: Extracting #3: cost 2 inf + 326 2.500 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.500 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.500 * [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.500 * * * * [progress]: [ 7 / 9 ] simplifiying candidate # 2.500 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.500 * * [simplify]: iters left: 2 (7 enodes) 2.502 * * [simplify]: iters left: 1 (18 enodes) 2.506 * * [simplify]: Extracting #0: cost 1 inf + 0 2.506 * * [simplify]: Extracting #1: cost 3 inf + 0 2.506 * * [simplify]: Extracting #2: cost 7 inf + 0 2.506 * * [simplify]: Extracting #3: cost 2 inf + 326 2.506 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.506 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.506 * [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.506 * * * * [progress]: [ 8 / 9 ] simplifiying candidate # 2.507 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.507 * * [simplify]: iters left: 2 (7 enodes) 2.509 * * [simplify]: iters left: 1 (18 enodes) 2.512 * * [simplify]: Extracting #0: cost 1 inf + 0 2.512 * * [simplify]: Extracting #1: cost 3 inf + 0 2.512 * * [simplify]: Extracting #2: cost 7 inf + 0 2.512 * * [simplify]: Extracting #3: cost 2 inf + 326 2.512 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.512 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.512 * [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.512 * * * * [progress]: [ 9 / 9 ] simplifiying candidate # 2.513 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 2.513 * * [simplify]: iters left: 2 (7 enodes) 2.515 * * [simplify]: iters left: 1 (18 enodes) 2.518 * * [simplify]: Extracting #0: cost 1 inf + 0 2.518 * * [simplify]: Extracting #1: cost 3 inf + 0 2.518 * * [simplify]: Extracting #2: cost 7 inf + 0 2.518 * * [simplify]: Extracting #3: cost 2 inf + 326 2.518 * * [simplify]: Extracting #4: cost 0 inf + 1332 2.518 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 2.518 * [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.519 * * * [progress]: adding candidates to table 2.643 * [progress]: [Phase 3 of 3] Extracting. 2.644 * * [regime]: Finding splitpoints for: (# # # # # # # # #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.649 * * * [regime-changes]: Trying 4 branch expressions: (y.im x.re y.re x.im) 2.649 * * * * [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 x.im y.re) (*.p16 x.re y.im)))))> #) 2.826 * * * * [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 x.im y.re) (*.p16 x.re y.im)))))> #) 2.993 * * * * [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 x.im y.re) (*.p16 x.re y.im)))))> #) 3.146 * * * * [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 x.im y.re) (*.p16 x.re y.im)))))> #) 3.309 * * * [regime]: Found split indices: #