
Time bar (total: 2.1s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 0 |
| 100% | 99.9% | 0% | 0.1% | 0% | 0% | 0% | 1 |
Compiled 9 to 7 computations (22.2% saved)
| 586.0ms | 8 256× | 0 | valid |
ival-mult: 390.0ms (89.6% of total)ival-sub: 36.0ms (8.3% of total)ival-true: 5.0ms (1.1% of total)ival-assert: 3.0ms (0.7% of total)adjust: 2.0ms (0.5% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 11 | 0 | - | 0 | - | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 0 | 0 | - | 0 | - | (*.f64 re re) |
| 0 | 0 | - | 0 | - | re |
| 0 | 0 | - | 0 | - | (*.f64 im im) |
| 0 | 0 | - | 0 | - | im |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
-.f64 | (-.f64 (*.f64 re re) (*.f64 im im)) | nan-rescue | 11 | 0 |
| ↳ | (*.f64 re re) | overflow | 56 | |
| ↳ | (*.f64 im im) | overflow | 51 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 11 | 0 |
| - | 0 | 245 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 11 | 0 | 0 |
| - | 0 | 0 | 245 |
| number | freq |
|---|---|
| 0 | 245 |
| 1 | 11 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 21.0ms | 512× | 0 | valid |
Compiled 41 to 19 computations (53.7% saved)
ival-mult: 7.0ms (73.3% of total)ival-sub: 2.0ms (21% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 13 | 38 |
| 1 | 48 | 35 |
| 2 | 215 | 35 |
| 3 | 371 | 35 |
| 4 | 909 | 35 |
| 5 | 1923 | 35 |
| 6 | 2926 | 35 |
| 7 | 3269 | 35 |
| 8 | 3347 | 35 |
| 9 | 3347 | 35 |
| 10 | 3546 | 35 |
| 0 | 5 | 7 |
| 0 | 8 | 7 |
| 1 | 21 | 7 |
| 2 | 81 | 7 |
| 3 | 223 | 7 |
| 4 | 403 | 7 |
| 5 | 836 | 7 |
| 6 | 1385 | 7 |
| 7 | 2069 | 7 |
| 8 | 2898 | 7 |
| 9 | 3208 | 7 |
| 10 | 3270 | 7 |
| 11 | 3270 | 7 |
| 12 | 3348 | 7 |
| 0 | 3348 | 7 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| 1× | saturated |
| Inputs |
|---|
(-.f64 (*.f64 re re) (*.f64 im im)) |
| Outputs |
|---|
(-.f64 (*.f64 re re) (*.f64 im im)) |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(abs im)
(abs re)
Compiled 7 to 5 computations (28.6% saved)
Compiled 0 to 2 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 95.7% | (-.f64 (*.f64 re re) (*.f64 im im)) |
Compiled 7 to 5 computations (28.6% saved)
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 im im) | |
| cost-diff | 0 | (*.f64 re re) | |
| cost-diff | 0 | (-.f64 (*.f64 re re) (*.f64 im im)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 5 | 15 |
| 0 | 8 | 15 |
| 1 | 21 | 15 |
| 2 | 81 | 15 |
| 3 | 223 | 15 |
| 4 | 403 | 15 |
| 5 | 836 | 15 |
| 6 | 1385 | 15 |
| 7 | 2069 | 15 |
| 8 | 2898 | 15 |
| 9 | 3208 | 15 |
| 10 | 3270 | 15 |
| 11 | 3270 | 15 |
| 12 | 3348 | 15 |
| 0 | 3348 | 15 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 (*.f64 re re) (*.f64 im im)) |
(*.f64 re re) |
re |
(*.f64 im im) |
im |
| Outputs |
|---|
(-.f64 (*.f64 re re) (*.f64 im im)) |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(*.f64 re re) |
re |
(*.f64 im im) |
im |
Found 3 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (*.f64 re re) | |
| accuracy | 0.0 | (*.f64 im im) | |
| accuracy | 2.347650057490618 | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 10.0ms | 256× | 0 | valid |
Compiled 17 to 7 computations (58.8% saved)
ival-mult: 3.0ms (66% of total)ival-sub: 1.0ms (22% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
(-.f64 (*.f64 re re) (*.f64 im im)) |
(*.f64 re re) |
(*.f64 im im) |
| Outputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(pow re 2) |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(pow im 2) |
(* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 5.0ms | re | @ | 0 | ((- (* re re) (* im im)) (* re re) (* im im)) |
| 1.0ms | re | @ | inf | ((- (* re re) (* im im)) (* re re) (* im im)) |
| 0.0ms | im | @ | inf | ((- (* re re) (* im im)) (* re re) (* im im)) |
| 0.0ms | re | @ | -inf | ((- (* re re) (* im im)) (* re re) (* im im)) |
| 0.0ms | im | @ | -inf | ((- (* re re) (* im im)) (* re re) (* im im)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 44 |
| 1 | 40 | 44 |
| 2 | 152 | 44 |
| 3 | 943 | 44 |
| 4 | 5541 | 44 |
| 0 | 8458 | 43 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(pow re 2) |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(pow im 2) |
(* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)) |
| Outputs |
|---|
(* -1 (pow im 2)) |
(*.f64 (neg.f64 im) im) |
(- (pow re 2) (pow im 2)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(pow re 2) |
(*.f64 re re) |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(pow im 2) |
(*.f64 im im) |
(* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)) |
(*.f64 (fma.f64 (/.f64 (/.f64 re im) im) re #s(literal -1 binary64)) (*.f64 im im)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 5 | 13 |
| 0 | 8 | 13 |
| 1 | 37 | 13 |
| 0 | 329 | 13 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
(-.f64 (*.f64 re re) (*.f64 im im)) |
(*.f64 re re) |
(*.f64 im im) |
| Outputs |
|---|
(*.f64 (+.f64 (neg.f64 re) (neg.f64 im)) (-.f64 (neg.f64 re) (neg.f64 im))) |
(*.f64 (+.f64 (neg.f64 re) (fabs.f64 im)) (-.f64 (neg.f64 re) (fabs.f64 im))) |
(*.f64 (+.f64 (neg.f64 re) im) (-.f64 (neg.f64 re) im)) |
(*.f64 (+.f64 (fabs.f64 re) (neg.f64 im)) (-.f64 (fabs.f64 re) (neg.f64 im))) |
(*.f64 (+.f64 (fabs.f64 re) (fabs.f64 im)) (-.f64 (fabs.f64 re) (fabs.f64 im))) |
(*.f64 (+.f64 (fabs.f64 re) im) (-.f64 (fabs.f64 re) im)) |
(*.f64 (+.f64 re (neg.f64 im)) (-.f64 re (neg.f64 im))) |
(*.f64 (+.f64 re (fabs.f64 im)) (-.f64 re (fabs.f64 im))) |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(*.f64 (+.f64 im re) (-.f64 re im)) |
(/.f64 (+.f64 (pow.f64 re #s(literal 6 binary64)) (pow.f64 (*.f64 (neg.f64 im) im) #s(literal 3 binary64))) (+.f64 (pow.f64 re #s(literal 4 binary64)) (-.f64 (pow.f64 im #s(literal 4 binary64)) (*.f64 (*.f64 re re) (*.f64 (neg.f64 im) im))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 re #s(literal 4 binary64)) (pow.f64 im #s(literal 4 binary64)))) (neg.f64 (fma.f64 im im (*.f64 re re)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 re #s(literal 6 binary64)) (pow.f64 im #s(literal 6 binary64)))) (neg.f64 (fma.f64 (*.f64 im im) (fma.f64 im im (*.f64 re re)) (pow.f64 re #s(literal 4 binary64))))) |
(/.f64 (-.f64 (pow.f64 re #s(literal 4 binary64)) (pow.f64 im #s(literal 4 binary64))) (fma.f64 im im (*.f64 re re))) |
(/.f64 (-.f64 (pow.f64 re #s(literal 6 binary64)) (pow.f64 im #s(literal 6 binary64))) (fma.f64 (*.f64 im im) (fma.f64 im im (*.f64 re re)) (pow.f64 re #s(literal 4 binary64)))) |
(fma.f64 (pow.f64 re #s(literal 1 binary64)) (pow.f64 re #s(literal 1 binary64)) (*.f64 (neg.f64 (neg.f64 im)) (neg.f64 im))) |
(fma.f64 (pow.f64 re #s(literal 1 binary64)) (pow.f64 re #s(literal 1 binary64)) (*.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im))) |
(fma.f64 (pow.f64 re #s(literal 1 binary64)) (pow.f64 re #s(literal 1 binary64)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re)) (*.f64 (neg.f64 (neg.f64 im)) (neg.f64 im))) |
(fma.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re)) (*.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im))) |
(fma.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re)) (*.f64 (neg.f64 (neg.f64 im)) (neg.f64 im))) |
(fma.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re)) (*.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im))) |
(fma.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re)) (*.f64 (neg.f64 (neg.f64 im)) (neg.f64 im))) |
(fma.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re)) (*.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im))) |
(fma.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(fma.f64 (neg.f64 re) (neg.f64 re) (*.f64 (neg.f64 (neg.f64 im)) (neg.f64 im))) |
(fma.f64 (neg.f64 re) (neg.f64 re) (*.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im))) |
(fma.f64 (neg.f64 re) (neg.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (fabs.f64 re) (fabs.f64 re) (*.f64 (neg.f64 (neg.f64 im)) (neg.f64 im))) |
(fma.f64 (fabs.f64 re) (fabs.f64 re) (*.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im))) |
(fma.f64 (fabs.f64 re) (fabs.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 im (neg.f64 im) (*.f64 re re)) |
(fma.f64 re re (*.f64 (neg.f64 (neg.f64 im)) (neg.f64 im))) |
(fma.f64 re re (*.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im))) |
(fma.f64 re re (*.f64 (neg.f64 im) im)) |
(-.f64 (/.f64 (pow.f64 re #s(literal 4 binary64)) (fma.f64 im im (*.f64 re re))) (/.f64 (pow.f64 im #s(literal 4 binary64)) (fma.f64 im im (*.f64 re re)))) |
(-.f64 (/.f64 (pow.f64 re #s(literal 6 binary64)) (fma.f64 (*.f64 im im) (fma.f64 im im (*.f64 re re)) (pow.f64 re #s(literal 4 binary64)))) (/.f64 (pow.f64 im #s(literal 6 binary64)) (fma.f64 (*.f64 im im) (fma.f64 im im (*.f64 re re)) (pow.f64 re #s(literal 4 binary64))))) |
(-.f64 (*.f64 re re) (*.f64 (neg.f64 (neg.f64 im)) im)) |
(-.f64 (*.f64 re re) (*.f64 im im)) |
(+.f64 (*.f64 (neg.f64 im) im) (*.f64 re re)) |
(+.f64 (*.f64 re re) (*.f64 (neg.f64 (neg.f64 im)) (neg.f64 im))) |
(+.f64 (*.f64 re re) (*.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im))) |
(+.f64 (*.f64 re re) (*.f64 (neg.f64 im) im)) |
(*.f64 (pow.f64 re #s(literal 1 binary64)) (pow.f64 re #s(literal 1 binary64))) |
(*.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re))) |
(*.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re))) |
(*.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re))) |
(*.f64 (neg.f64 re) (neg.f64 re)) |
(*.f64 (fabs.f64 re) (fabs.f64 re)) |
(*.f64 re re) |
(pow.f64 (neg.f64 re) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 re) #s(literal 2 binary64)) |
(pow.f64 re #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 re) re)) |
(neg.f64 (*.f64 re (neg.f64 re))) |
(fabs.f64 (*.f64 re re)) |
(exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) |
(*.f64 (pow.f64 im #s(literal 1 binary64)) (pow.f64 im #s(literal 1 binary64))) |
(*.f64 (neg.f64 (neg.f64 im)) (neg.f64 (neg.f64 im))) |
(*.f64 (neg.f64 (fabs.f64 im)) (neg.f64 (fabs.f64 im))) |
(*.f64 (fabs.f64 (fabs.f64 im)) (fabs.f64 (fabs.f64 im))) |
(*.f64 (neg.f64 im) (neg.f64 im)) |
(*.f64 (fabs.f64 im) (fabs.f64 im)) |
(*.f64 im im) |
(pow.f64 (neg.f64 im) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 im) #s(literal 2 binary64)) |
(pow.f64 im #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 im) im)) |
(fabs.f64 (*.f64 im im)) |
(exp.f64 (*.f64 (log.f64 im) #s(literal 2 binary64))) |
Compiled 866 to 181 computations (79.1% saved)
2 alts after pruning (2 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 76 | 2 | 78 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 77 | 2 | 79 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 (-.f64 re im) (+.f64 im re)) |
| ▶ | 51.3% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
Compiled 19 to 13 computations (31.6% saved)
Found 6 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (+.f64 im re) | |
| cost-diff | 0 | (-.f64 re im) | |
| cost-diff | 0 | (*.f64 (-.f64 re im) (+.f64 im re)) | |
| cost-diff | 0 | (neg.f64 im) | |
| cost-diff | 0 | (*.f64 (neg.f64 im) im) | |
| cost-diff | 0 | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 11 | 34 |
| 0 | 16 | 34 |
| 1 | 35 | 34 |
| 2 | 101 | 34 |
| 3 | 248 | 34 |
| 4 | 431 | 34 |
| 5 | 861 | 34 |
| 6 | 1399 | 34 |
| 7 | 2083 | 34 |
| 8 | 2913 | 34 |
| 9 | 3223 | 34 |
| 10 | 3285 | 34 |
| 11 | 3285 | 34 |
| 12 | 3363 | 34 |
| 0 | 3363 | 34 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
(*.f64 (neg.f64 im) im) |
(neg.f64 im) |
im |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(-.f64 re im) |
re |
im |
(+.f64 im re) |
| Outputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
(*.f64 (neg.f64 im) im) |
(neg.f64 im) |
im |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(*.f64 (+.f64 im re) (-.f64 re im)) |
(-.f64 re im) |
re |
im |
(+.f64 im re) |
Found 6 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (-.f64 re im) | |
| accuracy | 0.0 | (+.f64 im re) | |
| accuracy | 0.0 | (*.f64 (-.f64 re im) (+.f64 im re)) | |
| accuracy | 0.0 | (*.f64 (neg.f64 im) im) | |
| accuracy | 0.0 | (neg.f64 im) | |
| accuracy | 31.15762438484035 | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| 20.0ms | 256× | 0 | valid |
Compiled 31 to 12 computations (61.3% saved)
ival-mult: 6.0ms (55.3% of total)ival-sub: 2.0ms (18.4% of total)ival-add: 1.0ms (9.2% of total)ival-neg: 1.0ms (9.2% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
(*.f64 (neg.f64 im) im) |
(neg.f64 im) |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(-.f64 re im) |
(+.f64 im re) |
| Outputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(+ (* -1 (pow im 2)) (* re (+ im (* -1 im)))) |
(+ (* -1 (pow im 2)) (* re (+ im (+ re (* -1 im))))) |
(* -1 im) |
(- re im) |
im |
(+ im re) |
(pow re 2) |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (/ im re)))) |
(* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (+ (* -1 (/ (pow im 2) (pow re 2))) (/ im re))))) |
re |
(* re (+ 1 (* -1 (/ im re)))) |
(* re (+ 1 (/ im re))) |
(* (pow re 2) (+ 1 (* -1 (/ (+ (* -1 (+ im (* -1 im))) (/ (pow im 2) re)) re)))) |
(* -1 (* re (- (/ im re) 1))) |
(* -1 (* re (- (* -1 (/ im re)) 1))) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(+ (* im (+ re (* -1 re))) (pow re 2)) |
(+ (* im (+ re (+ (* -1 im) (* -1 re)))) (pow re 2)) |
(+ re (* -1 im)) |
(* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)) |
(* (pow im 2) (- (+ (* -1 (/ re im)) (/ re im)) 1)) |
(* (pow im 2) (- (+ (* -1 (/ re im)) (+ (/ re im) (/ (pow re 2) (pow im 2)))) 1)) |
(* im (- (/ re im) 1)) |
(* im (+ 1 (/ re im))) |
(* (pow im 2) (- (* -1 (/ (+ re (* -1 re)) im)) 1)) |
(* (pow im 2) (- (* -1 (/ (+ re (+ (* -1 re) (* -1 (/ (pow re 2) im)))) im)) 1)) |
(* -1 (* im (+ 1 (* -1 (/ re im))))) |
(* -1 (* im (- (* -1 (/ re im)) 1))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | im | @ | -inf | ((- (* re re) (* im im)) (* (neg im) im) (neg im) (* (- re im) (+ im re)) (- re im) (+ im re)) |
| 1.0ms | im | @ | inf | ((- (* re re) (* im im)) (* (neg im) im) (neg im) (* (- re im) (+ im re)) (- re im) (+ im re)) |
| 1.0ms | re | @ | inf | ((- (* re re) (* im im)) (* (neg im) im) (neg im) (* (- re im) (+ im re)) (- re im) (+ im re)) |
| 1.0ms | re | @ | -inf | ((- (* re re) (* im im)) (* (neg im) im) (neg im) (* (- re im) (+ im re)) (- re im) (+ im re)) |
| 1.0ms | im | @ | 0 | ((- (* re re) (* im im)) (* (neg im) im) (neg im) (* (- re im) (+ im re)) (- re im) (+ im re)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 92 | 207 |
| 1 | 301 | 200 |
| 2 | 1134 | 200 |
| 0 | 8147 | 193 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(+ (* -1 (pow im 2)) (* re (+ im (* -1 im)))) |
(+ (* -1 (pow im 2)) (* re (+ im (+ re (* -1 im))))) |
(* -1 im) |
(- re im) |
im |
(+ im re) |
(pow re 2) |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (/ im re)))) |
(* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (+ (* -1 (/ (pow im 2) (pow re 2))) (/ im re))))) |
re |
(* re (+ 1 (* -1 (/ im re)))) |
(* re (+ 1 (/ im re))) |
(* (pow re 2) (+ 1 (* -1 (/ (+ (* -1 (+ im (* -1 im))) (/ (pow im 2) re)) re)))) |
(* -1 (* re (- (/ im re) 1))) |
(* -1 (* re (- (* -1 (/ im re)) 1))) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(+ (* im (+ re (* -1 re))) (pow re 2)) |
(+ (* im (+ re (+ (* -1 im) (* -1 re)))) (pow re 2)) |
(+ re (* -1 im)) |
(* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)) |
(* (pow im 2) (- (+ (* -1 (/ re im)) (/ re im)) 1)) |
(* (pow im 2) (- (+ (* -1 (/ re im)) (+ (/ re im) (/ (pow re 2) (pow im 2)))) 1)) |
(* im (- (/ re im) 1)) |
(* im (+ 1 (/ re im))) |
(* (pow im 2) (- (* -1 (/ (+ re (* -1 re)) im)) 1)) |
(* (pow im 2) (- (* -1 (/ (+ re (+ (* -1 re) (* -1 (/ (pow re 2) im)))) im)) 1)) |
(* -1 (* im (+ 1 (* -1 (/ re im))))) |
(* -1 (* im (- (* -1 (/ re im)) 1))) |
| Outputs |
|---|
(* -1 (pow im 2)) |
(*.f64 (neg.f64 im) im) |
(- (pow re 2) (pow im 2)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(+ (* -1 (pow im 2)) (* re (+ im (* -1 im)))) |
(*.f64 (neg.f64 im) im) |
(+ (* -1 (pow im 2)) (* re (+ im (+ re (* -1 im))))) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(* -1 im) |
(neg.f64 im) |
(- re im) |
(-.f64 re im) |
im |
(+ im re) |
(+.f64 im re) |
(pow re 2) |
(*.f64 re re) |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(*.f64 (neg.f64 (*.f64 re (fma.f64 (/.f64 im re) (/.f64 im re) #s(literal -1 binary64)))) re) |
(* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (/ im re)))) |
(*.f64 re re) |
(* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (+ (* -1 (/ (pow im 2) (pow re 2))) (/ im re))))) |
(*.f64 (neg.f64 (*.f64 re (fma.f64 (/.f64 im re) (/.f64 im re) #s(literal -1 binary64)))) re) |
re |
(* re (+ 1 (* -1 (/ im re)))) |
(*.f64 (-.f64 #s(literal 1 binary64) (/.f64 im re)) re) |
(* re (+ 1 (/ im re))) |
(fma.f64 (/.f64 im re) re re) |
(* (pow re 2) (+ 1 (* -1 (/ (+ (* -1 (+ im (* -1 im))) (/ (pow im 2) re)) re)))) |
(*.f64 (neg.f64 (*.f64 re (fma.f64 (/.f64 im re) (/.f64 im re) #s(literal -1 binary64)))) re) |
(* -1 (* re (- (/ im re) 1))) |
(*.f64 (-.f64 #s(literal 1 binary64) (/.f64 im re)) re) |
(* -1 (* re (- (* -1 (/ im re)) 1))) |
(fma.f64 (/.f64 im re) re re) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(+ (* im (+ re (* -1 re))) (pow re 2)) |
(*.f64 re re) |
(+ (* im (+ re (+ (* -1 im) (* -1 re)))) (pow re 2)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(+ re (* -1 im)) |
(-.f64 re im) |
(* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)) |
(*.f64 (fma.f64 (/.f64 (/.f64 re im) im) re #s(literal -1 binary64)) (*.f64 im im)) |
(* (pow im 2) (- (+ (* -1 (/ re im)) (/ re im)) 1)) |
(*.f64 (neg.f64 im) im) |
(* (pow im 2) (- (+ (* -1 (/ re im)) (+ (/ re im) (/ (pow re 2) (pow im 2)))) 1)) |
(*.f64 (fma.f64 (/.f64 (/.f64 re im) im) re #s(literal -1 binary64)) (*.f64 im im)) |
(* im (- (/ re im) 1)) |
(*.f64 (-.f64 (/.f64 re im) #s(literal 1 binary64)) im) |
(* im (+ 1 (/ re im))) |
(fma.f64 (/.f64 re im) im im) |
(* (pow im 2) (- (* -1 (/ (+ re (* -1 re)) im)) 1)) |
(*.f64 (neg.f64 im) im) |
(* (pow im 2) (- (* -1 (/ (+ re (+ (* -1 re) (* -1 (/ (pow re 2) im)))) im)) 1)) |
(*.f64 (fma.f64 (/.f64 (/.f64 re im) im) re #s(literal -1 binary64)) (*.f64 im im)) |
(* -1 (* im (+ 1 (* -1 (/ re im))))) |
(*.f64 (-.f64 (/.f64 re im) #s(literal 1 binary64)) im) |
(* -1 (* im (- (* -1 (/ re im)) 1))) |
(fma.f64 (/.f64 re im) im im) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 11 | 31 |
| 0 | 16 | 31 |
| 1 | 68 | 31 |
| 0 | 610 | 31 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
(*.f64 (neg.f64 im) im) |
(neg.f64 im) |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(-.f64 re im) |
(+.f64 im re) |
| Outputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
(*.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im)) |
(*.f64 (neg.f64 (neg.f64 im)) (neg.f64 im)) |
(*.f64 (fabs.f64 im) (neg.f64 (fabs.f64 im))) |
(*.f64 (neg.f64 im) (neg.f64 (neg.f64 im))) |
(*.f64 (neg.f64 im) im) |
(*.f64 im (neg.f64 im)) |
(neg.f64 (*.f64 im im)) |
(neg.f64 im) |
(*.f64 (+.f64 (neg.f64 re) (fabs.f64 im)) (-.f64 (neg.f64 re) (fabs.f64 im))) |
(*.f64 (+.f64 (neg.f64 re) (neg.f64 im)) (-.f64 (neg.f64 re) (neg.f64 im))) |
(*.f64 (+.f64 (neg.f64 re) im) (-.f64 (neg.f64 re) im)) |
(*.f64 (+.f64 (fabs.f64 re) (fabs.f64 im)) (-.f64 (fabs.f64 re) (fabs.f64 im))) |
(*.f64 (+.f64 (fabs.f64 re) (neg.f64 im)) (-.f64 (fabs.f64 re) (neg.f64 im))) |
(*.f64 (+.f64 (fabs.f64 re) im) (-.f64 (fabs.f64 re) im)) |
(*.f64 (+.f64 re (fabs.f64 im)) (-.f64 re (fabs.f64 im))) |
(*.f64 (+.f64 re (neg.f64 im)) (-.f64 re (neg.f64 im))) |
(*.f64 (+.f64 im re) (-.f64 re im)) |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(/.f64 (*.f64 (*.f64 (+.f64 im re) (-.f64 im re)) (-.f64 re im)) (-.f64 im re)) |
(/.f64 (*.f64 (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64))) (-.f64 re im)) (fma.f64 (-.f64 re im) re (*.f64 im im))) |
(/.f64 (*.f64 (-.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64))) (+.f64 im re)) (fma.f64 im (+.f64 im re) (*.f64 re re))) |
(/.f64 (*.f64 (*.f64 (+.f64 im re) (-.f64 re im)) (+.f64 im re)) (+.f64 im re)) |
(/.f64 (*.f64 (+.f64 im re) (-.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) (fma.f64 im (+.f64 im re) (*.f64 re re))) |
(/.f64 (*.f64 (+.f64 im re) (*.f64 (+.f64 im re) (-.f64 re im))) (+.f64 im re)) |
(/.f64 (*.f64 (-.f64 re im) (*.f64 (+.f64 im re) (-.f64 im re))) (-.f64 im re)) |
(/.f64 (*.f64 (-.f64 re im) (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) (fma.f64 (-.f64 re im) re (*.f64 im im))) |
(/.f64 (-.f64 (*.f64 (*.f64 (-.f64 re im) im) (*.f64 (-.f64 re im) im)) (*.f64 (*.f64 (-.f64 re im) re) (*.f64 (-.f64 re im) re))) (-.f64 (*.f64 (-.f64 re im) im) (*.f64 (-.f64 re im) re))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (-.f64 re im) im) #s(literal 3 binary64)) (pow.f64 (*.f64 (-.f64 re im) re) #s(literal 3 binary64))) (fma.f64 (*.f64 (-.f64 re im) im) (*.f64 (-.f64 re im) im) (-.f64 (*.f64 (*.f64 (-.f64 re im) re) (*.f64 (-.f64 re im) re)) (*.f64 (*.f64 (-.f64 re im) im) (*.f64 (-.f64 re im) re))))) |
(/.f64 (+.f64 (pow.f64 re #s(literal 6 binary64)) (pow.f64 (*.f64 (neg.f64 im) im) #s(literal 3 binary64))) (+.f64 (pow.f64 re #s(literal 4 binary64)) (-.f64 (pow.f64 im #s(literal 4 binary64)) (*.f64 (*.f64 re re) (*.f64 (neg.f64 im) im))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 re #s(literal 4 binary64)) (pow.f64 im #s(literal 4 binary64)))) (neg.f64 (fma.f64 im im (*.f64 re re)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 re #s(literal 6 binary64)) (pow.f64 im #s(literal 6 binary64)))) (neg.f64 (fma.f64 (*.f64 im im) (fma.f64 im im (*.f64 re re)) (pow.f64 re #s(literal 4 binary64))))) |
(/.f64 (*.f64 (*.f64 (+.f64 im re) (-.f64 im re)) (-.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) (*.f64 (-.f64 im re) (fma.f64 im (+.f64 im re) (*.f64 re re)))) |
(/.f64 (*.f64 (*.f64 (+.f64 im re) (-.f64 im re)) (*.f64 (+.f64 im re) (-.f64 re im))) (*.f64 (-.f64 im re) (+.f64 im re))) |
(/.f64 (*.f64 (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64))) (-.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) (*.f64 (fma.f64 (-.f64 re im) re (*.f64 im im)) (fma.f64 im (+.f64 im re) (*.f64 re re)))) |
(/.f64 (*.f64 (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64))) (*.f64 (+.f64 im re) (-.f64 re im))) (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) |
(/.f64 (*.f64 (-.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64))) (*.f64 (+.f64 im re) (-.f64 im re))) (*.f64 (fma.f64 im (+.f64 im re) (*.f64 re re)) (-.f64 im re))) |
(/.f64 (*.f64 (-.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64))) (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) (*.f64 (fma.f64 im (+.f64 im re) (*.f64 re re)) (fma.f64 (-.f64 re im) re (*.f64 im im)))) |
(/.f64 (*.f64 (*.f64 (+.f64 im re) (-.f64 re im)) (*.f64 (+.f64 im re) (-.f64 im re))) (*.f64 (+.f64 im re) (-.f64 im re))) |
(/.f64 (*.f64 (*.f64 (+.f64 im re) (-.f64 re im)) (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) (*.f64 (+.f64 im re) (fma.f64 (-.f64 re im) re (*.f64 im im)))) |
(/.f64 (-.f64 (pow.f64 re #s(literal 4 binary64)) (pow.f64 im #s(literal 4 binary64))) (fma.f64 im im (*.f64 re re))) |
(/.f64 (-.f64 (pow.f64 re #s(literal 6 binary64)) (pow.f64 im #s(literal 6 binary64))) (fma.f64 (*.f64 im im) (fma.f64 im im (*.f64 re re)) (pow.f64 re #s(literal 4 binary64)))) |
(fma.f64 (pow.f64 re #s(literal 1 binary64)) (pow.f64 re #s(literal 1 binary64)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 (fabs.f64 im)) (fabs.f64 im) (*.f64 re re)) |
(fma.f64 (neg.f64 (neg.f64 im)) (neg.f64 im) (*.f64 re re)) |
(fma.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 re) (neg.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (fabs.f64 im) (neg.f64 (fabs.f64 im)) (*.f64 re re)) |
(fma.f64 (fabs.f64 re) (fabs.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (-.f64 re im) im (*.f64 (-.f64 re im) re)) |
(fma.f64 (-.f64 re im) re (*.f64 (-.f64 re im) im)) |
(fma.f64 (neg.f64 im) (neg.f64 (neg.f64 im)) (*.f64 re re)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(fma.f64 im (-.f64 re im) (*.f64 (-.f64 re im) re)) |
(fma.f64 im (neg.f64 im) (*.f64 re re)) |
(fma.f64 re (-.f64 re im) (*.f64 (-.f64 re im) im)) |
(fma.f64 re re (*.f64 (neg.f64 im) im)) |
(-.f64 (/.f64 (pow.f64 re #s(literal 4 binary64)) (fma.f64 im im (*.f64 re re))) (/.f64 (pow.f64 im #s(literal 4 binary64)) (fma.f64 im im (*.f64 re re)))) |
(-.f64 (/.f64 (pow.f64 re #s(literal 6 binary64)) (fma.f64 (*.f64 im im) (fma.f64 im im (*.f64 re re)) (pow.f64 re #s(literal 4 binary64)))) (/.f64 (pow.f64 im #s(literal 6 binary64)) (fma.f64 (*.f64 im im) (fma.f64 im im (*.f64 re re)) (pow.f64 re #s(literal 4 binary64))))) |
(-.f64 (*.f64 (-.f64 re im) im) (*.f64 (neg.f64 re) (-.f64 re im))) |
(-.f64 (*.f64 (-.f64 re im) im) (*.f64 (neg.f64 (-.f64 re im)) re)) |
(-.f64 (*.f64 re re) (*.f64 (neg.f64 (neg.f64 im)) im)) |
(-.f64 (*.f64 re re) (*.f64 im im)) |
(+.f64 (*.f64 (-.f64 re im) re) (*.f64 (-.f64 re im) im)) |
(+.f64 (*.f64 (-.f64 re im) im) (*.f64 (-.f64 re im) re)) |
(+.f64 (*.f64 (neg.f64 im) im) (*.f64 re re)) |
(+.f64 (*.f64 re re) (*.f64 (neg.f64 im) im)) |
(*.f64 (/.f64 (*.f64 (+.f64 im re) (-.f64 re im)) (*.f64 (+.f64 im re) (-.f64 im re))) (-.f64 im re)) |
(*.f64 (/.f64 (*.f64 (+.f64 im re) (-.f64 re im)) (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) (fma.f64 (-.f64 re im) re (*.f64 im im))) |
(*.f64 (+.f64 im re) (/.f64 (-.f64 re im) (+.f64 im re))) |
(*.f64 (-.f64 re im) (/.f64 (+.f64 im re) (+.f64 im re))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) (neg.f64 (fma.f64 im (+.f64 im re) (*.f64 re re)))) |
(/.f64 (neg.f64 (*.f64 (+.f64 im re) (-.f64 re im))) (neg.f64 (+.f64 im re))) |
(/.f64 (-.f64 (pow.f64 re #s(literal 4 binary64)) (pow.f64 im #s(literal 4 binary64))) (*.f64 (fma.f64 im im (*.f64 re re)) (+.f64 im re))) |
(/.f64 (-.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64))) (fma.f64 im (+.f64 im re) (*.f64 re re))) |
(/.f64 (-.f64 (pow.f64 re #s(literal 6 binary64)) (pow.f64 im #s(literal 6 binary64))) (*.f64 (fma.f64 (*.f64 im im) (fma.f64 im im (*.f64 re re)) (pow.f64 re #s(literal 4 binary64))) (+.f64 im re))) |
(/.f64 (*.f64 (+.f64 im re) (-.f64 re im)) (+.f64 im re)) |
(-.f64 (/.f64 (pow.f64 re #s(literal 3 binary64)) (fma.f64 im (+.f64 im re) (*.f64 re re))) (/.f64 (pow.f64 im #s(literal 3 binary64)) (fma.f64 im (+.f64 im re) (*.f64 re re)))) |
(-.f64 (/.f64 (*.f64 re re) (+.f64 im re)) (/.f64 (*.f64 im im) (+.f64 im re))) |
(-.f64 re im) |
(+.f64 (/.f64 (*.f64 (-.f64 re im) im) (+.f64 im re)) (/.f64 (*.f64 (-.f64 re im) re) (+.f64 im re))) |
(+.f64 (/.f64 (*.f64 re re) (+.f64 im re)) (/.f64 (*.f64 (neg.f64 im) im) (+.f64 im re))) |
(/.f64 (neg.f64 (*.f64 (+.f64 im re) (-.f64 im re))) (neg.f64 (-.f64 im re))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64)))) (neg.f64 (fma.f64 (-.f64 re im) re (*.f64 im im)))) |
(/.f64 (*.f64 (+.f64 im re) (-.f64 im re)) (-.f64 im re)) |
(/.f64 (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64))) (fma.f64 re re (-.f64 (*.f64 im im) (*.f64 im re)))) |
(/.f64 (+.f64 (pow.f64 re #s(literal 3 binary64)) (pow.f64 im #s(literal 3 binary64))) (fma.f64 (-.f64 re im) re (*.f64 im im))) |
(/.f64 (*.f64 (+.f64 im re) (-.f64 re im)) (-.f64 re im)) |
(-.f64 (/.f64 (*.f64 im im) (-.f64 im re)) (/.f64 (*.f64 re re) (-.f64 im re))) |
(+.f64 (/.f64 (pow.f64 im #s(literal 3 binary64)) (fma.f64 (-.f64 re im) re (*.f64 im im))) (/.f64 (pow.f64 re #s(literal 3 binary64)) (fma.f64 (-.f64 re im) re (*.f64 im im)))) |
(+.f64 im re) |
(+.f64 re im) |
Compiled 1 761 to 296 computations (83.2% saved)
3 alts after pruning (1 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 109 | 1 | 110 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 0 | 0 |
| Total | 109 | 3 | 112 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (-.f64 re im) (+.f64 im re)) |
| ✓ | 51.3% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| ▶ | 59.3% | #s(approx (- (* re re) (* im im)) (*.f64 re re)) |
Compiled 30 to 20 computations (33.3% saved)
Found 2 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| cost-diff | 0 | (*.f64 re re) | |
| cost-diff | 0 | #s(approx (- (* re re) (* im im)) (*.f64 re re)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 15 |
| 0 | 8 | 15 |
| 1 | 21 | 15 |
| 2 | 81 | 15 |
| 3 | 223 | 15 |
| 4 | 401 | 15 |
| 5 | 828 | 15 |
| 6 | 1379 | 15 |
| 7 | 2063 | 15 |
| 8 | 2900 | 15 |
| 9 | 3210 | 15 |
| 10 | 3272 | 15 |
| 11 | 3272 | 15 |
| 12 | 3350 | 15 |
| 0 | 3350 | 15 |
| 1× | iter limit |
| 1× | saturated |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
(*.f64 re re) |
re |
| Outputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
(*.f64 re re) |
re |
Found 2 expressions of interest:
| New | Metric | Score | Program |
|---|---|---|---|
| accuracy | 0.0 | (*.f64 re re) | |
| accuracy | 26.0509222637776 | #s(approx (- (* re re) (* im im)) (*.f64 re re)) |
| 9.0ms | 256× | 0 | valid |
Compiled 13 to 7 computations (46.2% saved)
ival-mult: 3.0ms (66.5% of total)ival-sub: 1.0ms (22.2% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
(*.f64 re re) |
| Outputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(pow re 2) |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 20.0ms | im | @ | 0 | ((- (* re re) (* im im)) (* re re)) |
| 0.0ms | re | @ | inf | ((- (* re re) (* im im)) (* re re)) |
| 0.0ms | re | @ | -inf | ((- (* re re) (* im im)) (* re re)) |
| 0.0ms | im | @ | inf | ((- (* re re) (* im im)) (* re re)) |
| 0.0ms | re | @ | 0 | ((- (* re re) (* im im)) (* re re)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 41 |
| 1 | 40 | 41 |
| 2 | 152 | 41 |
| 3 | 943 | 41 |
| 4 | 5541 | 41 |
| 0 | 8458 | 40 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(pow re 2) |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)) |
| Outputs |
|---|
(* -1 (pow im 2)) |
(*.f64 (neg.f64 im) im) |
(- (pow re 2) (pow im 2)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(pow re 2) |
(*.f64 re re) |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)) |
(*.f64 (fma.f64 (/.f64 (/.f64 re im) im) re #s(literal -1 binary64)) (*.f64 im im)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 7 | 14 |
| 0 | 8 | 14 |
| 1 | 37 | 14 |
| 0 | 329 | 14 |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
(*.f64 re re) |
| Outputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
(*.f64 (pow.f64 re #s(literal 1 binary64)) (pow.f64 re #s(literal 1 binary64))) |
(*.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re))) |
(*.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re))) |
(*.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re))) |
(*.f64 (neg.f64 re) (neg.f64 re)) |
(*.f64 (fabs.f64 re) (fabs.f64 re)) |
(*.f64 re re) |
(pow.f64 (neg.f64 re) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 re) #s(literal 2 binary64)) |
(pow.f64 re #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 re) re)) |
(neg.f64 (*.f64 re (neg.f64 re))) |
(fabs.f64 (*.f64 re re)) |
(exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) |
Compiled 256 to 59 computations (77% saved)
3 alts after pruning (0 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 19 | 0 | 19 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 2 | 2 |
| Total | 19 | 3 | 22 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (-.f64 re im) (+.f64 im re)) |
| ✓ | 51.3% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| ✓ | 59.3% | #s(approx (- (* re re) (* im im)) (*.f64 re re)) |
Compiled 67 to 35 computations (47.8% saved)
| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
#s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(-.f64 (*.f64 re re) (*.f64 im im)) |
| Outputs |
|---|
(*.f64 (-.f64 re im) (+.f64 im re)) |
5 calls:
| 9.0ms | (*.f64 re re) |
| 2.0ms | im |
| 2.0ms | re |
| 2.0ms | (*.f64 im im) |
| 2.0ms | (-.f64 (*.f64 re re) (*.f64 im im)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | (*.f64 im im) |
| 100.0% | 1 | (*.f64 re re) |
| 100.0% | 1 | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 100.0% | 1 | re |
| 100.0% | 1 | im |
Compiled 15 to 15 computations (0% saved)
| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
#s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| Outputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
5 calls:
| 1.0ms | re |
| 1.0ms | im |
| 1.0ms | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 1.0ms | (*.f64 re re) |
| 1.0ms | (*.f64 im im) |
| Accuracy | Segments | Branch |
|---|---|---|
| 77.7% | 2 | (*.f64 im im) |
| 79.1% | 2 | (*.f64 re re) |
| 98.6% | 2 | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 79.1% | 2 | re |
| 77.7% | 2 | im |
Compiled 15 to 15 computations (0% saved)
Total 0.0b remaining (0%)
Threshold costs 0b (0%)
| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
| Outputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
5 calls:
| 1.0ms | re |
| 1.0ms | im |
| 1.0ms | (*.f64 re re) |
| 1.0ms | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 1.0ms | (*.f64 im im) |
| Accuracy | Segments | Branch |
|---|---|---|
| 59.3% | 1 | (*.f64 im im) |
| 59.3% | 1 | im |
| 59.3% | 1 | (*.f64 re re) |
| 59.3% | 1 | re |
| 59.3% | 1 | (-.f64 (*.f64 re re) (*.f64 im im)) |
Compiled 15 to 15 computations (0% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -1.097e-321 | 0.0 |
Compiled 10 to 10 computations (0% saved)
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 18 | 51 |
| 1 | 39 | 51 |
| 2 | 104 | 51 |
| 3 | 247 | 51 |
| 4 | 425 | 51 |
| 5 | 860 | 51 |
| 6 | 1409 | 51 |
| 7 | 2093 | 51 |
| 8 | 2924 | 51 |
| 9 | 3234 | 51 |
| 10 | 3296 | 51 |
| 11 | 3296 | 51 |
| 12 | 3374 | 51 |
| 1× | saturated |
| Inputs |
|---|
(*.f64 (-.f64 re im) (+.f64 im re)) |
(if (<=.f64 (-.f64 (*.f64 re re) (*.f64 im im)) #s(literal -101/101201126653655309176247673359458653524778324882071059178450679013715169783997673445980191850718562247593538932158405955694904368692896738433506699970369254960758712138283180682233453871046608170619883839236372534281003741712346349309051677824579778170405028256179384776166707307615251266093163754323003131653853870546747392 binary64)) #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) #s(approx (- (* re re) (* im im)) (*.f64 re re))) |
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
| Outputs |
|---|
(*.f64 (-.f64 re im) (+.f64 im re)) |
(if (<=.f64 (-.f64 (*.f64 re re) (*.f64 im im)) #s(literal -101/101201126653655309176247673359458653524778324882071059178450679013715169783997673445980191850718562247593538932158405955694904368692896738433506699970369254960758712138283180682233453871046608170619883839236372534281003741712346349309051677824579778170405028256179384776166707307615251266093163754323003131653853870546747392 binary64)) #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) #s(approx (- (* re re) (* im im)) (*.f64 re re))) |
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
| 1× | done |
Compiled 51 to 18 computations (64.7% saved)
(abs re)
(abs im)
Compiled 144 to 66 computations (54.2% saved)
Loading profile data...