
Time bar (total: 3.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)
| 619.0ms | 8 255× | 0 | valid |
| 0.0ms | 1× | 1 | valid |
ival-mult: 128.0ms (65.1% of total)ival-sub: 58.0ms (29.5% of total)ival-true: 6.0ms (3.1% of total)ival-assert: 3.0ms (1.5% of total)adjust: 2.0ms (1% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 18 | 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 | 18 | 0 |
| ↳ | (*.f64 re re) | overflow | 59 | |
| ↳ | (*.f64 im im) | overflow | 54 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 18 | 0 |
| - | 0 | 238 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 18 | 0 | 0 |
| - | 0 | 0 | 238 |
| number | freq |
|---|---|
| 0 | 238 |
| 1 | 18 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 22.0ms | 512× | 0 | valid |
Compiled 41 to 19 computations (53.7% saved)
ival-mult: 7.0ms (70.3% of total)ival-sub: 2.0ms (20.1% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | egg-herbie |
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 |
|---|---|---|
| ▶ | 93.0% | (-.f64 (*.f64 re re) (*.f64 im im)) |
Compiled 7 to 5 computations (28.6% saved)
| 1× | egg-herbie |
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 | 4.093729358302059 | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 10.0ms | 256× | 0 | valid |
Compiled 17 to 7 computations (58.8% saved)
ival-mult: 3.0ms (64.4% of total)ival-sub: 1.0ms (21.5% 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 | |
|---|---|---|---|---|
| 1.0ms | re | @ | inf | ((- (* re re) (* im im)) (* re re) (* im im)) |
| 1.0ms | re | @ | 0 | ((- (* re re) (* im im)) (* re re) (* im im)) |
| 0.0ms | im | @ | 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)) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 44 |
| 1 | 40 | 44 |
| 2 | 152 | 44 |
| 3 | 943 | 44 |
| 4 | 5676 | 44 |
| 0 | 8028 | 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)) |
| ▶ | 53.0% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
Compiled 19 to 13 computations (31.6% saved)
| 1× | egg-herbie |
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 | 30.071864016962017 | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| 23.0ms | 256× | 0 | valid |
Compiled 31 to 12 computations (61.3% saved)
ival-mult: 6.0ms (46% of total)ival-neg: 3.0ms (23% of total)ival-sub: 2.0ms (15.3% of total)ival-add: 1.0ms (7.7% 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)) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 92 | 207 |
| 1 | 301 | 200 |
| 2 | 1134 | 200 |
| 0 | 8149 | 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)) |
| ✓ | 53.0% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| ▶ | 51.5% | #s(approx (- (* re re) (* im im)) (*.f64 re re)) |
Compiled 30 to 20 computations (33.3% saved)
| 1× | egg-herbie |
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 | 31.060079738704232 | #s(approx (- (* re re) (* im im)) (*.f64 re re)) |
| 10.0ms | 256× | 0 | valid |
Compiled 13 to 7 computations (46.2% saved)
ival-mult: 3.0ms (64.7% of total)ival-sub: 1.0ms (21.6% 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 | |
|---|---|---|---|---|
| 3.0ms | re | @ | inf | ((- (* re re) (* im im)) (* re re)) |
| 0.0ms | re | @ | -inf | ((- (* re re) (* im im)) (* re re)) |
| 0.0ms | re | @ | 0 | ((- (* re re) (* im im)) (* re re)) |
| 0.0ms | im | @ | -inf | ((- (* re re) (* im im)) (* re re)) |
| 0.0ms | im | @ | inf | ((- (* re re) (* im im)) (* re re)) |
| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 41 |
| 1 | 40 | 41 |
| 2 | 152 | 41 |
| 3 | 943 | 41 |
| 4 | 5676 | 41 |
| 0 | 8028 | 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)) |
| ✓ | 53.0% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| ✓ | 51.5% | #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:
| 2.0ms | im |
| 2.0ms | re |
| 2.0ms | (*.f64 re 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 | im |
| 1.0ms | re |
| 1.0ms | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 1.0ms | (*.f64 im im) |
| 1.0ms | (*.f64 re re) |
| Accuracy | Segments | Branch |
|---|---|---|
| 78.9% | 2 | (*.f64 im im) |
| 79.0% | 2 | (*.f64 re re) |
| 95.6% | 2 | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 79.0% | 2 | re |
| 78.9% | 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 (*.f64 re re) (*.f64 im im)) |
| 1.0ms | (*.f64 im im) |
| 1.0ms | (*.f64 re re) |
| Accuracy | Segments | Branch |
|---|---|---|
| 51.5% | 1 | (*.f64 im im) |
| 51.5% | 1 | im |
| 51.5% | 1 | (*.f64 re re) |
| 51.5% | 1 | re |
| 51.5% | 1 | (-.f64 (*.f64 re re) (*.f64 im im)) |
Compiled 15 to 15 computations (0% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -2.666750070464494e-248 | 0.0 |
Compiled 10 to 10 computations (0% saved)
| 1× | egg-herbie |
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 -5038209258419659/251910462920982955146951572855242064723418868082104455055218081010186148908960752236565235084370225856148908135059894885483907489539473312974233140212507046179002134322645704349866637075627537275802723363977045251916898867011814946574400376685636747593659677933568 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 -5038209258419659/251910462920982955146951572855242064723418868082104455055218081010186148908960752236565235084370225856148908135059894885483907489539473312974233140212507046179002134322645704349866637075627537275802723363977045251916898867011814946574400376685636747593659677933568 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)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 92 | 207 |
| 1 | 301 | 200 |
| 2 | 1134 | 200 |
| 0 | 8149 | 193 |
| 0 | 5 | 13 |
| 0 | 8 | 13 |
| 1 | 37 | 13 |
| 0 | 329 | 13 |
| 0 | 17 | 44 |
| 1 | 40 | 44 |
| 2 | 152 | 44 |
| 3 | 943 | 44 |
| 4 | 5676 | 44 |
| 0 | 8028 | 43 |
| 1× | done |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | iter limit |
| 1× | unsound |
| 1× | iter limit |
| 1× | iter limit |
| 1× | node limit |
Compiled 51 to 18 computations (64.7% saved)
(abs re)
(abs im)
Compiled 144 to 66 computations (54.2% saved)
Loading profile data...