0.002 * [progress]: [Phase 1 of 3] Setting up. 0.002 * * * [progress]: [1/2] Preparing points 0.003 * * * * [points]: Sampling 256 additional inputs, on iter 0 have 0 / 256 0.006 * * * * [points]: Computing exacts on every 16 of 256 points to ramp up precision 0.008 * * * * [points]: Setting MPFR precision to 64 0.010 * * * * [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.020 * * * * [points]: Computing exacts on every 4 of 256 points to ramp up precision 0.022 * * * * [points]: Setting MPFR precision to 64 0.028 * * * * [points]: Setting MPFR precision to 320 0.034 * * * * [points]: Computing exacts on every 2 of 256 points to ramp up precision 0.036 * * * * [points]: Setting MPFR precision to 64 0.045 * * * * [points]: Setting MPFR precision to 320 0.054 * * * * [points]: Computing exacts for 256 points 0.056 * * * * [points]: Setting MPFR precision to 64 0.078 * * * * [points]: Setting MPFR precision to 320 0.096 * * * * [points]: Filtering points with unrepresentable outputs 0.096 * * * * [points]: Sampled 256 points with exact outputs 0.096 * * * [progress]: [2/2] Setting up program. 0.103 * [progress]: [Phase 2 of 3] Improving. 0.103 * * * * [progress]: [ 1 / 1 ] simplifiying candidate # 0.103 * [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.104 * * [simplify]: iters left: 3 (11 enodes) 0.108 * * [simplify]: iters left: 2 (29 enodes) 0.118 * * [simplify]: iters left: 1 (57 enodes) 0.162 * * [simplify]: Extracting #0: cost 1 inf + 0 0.162 * * [simplify]: Extracting #1: cost 10 inf + 0 0.163 * * [simplify]: Extracting #2: cost 31 inf + 0 0.163 * * [simplify]: Extracting #3: cost 44 inf + 0 0.163 * * [simplify]: Extracting #4: cost 58 inf + 647 0.164 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.169 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.171 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.173 * [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.173 * [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.179 * * [progress]: iteration 1 / 4 0.179 * * * [progress]: picking best candidate 0.184 * * * * [pick]: Picked # 0.184 * * * [progress]: localizing error 0.357 * * * [progress]: generating rewritten candidates 0.357 * * * * [progress]: [ 1 / 3 ] rewriting at (2) 0.359 * * * * [progress]: [ 2 / 3 ] rewriting at (2 1) 0.361 * * * * [progress]: [ 3 / 3 ] rewriting at (2 2) 0.365 * * * [progress]: generating series expansions 0.365 * * * * [progress]: [ 1 / 3 ] generating series at (2) 0.366 * * * * [progress]: [ 2 / 3 ] generating series at (2 1) 0.366 * * * * [progress]: [ 3 / 3 ] generating series at (2 2) 0.366 * * * [progress]: simplifying candidates 0.366 * * * * [progress]: [ 1 / 7 ] simplifiying candidate # 0.366 * [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.366 * * [simplify]: iters left: 3 (9 enodes) 0.370 * * [simplify]: iters left: 2 (37 enodes) 0.382 * * [simplify]: iters left: 1 (90 enodes) 0.419 * * [simplify]: Extracting #0: cost 1 inf + 0 0.420 * * [simplify]: Extracting #1: cost 21 inf + 0 0.420 * * [simplify]: Extracting #2: cost 55 inf + 0 0.420 * * [simplify]: Extracting #3: cost 88 inf + 2654 0.422 * * [simplify]: Extracting #4: cost 69 inf + 28908 0.430 * * [simplify]: Extracting #5: cost 2 inf + 127256 0.434 * * [simplify]: Extracting #6: cost 0 inf + 129622 0.441 * [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.441 * [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.441 * * * * [progress]: [ 2 / 7 ] simplifiying candidate # 0.441 * * * * [progress]: [ 3 / 7 ] simplifiying candidate # 0.441 * * * * [progress]: [ 4 / 7 ] simplifiying candidate # 0.441 * * * * [progress]: [ 5 / 7 ] simplifiying candidate # 0.441 * [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.442 * * [simplify]: iters left: 3 (11 enodes) 0.445 * * [simplify]: iters left: 2 (29 enodes) 0.450 * * [simplify]: iters left: 1 (57 enodes) 0.461 * * [simplify]: Extracting #0: cost 1 inf + 0 0.461 * * [simplify]: Extracting #1: cost 10 inf + 0 0.461 * * [simplify]: Extracting #2: cost 31 inf + 0 0.461 * * [simplify]: Extracting #3: cost 44 inf + 0 0.461 * * [simplify]: Extracting #4: cost 58 inf + 647 0.462 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.463 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.465 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.469 * [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.469 * [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.469 * * * * [progress]: [ 6 / 7 ] simplifiying candidate # 0.469 * [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.469 * * [simplify]: iters left: 3 (11 enodes) 0.473 * * [simplify]: iters left: 2 (29 enodes) 0.482 * * [simplify]: iters left: 1 (57 enodes) 0.499 * * [simplify]: Extracting #0: cost 1 inf + 0 0.499 * * [simplify]: Extracting #1: cost 10 inf + 0 0.499 * * [simplify]: Extracting #2: cost 31 inf + 0 0.499 * * [simplify]: Extracting #3: cost 44 inf + 0 0.499 * * [simplify]: Extracting #4: cost 58 inf + 647 0.500 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.501 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.504 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.507 * [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.507 * [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.507 * * * * [progress]: [ 7 / 7 ] simplifiying candidate # 0.507 * [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.507 * * [simplify]: iters left: 3 (11 enodes) 0.510 * * [simplify]: iters left: 2 (29 enodes) 0.515 * * [simplify]: iters left: 1 (57 enodes) 0.527 * * [simplify]: Extracting #0: cost 1 inf + 0 0.527 * * [simplify]: Extracting #1: cost 10 inf + 0 0.527 * * [simplify]: Extracting #2: cost 31 inf + 0 0.527 * * [simplify]: Extracting #3: cost 44 inf + 0 0.527 * * [simplify]: Extracting #4: cost 58 inf + 647 0.528 * * [simplify]: Extracting #5: cost 32 inf + 21623 0.530 * * [simplify]: Extracting #6: cost 1 inf + 63920 0.531 * * [simplify]: Extracting #7: cost 0 inf + 65284 0.533 * [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.534 * [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.534 * * * [progress]: adding candidates to table 0.617 * * [progress]: iteration 2 / 4 0.618 * * * [progress]: picking best candidate 0.629 * * * * [pick]: Picked # 0.629 * * * [progress]: localizing error 0.877 * * * [progress]: generating rewritten candidates 0.877 * * * * [progress]: [ 1 / 4 ] rewriting at (2 1) 0.892 * * * * [progress]: [ 2 / 4 ] rewriting at (2) 0.901 * * * * [progress]: [ 3 / 4 ] rewriting at (2 1 2) 0.905 * * * * [progress]: [ 4 / 4 ] rewriting at (2 2) 0.909 * * * [progress]: generating series expansions 0.909 * * * * [progress]: [ 1 / 4 ] generating series at (2 1) 0.909 * * * * [progress]: [ 2 / 4 ] generating series at (2) 0.909 * * * * [progress]: [ 3 / 4 ] generating series at (2 1 2) 0.909 * * * * [progress]: [ 4 / 4 ] generating series at (2 2) 0.909 * * * [progress]: simplifying candidates 0.909 * * * * [progress]: [ 1 / 9 ] simplifiying candidate # 0.909 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 0.909 * * [simplify]: iters left: 2 (7 enodes) 0.911 * * [simplify]: iters left: 1 (18 enodes) 0.913 * * [simplify]: Extracting #0: cost 1 inf + 0 0.913 * * [simplify]: Extracting #1: cost 3 inf + 0 0.913 * * [simplify]: Extracting #2: cost 7 inf + 0 0.913 * * [simplify]: Extracting #3: cost 2 inf + 326 0.913 * * [simplify]: Extracting #4: cost 0 inf + 1332 0.913 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 0.914 * [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)))) 0.914 * * * * [progress]: [ 2 / 9 ] simplifiying candidate # 0.914 * [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)))) 0.914 * * [simplify]: iters left: 4 (11 enodes) 0.917 * * [simplify]: iters left: 3 (47 enodes) 0.926 * * [simplify]: iters left: 2 (143 enodes) 0.971 * * [simplify]: Extracting #0: cost 1 inf + 0 0.971 * * [simplify]: Extracting #1: cost 25 inf + 0 0.971 * * [simplify]: Extracting #2: cost 73 inf + 0 0.972 * * [simplify]: Extracting #3: cost 142 inf + 2332 0.974 * * [simplify]: Extracting #4: cost 134 inf + 55820 0.980 * * [simplify]: Extracting #5: cost 28 inf + 228590 0.990 * * [simplify]: Extracting #6: cost 1 inf + 283752 1.000 * * [simplify]: Extracting #7: cost 0 inf + 287356 1.011 * [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.011 * [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.011 * * * * [progress]: [ 3 / 9 ] simplifiying candidate # 1.011 * [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.011 * * [simplify]: iters left: 3 (9 enodes) 1.013 * * [simplify]: iters left: 2 (37 enodes) 1.020 * * [simplify]: iters left: 1 (90 enodes) 1.042 * * [simplify]: Extracting #0: cost 1 inf + 0 1.042 * * [simplify]: Extracting #1: cost 21 inf + 0 1.042 * * [simplify]: Extracting #2: cost 55 inf + 0 1.042 * * [simplify]: Extracting #3: cost 88 inf + 2654 1.043 * * [simplify]: Extracting #4: cost 69 inf + 28908 1.049 * * [simplify]: Extracting #5: cost 2 inf + 127256 1.054 * * [simplify]: Extracting #6: cost 0 inf + 129622 1.059 * [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.059 * [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.059 * * * * [progress]: [ 4 / 9 ] simplifiying candidate # 1.059 * * * * [progress]: [ 5 / 9 ] simplifiying candidate # 1.059 * * * * [progress]: [ 6 / 9 ] simplifiying candidate # 1.059 * * * * [progress]: [ 7 / 9 ] simplifiying candidate # 1.059 * * * * [progress]: [ 8 / 9 ] simplifiying candidate # 1.059 * * * * [progress]: [ 9 / 9 ] simplifiying candidate # 1.059 * * * [progress]: adding candidates to table 1.193 * * [progress]: iteration 3 / 4 1.193 * * * [progress]: picking best candidate 1.222 * * * * [pick]: Picked # 1.222 * * * [progress]: localizing error 1.496 * * * [progress]: generating rewritten candidates 1.497 * * * * [progress]: [ 1 / 4 ] rewriting at (2) 1.500 * * * * [progress]: [ 2 / 4 ] rewriting at (2 1 2) 1.502 * * * * [progress]: [ 3 / 4 ] rewriting at (2 1 2 1) 1.505 * * * * [progress]: [ 4 / 4 ] rewriting at (2 1 1) 1.509 * * * [progress]: generating series expansions 1.509 * * * * [progress]: [ 1 / 4 ] generating series at (2) 1.509 * * * * [progress]: [ 2 / 4 ] generating series at (2 1 2) 1.509 * * * * [progress]: [ 3 / 4 ] generating series at (2 1 2 1) 1.509 * * * * [progress]: [ 4 / 4 ] generating series at (2 1 1) 1.509 * * * [progress]: simplifying candidates 1.509 * * * * [progress]: [ 1 / 9 ] simplifiying candidate # 1.509 * [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.509 * * [simplify]: iters left: 3 (8 enodes) 1.511 * * [simplify]: iters left: 2 (21 enodes) 1.514 * * [simplify]: iters left: 1 (22 enodes) 1.517 * * [simplify]: Extracting #0: cost 1 inf + 0 1.517 * * [simplify]: Extracting #1: cost 3 inf + 0 1.517 * * [simplify]: Extracting #2: cost 4 inf + 1 1.517 * * [simplify]: Extracting #3: cost 7 inf + 2 1.517 * * [simplify]: Extracting #4: cost 2 inf + 328 1.517 * * [simplify]: Extracting #5: cost 0 inf + 1334 1.518 * [simplify]: Simplified to (real->posit16 1.0) 1.518 * [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.518 * * * * [progress]: [ 2 / 9 ] simplifiying candidate # 1.518 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.518 * * [simplify]: iters left: 2 (7 enodes) 1.520 * * [simplify]: iters left: 1 (18 enodes) 1.523 * * [simplify]: Extracting #0: cost 1 inf + 0 1.523 * * [simplify]: Extracting #1: cost 3 inf + 0 1.523 * * [simplify]: Extracting #2: cost 7 inf + 0 1.524 * * [simplify]: Extracting #3: cost 2 inf + 326 1.524 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.524 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.524 * [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.524 * * * * [progress]: [ 3 / 9 ] simplifiying candidate # 1.524 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.524 * * [simplify]: iters left: 2 (7 enodes) 1.526 * * [simplify]: iters left: 1 (18 enodes) 1.528 * * [simplify]: Extracting #0: cost 1 inf + 0 1.528 * * [simplify]: Extracting #1: cost 3 inf + 0 1.528 * * [simplify]: Extracting #2: cost 7 inf + 0 1.528 * * [simplify]: Extracting #3: cost 2 inf + 326 1.528 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.528 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.528 * [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.528 * * * * [progress]: [ 4 / 9 ] simplifiying candidate # 1.528 * * * * [progress]: [ 5 / 9 ] simplifiying candidate # 1.528 * * * * [progress]: [ 6 / 9 ] simplifiying candidate # 1.528 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.528 * * [simplify]: iters left: 2 (7 enodes) 1.530 * * [simplify]: iters left: 1 (18 enodes) 1.532 * * [simplify]: Extracting #0: cost 1 inf + 0 1.532 * * [simplify]: Extracting #1: cost 3 inf + 0 1.532 * * [simplify]: Extracting #2: cost 7 inf + 0 1.532 * * [simplify]: Extracting #3: cost 2 inf + 326 1.532 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.532 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.532 * [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.532 * * * * [progress]: [ 7 / 9 ] simplifiying candidate # 1.532 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.533 * * [simplify]: iters left: 2 (7 enodes) 1.534 * * [simplify]: iters left: 1 (18 enodes) 1.536 * * [simplify]: Extracting #0: cost 1 inf + 0 1.536 * * [simplify]: Extracting #1: cost 3 inf + 0 1.536 * * [simplify]: Extracting #2: cost 7 inf + 0 1.536 * * [simplify]: Extracting #3: cost 2 inf + 326 1.536 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.536 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.536 * [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.536 * * * * [progress]: [ 8 / 9 ] simplifiying candidate # 1.537 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.537 * * [simplify]: iters left: 2 (7 enodes) 1.538 * * [simplify]: iters left: 1 (18 enodes) 1.540 * * [simplify]: Extracting #0: cost 1 inf + 0 1.540 * * [simplify]: Extracting #1: cost 3 inf + 0 1.540 * * [simplify]: Extracting #2: cost 7 inf + 0 1.540 * * [simplify]: Extracting #3: cost 2 inf + 326 1.540 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.540 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.541 * [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.541 * * * * [progress]: [ 9 / 9 ] simplifiying candidate # 1.541 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.541 * * [simplify]: iters left: 2 (7 enodes) 1.542 * * [simplify]: iters left: 1 (18 enodes) 1.544 * * [simplify]: Extracting #0: cost 1 inf + 0 1.544 * * [simplify]: Extracting #1: cost 3 inf + 0 1.544 * * [simplify]: Extracting #2: cost 7 inf + 0 1.545 * * [simplify]: Extracting #3: cost 2 inf + 326 1.545 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.545 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.545 * [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.545 * * * [progress]: adding candidates to table 1.647 * * [progress]: iteration 4 / 4 1.647 * * * [progress]: picking best candidate 1.680 * * * * [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)))))> 1.681 * * * [progress]: localizing error 1.839 * * * [progress]: generating rewritten candidates 1.839 * * * * [progress]: [ 1 / 4 ] rewriting at (2 2) 1.842 * * * * [progress]: [ 2 / 4 ] rewriting at (2) 1.845 * * * * [progress]: [ 3 / 4 ] rewriting at (2 2 2) 1.847 * * * * [progress]: [ 4 / 4 ] rewriting at (2 2 1) 1.851 * * * [progress]: generating series expansions 1.851 * * * * [progress]: [ 1 / 4 ] generating series at (2 2) 1.851 * * * * [progress]: [ 2 / 4 ] generating series at (2) 1.851 * * * * [progress]: [ 3 / 4 ] generating series at (2 2 2) 1.851 * * * * [progress]: [ 4 / 4 ] generating series at (2 2 1) 1.851 * * * [progress]: simplifying candidates 1.851 * * * * [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)))))> 1.851 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.851 * * [simplify]: iters left: 2 (7 enodes) 1.853 * * [simplify]: iters left: 1 (18 enodes) 1.855 * * [simplify]: Extracting #0: cost 1 inf + 0 1.856 * * [simplify]: Extracting #1: cost 3 inf + 0 1.856 * * [simplify]: Extracting #2: cost 7 inf + 0 1.856 * * [simplify]: Extracting #3: cost 2 inf + 326 1.856 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.856 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.856 * [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))))) 1.856 * * * * [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))))> 1.856 * [simplify]: Simplifying (+.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.856 * * [simplify]: iters left: 2 (7 enodes) 1.857 * * [simplify]: iters left: 1 (18 enodes) 1.860 * * [simplify]: Extracting #0: cost 1 inf + 0 1.861 * * [simplify]: Extracting #1: cost 3 inf + 0 1.861 * * [simplify]: Extracting #2: cost 7 inf + 0 1.861 * * [simplify]: Extracting #3: cost 2 inf + 326 1.861 * * [simplify]: Extracting #4: cost 0 inf + 1332 1.861 * [simplify]: Simplified to (+.p16 (*.p16 y.im x.re) (*.p16 y.re x.im)) 1.861 * [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)))) 1.861 * * * * [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))))> 1.861 * [simplify]: Simplifying (-.p16 (*.p16 x.im y.re) (*.p16 x.re y.im)) 1.861 * * [simplify]: iters left: 2 (7 enodes) 1.863 * * [simplify]: iters left: 1 (24 enodes) 1.869 * * [simplify]: Extracting #0: cost 1 inf + 0 1.869 * * [simplify]: Extracting #1: cost 6 inf + 0 1.869 * * [simplify]: Extracting #2: cost 15 inf + 0 1.869 * * [simplify]: Extracting #3: cost 19 inf + 728 1.870 * * [simplify]: Extracting #4: cost 3 inf + 11524 1.870 * * [simplify]: Extracting #5: cost 0 inf + 15936 1.871 * [simplify]: Simplified to (-.p16 (*.p16 y.re x.im) (*.p16 y.im x.re)) 1.871 * [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)))) 1.871 * * * * [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))))))> 1.871 * * * * [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))))))> 1.871 * * * * [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)))))> 1.871 * * * * [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)))))> 1.871 * [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)))) 1.871 * * [simplify]: iters left: 4 (14 enodes) 1.876 * * [simplify]: iters left: 3 (35 enodes) 1.885 * * [simplify]: iters left: 2 (74 enodes) 1.905 * * [simplify]: iters left: 1 (208 enodes) 2.021 * * [simplify]: Extracting #0: cost 1 inf + 0 2.022 * * [simplify]: Extracting #1: cost 24 inf + 0 2.022 * * [simplify]: Extracting #2: cost 157 inf + 0 2.023 * * [simplify]: Extracting #3: cost 232 inf + 646 2.025 * * [simplify]: Extracting #4: cost 277 inf + 15215 2.033 * * [simplify]: Extracting #5: cost 108 inf + 261189 2.049 * * [simplify]: Extracting #6: cost 10 inf + 467107 2.070 * * [simplify]: Extracting #7: cost 0 inf + 497790 2.093 * [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.093 * [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.093 * * * * [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.093 * [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.093 * * [simplify]: iters left: 4 (14 enodes) 2.096 * * [simplify]: iters left: 3 (35 enodes) 2.102 * * [simplify]: iters left: 2 (74 enodes) 2.119 * * [simplify]: iters left: 1 (208 enodes) 2.200 * * [simplify]: Extracting #0: cost 1 inf + 0 2.200 * * [simplify]: Extracting #1: cost 24 inf + 0 2.200 * * [simplify]: Extracting #2: cost 157 inf + 0 2.201 * * [simplify]: Extracting #3: cost 232 inf + 646 2.202 * * [simplify]: Extracting #4: cost 277 inf + 15215 2.209 * * [simplify]: Extracting #5: cost 108 inf + 261189 2.225 * * [simplify]: Extracting #6: cost 10 inf + 467107 2.243 * * [simplify]: Extracting #7: cost 0 inf + 497790 2.270 * [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.270 * [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.270 * * * * [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.270 * [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.270 * * [simplify]: iters left: 4 (14 enodes) 2.275 * * [simplify]: iters left: 3 (35 enodes) 2.284 * * [simplify]: iters left: 2 (74 enodes) 2.307 * * [simplify]: iters left: 1 (208 enodes) 2.412 * * [simplify]: Extracting #0: cost 1 inf + 0 2.412 * * [simplify]: Extracting #1: cost 24 inf + 0 2.413 * * [simplify]: Extracting #2: cost 157 inf + 0 2.414 * * [simplify]: Extracting #3: cost 232 inf + 646 2.416 * * [simplify]: Extracting #4: cost 277 inf + 15215 2.429 * * [simplify]: Extracting #5: cost 108 inf + 261189 2.458 * * [simplify]: Extracting #6: cost 10 inf + 467107 2.480 * * [simplify]: Extracting #7: cost 0 inf + 497790 2.499 * [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.499 * [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.499 * * * * [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)))))> 2.499 * [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.499 * * [simplify]: iters left: 4 (14 enodes) 2.502 * * [simplify]: iters left: 3 (35 enodes) 2.509 * * [simplify]: iters left: 2 (74 enodes) 2.533 * * [simplify]: iters left: 1 (208 enodes) 2.625 * * [simplify]: Extracting #0: cost 1 inf + 0 2.626 * * [simplify]: Extracting #1: cost 24 inf + 0 2.626 * * [simplify]: Extracting #2: cost 157 inf + 0 2.627 * * [simplify]: Extracting #3: cost 232 inf + 646 2.628 * * [simplify]: Extracting #4: cost 277 inf + 15215 2.635 * * [simplify]: Extracting #5: cost 108 inf + 261189 2.659 * * [simplify]: Extracting #6: cost 10 inf + 467107 2.683 * * [simplify]: Extracting #7: cost 0 inf + 497790 2.702 * [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.703 * [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.703 * * * [progress]: adding candidates to table 2.936 * [progress]: [Phase 3 of 3] Extracting. 2.936 * * [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)))))> #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 (+.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))))>) 2.939 * * * [regime-changes]: Trying 4 branch expressions: (y.im x.re y.re x.im) 2.939 * * * * [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)))))> #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 (+.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))))>) 3.103 * * * * [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)))))> #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 (+.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))))>) 3.276 * * * * [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)))))> #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 (+.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))))>) 3.444 * * * * [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)))))> #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 (+.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))))>) 3.611 * * * [regime]: Found split indices: #