
Time bar (total: 1.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)
| 356.0ms | 8 256× | 0 | valid |
ival-mult!: 110.0ms (85.9% of total)ival-sub!: 17.0ms (13.3% of total)adjust: 2.0ms (1.6% of total)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 14 | 42 |
| 1 | 62 | 42 |
| 2 | 273 | 42 |
| 3 | 477 | 42 |
| 4 | 1202 | 42 |
| 5 | 4632 | 42 |
| 1× | node-limit |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 94.9% | (-.f64 (*.f64 re re) (*.f64 im im)) |
(abs re)
(abs im)
Compiled 10 to 10 computations (0% saved)
| Inputs |
|---|
(-.f64 (*.f64 re re) (*.f64 im im)) |
(*.f64 re re) |
re |
(*.f64 im im) |
im |
| Outputs |
|---|
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* -1 (pow im 2)))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (- (pow re 2) (pow im 2)))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (+ (* -1 (pow im 2)) (pow re 2)))) |
#s(approx (* im im) #s(hole binary64 (pow im 2))) |
#s(approx im #s(hole binary64 im)) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* (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) re (* im im) im) |
| 1.0ms | re | @ | -inf | ((- (* re re) (* im im)) (* re re) re (* im im) im) |
| 1.0ms | re | @ | 0 | ((- (* re re) (* im im)) (* re re) re (* im im) im) |
| 1.0ms | im | @ | inf | ((- (* re re) (* im im)) (* re re) re (* im im) im) |
| 1.0ms | im | @ | -inf | ((- (* re re) (* im im)) (* re re) re (* im im) im) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 32 | 124 |
| 0 | 33 | 120 |
| 1 | 157 | 119 |
| 0 | 1645 | 118 |
| 1 | 5850 | 118 |
| 1× | saturated |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
(-.f64 (*.f64 re re) (*.f64 im im)) |
(*.f64 re re) |
re |
(*.f64 im im) |
im |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* -1 (pow im 2)))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (- (pow re 2) (pow im 2)))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (+ (* -1 (pow im 2)) (pow re 2)))) |
#s(approx (* im im) #s(hole binary64 (pow im 2))) |
#s(approx im #s(hole binary64 im)) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)))) |
| Outputs |
|---|
(*.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 (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 re (fabs.f64 im)) (-.f64 re (fabs.f64 im))) |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(*.f64 (+.f64 im re) (-.f64 re im)) |
(neg.f64 (-.f64 (*.f64 (neg.f64 re) re) (*.f64 (neg.f64 im) im))) |
(neg.f64 (*.f64 (+.f64 im re) (-.f64 im re))) |
(fma.f64 (*.f64 #s(literal -1 binary64) (fabs.f64 im)) (fabs.f64 im) (*.f64 re re)) |
(fma.f64 (*.f64 #s(literal -1 binary64) (neg.f64 im)) (neg.f64 im) (*.f64 re re)) |
(fma.f64 (*.f64 #s(literal -1 binary64) im) im (*.f64 re re)) |
(fma.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 re)) (*.f64 #s(literal 1 binary64) (fabs.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 re)) (fabs.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 #s(literal 1 binary64) (neg.f64 re)) (*.f64 #s(literal 1 binary64) (neg.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 #s(literal 1 binary64) (neg.f64 re)) (neg.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 #s(literal 1 binary64) re) (*.f64 #s(literal 1 binary64) re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 #s(literal 1 binary64) re) re (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 (fabs.f64 re) #s(literal 1 binary64)) (*.f64 (fabs.f64 re) #s(literal 1 binary64)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 (neg.f64 re) #s(literal 1 binary64)) (*.f64 (neg.f64 re) #s(literal 1 binary64)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 re #s(literal 1 binary64)) (*.f64 re #s(literal 1 binary64)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (fabs.f64 (fabs.f64 re)) (fabs.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 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (fabs.f64 im) (*.f64 (fabs.f64 im) #s(literal -1 binary64)) (*.f64 re re)) |
(fma.f64 (fabs.f64 im) (neg.f64 (fabs.f64 im)) (*.f64 re re)) |
(fma.f64 (fabs.f64 re) (*.f64 (fabs.f64 re) #s(literal 1 binary64)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (fabs.f64 re) (fabs.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 im) (*.f64 (neg.f64 im) #s(literal -1 binary64)) (*.f64 re re)) |
(fma.f64 (neg.f64 im) (neg.f64 (neg.f64 im)) (*.f64 re re)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(fma.f64 (neg.f64 re) (*.f64 (neg.f64 re) #s(literal 1 binary64)) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 re) (neg.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 #s(literal 1 binary64) (*.f64 re re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 re re) #s(literal 1 binary64) (*.f64 (neg.f64 im) im)) |
(fma.f64 (*.f64 im im) #s(literal -1 binary64) (*.f64 re re)) |
(fma.f64 #s(literal -1 binary64) (*.f64 im im) (*.f64 re re)) |
(fma.f64 im (*.f64 im #s(literal -1 binary64)) (*.f64 re re)) |
(fma.f64 im (neg.f64 im) (*.f64 re re)) |
(fma.f64 re (*.f64 re #s(literal 1 binary64)) (*.f64 (neg.f64 im) im)) |
(fma.f64 re re (*.f64 (neg.f64 im) im)) |
(-.f64 (*.f64 re re) (*.f64 (neg.f64 (neg.f64 im)) im)) |
(-.f64 (*.f64 re re) (*.f64 (*.f64 (neg.f64 im) im) #s(literal -1 binary64))) |
(-.f64 (*.f64 re re) (*.f64 #s(literal 1 binary64) (*.f64 im im))) |
(-.f64 (*.f64 re re) (*.f64 im im)) |
(-.f64 (*.f64 (neg.f64 im) im) (*.f64 (neg.f64 re) re)) |
(+.f64 (*.f64 re re) (*.f64 (neg.f64 im) im)) |
(+.f64 (*.f64 (neg.f64 im) im) (*.f64 re re)) |
(*.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 re)) (*.f64 #s(literal 1 binary64) (fabs.f64 re))) |
(*.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 re)) (fabs.f64 re)) |
(*.f64 (*.f64 #s(literal 1 binary64) (neg.f64 re)) (*.f64 #s(literal 1 binary64) (neg.f64 re))) |
(*.f64 (*.f64 #s(literal 1 binary64) (neg.f64 re)) (neg.f64 re)) |
(*.f64 (*.f64 #s(literal 1 binary64) re) (*.f64 #s(literal 1 binary64) re)) |
(*.f64 (*.f64 #s(literal 1 binary64) re) re) |
(*.f64 (*.f64 (fabs.f64 re) #s(literal 1 binary64)) (*.f64 (fabs.f64 re) #s(literal 1 binary64))) |
(*.f64 (*.f64 (neg.f64 re) #s(literal 1 binary64)) (*.f64 (neg.f64 re) #s(literal 1 binary64))) |
(*.f64 (*.f64 re #s(literal 1 binary64)) (*.f64 re #s(literal 1 binary64))) |
(*.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re))) |
(*.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re))) |
(*.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re))) |
(*.f64 (fabs.f64 re) (*.f64 (fabs.f64 re) #s(literal 1 binary64))) |
(*.f64 (fabs.f64 re) (fabs.f64 re)) |
(*.f64 (neg.f64 re) (*.f64 (neg.f64 re) #s(literal 1 binary64))) |
(*.f64 (neg.f64 re) (neg.f64 re)) |
(*.f64 #s(literal 1 binary64) (*.f64 re re)) |
(*.f64 (*.f64 re re) #s(literal 1 binary64)) |
(*.f64 re (*.f64 re #s(literal 1 binary64))) |
(*.f64 re re) |
(pow.f64 (fabs.f64 (fabs.f64 re)) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 (fabs.f64 re)) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 (neg.f64 re)) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 re) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 re) #s(literal 2 binary64)) |
(pow.f64 re #s(literal 2 binary64)) |
(/.f64 (*.f64 #s(literal 2 binary64) (*.f64 re re)) #s(literal 2 binary64)) |
(/.f64 (*.f64 (*.f64 re re) #s(literal 2 binary64)) #s(literal 2 binary64)) |
(neg.f64 (*.f64 #s(literal -1 binary64) (*.f64 re re))) |
(neg.f64 (*.f64 (*.f64 re re) #s(literal -1 binary64))) |
(neg.f64 (*.f64 (neg.f64 re) re)) |
(sqrt.f64 (*.f64 (*.f64 (*.f64 re re) re) re)) |
(fabs.f64 (*.f64 (neg.f64 re) re)) |
(fabs.f64 (*.f64 re re)) |
re |
(*.f64 (fabs.f64 (fabs.f64 im)) (fabs.f64 (fabs.f64 im))) |
(*.f64 (neg.f64 (fabs.f64 im)) (neg.f64 (fabs.f64 im))) |
(*.f64 (neg.f64 (neg.f64 im)) (neg.f64 (neg.f64 im))) |
(*.f64 (fabs.f64 im) (fabs.f64 im)) |
(*.f64 (neg.f64 im) (neg.f64 im)) |
(*.f64 im im) |
(pow.f64 (fabs.f64 (fabs.f64 im)) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 (fabs.f64 im)) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 (neg.f64 im)) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 im) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 im) #s(literal 2 binary64)) |
(pow.f64 im #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 im) im)) |
(sqrt.f64 (*.f64 (*.f64 (*.f64 im im) im) im)) |
(fabs.f64 (*.f64 (neg.f64 im) im)) |
(fabs.f64 (*.f64 im im)) |
im |
#s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
#s(approx (- (* re re) (* im im)) (*.f64 (-.f64 re im) (+.f64 im re))) |
#s(approx (* re re) (*.f64 re re)) |
#s(approx re re) |
#s(approx (- (* re re) (* im im)) (*.f64 (-.f64 #s(literal 1 binary64) (*.f64 im (/.f64 im (*.f64 re re)))) (*.f64 re re))) |
#s(approx (- (* re re) (* im im)) (*.f64 (-.f64 re im) (+.f64 im re))) |
#s(approx (* im im) (*.f64 im im)) |
#s(approx im im) |
#s(approx (- (* re re) (* im im)) (*.f64 (*.f64 (fma.f64 re (/.f64 re (*.f64 im im)) #s(literal -1 binary64)) im) im)) |
Compiled 515 to 233 computations (54.8% saved)
2 alts after pruning (2 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 105 | 2 | 107 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 106 | 2 | 108 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 (-.f64 re im) (+.f64 im re)) |
| ▶ | 57.8% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
Compiled 13 to 13 computations (0% saved)
| 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 |
(+.f64 im re) |
| Outputs |
|---|
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* -1 (pow im 2)))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (- (pow re 2) (pow im 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* -1 (pow im 2)) (* re (+ im (* -1 im)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* -1 (pow im 2)) (* re (+ im (+ re (* -1 im))))))) |
#s(approx (- re im) #s(hole binary64 (* -1 im))) |
#s(approx (- re im) #s(hole binary64 (- re im))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (+ im re) #s(hole binary64 im)) |
#s(approx (+ im re) #s(hole binary64 (+ im re))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (pow re 2))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (/ im re)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (+ (* -1 (/ (pow im 2) (pow re 2))) (/ im re))))))) |
#s(approx (- re im) #s(hole binary64 (* re (+ 1 (* -1 (/ im re)))))) |
#s(approx (+ im re) #s(hole binary64 (* re (+ 1 (/ im re))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (* -1 (/ (+ (* -1 (+ im (* -1 im))) (/ (pow im 2) re)) re)))))) |
#s(approx (- re im) #s(hole binary64 (* -1 (* re (- (/ im re) 1))))) |
#s(approx (+ im re) #s(hole binary64 (* -1 (* re (- (* -1 (/ im re)) 1))))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (+ (* -1 (pow im 2)) (pow re 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* im (+ re (* -1 re))) (pow re 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* im (+ re (+ (* -1 im) (* -1 re)))) (pow re 2)))) |
#s(approx (- re im) #s(hole binary64 (+ re (* -1 im)))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (+ (* -1 (/ re im)) (/ re im)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (+ (* -1 (/ re im)) (+ (/ re im) (/ (pow re 2) (pow im 2)))) 1)))) |
#s(approx (- re im) #s(hole binary64 (* im (- (/ re im) 1)))) |
#s(approx (+ im re) #s(hole binary64 (* im (+ 1 (/ re im))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (* -1 (/ (+ re (* -1 re)) im)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (* -1 (/ (+ re (+ (* -1 re) (* -1 (/ (pow re 2) im)))) im)) 1)))) |
#s(approx (- re im) #s(hole binary64 (* -1 (* im (+ 1 (* -1 (/ re im))))))) |
#s(approx (+ im re) #s(hole binary64 (* -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) im (* (- re im) (+ im re)) (- re im) re (+ im re)) |
| 1.0ms | im | @ | inf | ((- (* re re) (* im im)) (* (neg im) im) (neg im) im (* (- re im) (+ im re)) (- re im) re (+ im re)) |
| 1.0ms | re | @ | -inf | ((- (* re re) (* im im)) (* (neg im) im) (neg im) im (* (- re im) (+ im re)) (- re im) re (+ im re)) |
| 1.0ms | re | @ | 0 | ((- (* re re) (* im im)) (* (neg im) im) (neg im) im (* (- re im) (+ im re)) (- re im) re (+ im re)) |
| 1.0ms | re | @ | inf | ((- (* re re) (* im im)) (* (neg im) im) (neg im) im (* (- re im) (+ im re)) (- re im) re (+ im re)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 133 | 556 |
| 0 | 137 | 505 |
| 0 | 932 | 497 |
| 1 | 2753 | 497 |
| 1× | saturated |
| 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) |
im |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(-.f64 re im) |
re |
(+.f64 im re) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* -1 (pow im 2)))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (- (pow re 2) (pow im 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* -1 (pow im 2)) (* re (+ im (* -1 im)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* -1 (pow im 2)) (* re (+ im (+ re (* -1 im))))))) |
#s(approx (- re im) #s(hole binary64 (* -1 im))) |
#s(approx (- re im) #s(hole binary64 (- re im))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (+ im re) #s(hole binary64 im)) |
#s(approx (+ im re) #s(hole binary64 (+ im re))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (pow re 2))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (/ im re)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (+ (* -1 (/ (pow im 2) (pow re 2))) (/ im re))))))) |
#s(approx (- re im) #s(hole binary64 (* re (+ 1 (* -1 (/ im re)))))) |
#s(approx (+ im re) #s(hole binary64 (* re (+ 1 (/ im re))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (* -1 (/ (+ (* -1 (+ im (* -1 im))) (/ (pow im 2) re)) re)))))) |
#s(approx (- re im) #s(hole binary64 (* -1 (* re (- (/ im re) 1))))) |
#s(approx (+ im re) #s(hole binary64 (* -1 (* re (- (* -1 (/ im re)) 1))))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (+ (* -1 (pow im 2)) (pow re 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* im (+ re (* -1 re))) (pow re 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* im (+ re (+ (* -1 im) (* -1 re)))) (pow re 2)))) |
#s(approx (- re im) #s(hole binary64 (+ re (* -1 im)))) |
#s(approx (- (* re re) (* im im)) #s(hole binary64 (* (pow im 2) (- (/ (pow re 2) (pow im 2)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (+ (* -1 (/ re im)) (/ re im)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (+ (* -1 (/ re im)) (+ (/ re im) (/ (pow re 2) (pow im 2)))) 1)))) |
#s(approx (- re im) #s(hole binary64 (* im (- (/ re im) 1)))) |
#s(approx (+ im re) #s(hole binary64 (* im (+ 1 (/ re im))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (* -1 (/ (+ re (* -1 re)) im)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (* -1 (/ (+ re (+ (* -1 re) (* -1 (/ (pow re 2) im)))) im)) 1)))) |
#s(approx (- re im) #s(hole binary64 (* -1 (* im (+ 1 (* -1 (/ re im))))))) |
#s(approx (+ im re) #s(hole binary64 (* -1 (* im (- (* -1 (/ re im)) 1))))) |
| Outputs |
|---|
#s(approx (* (- re im) (+ im re)) (*.f64 (neg.f64 im) im)) |
(*.f64 (neg.f64 im) im) |
(*.f64 (*.f64 im im) #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) (*.f64 im im)) |
(*.f64 im (neg.f64 im)) |
(neg.f64 (*.f64 im im)) |
(*.f64 #s(literal -1 binary64) im) |
(*.f64 im #s(literal -1 binary64)) |
(neg.f64 im) |
im |
(*.f64 (+.f64 im re) (-.f64 re im)) |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(neg.f64 (-.f64 (*.f64 im im) (*.f64 re re))) |
(fma.f64 (fabs.f64 re) (fabs.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 re) (neg.f64 re) (*.f64 (neg.f64 im) im)) |
(fma.f64 (neg.f64 im) im (*.f64 re re)) |
(fma.f64 (-.f64 re im) im (*.f64 (-.f64 re im) re)) |
(fma.f64 (*.f64 im im) #s(literal -1 binary64) (*.f64 re re)) |
(fma.f64 #s(literal -1 binary64) (*.f64 im im) (*.f64 re re)) |
(fma.f64 im (neg.f64 im) (*.f64 re re)) |
(fma.f64 im (-.f64 re im) (*.f64 re (-.f64 re im))) |
(fma.f64 re re (*.f64 (neg.f64 im) im)) |
(-.f64 (*.f64 re re) (*.f64 im im)) |
(-.f64 (*.f64 (neg.f64 im) im) (neg.f64 (*.f64 re re))) |
(+.f64 (*.f64 (-.f64 re im) im) (*.f64 (-.f64 re im) re)) |
(+.f64 (*.f64 im (-.f64 re im)) (*.f64 re (-.f64 re im))) |
(+.f64 (*.f64 re re) (*.f64 (neg.f64 im) im)) |
(+.f64 (*.f64 (neg.f64 im) im) (*.f64 re re)) |
(neg.f64 (-.f64 im re)) |
(fma.f64 #s(literal -1 binary64) im re) |
(fma.f64 im #s(literal -1 binary64) re) |
(-.f64 re (*.f64 #s(literal 1 binary64) im)) |
(-.f64 re (neg.f64 (neg.f64 im))) |
(-.f64 re im) |
(+.f64 (neg.f64 im) re) |
(+.f64 re (neg.f64 im)) |
re |
(-.f64 im (neg.f64 re)) |
(+.f64 im re) |
(+.f64 re im) |
#s(approx (* (- re im) (+ im re)) (*.f64 (neg.f64 im) im)) |
#s(approx (* (- re im) (+ im re)) (*.f64 (+.f64 im re) (-.f64 re im))) |
#s(approx (* (- re im) (+ im re)) (fma.f64 (neg.f64 im) im (*.f64 (*.f64 #s(literal 0 binary64) im) re))) |
#s(approx (* (- re im) (+ im re)) (fma.f64 (neg.f64 im) im (*.f64 (+.f64 (-.f64 re im) im) re))) |
#s(approx (- re im) (neg.f64 im)) |
#s(approx (- re im) (-.f64 re im)) |
#s(approx re re) |
#s(approx (+ im re) im) |
#s(approx (+ im re) (+.f64 im re)) |
#s(approx (* (- re im) (+ im re)) (*.f64 re re)) |
#s(approx (* (- re im) (+ im re)) (*.f64 (+.f64 (/.f64 (*.f64 (neg.f64 im) im) (*.f64 re re)) #s(literal 1 binary64)) (*.f64 re re))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (fma.f64 #s(literal 0 binary64) (/.f64 im re) #s(literal 1 binary64)) (*.f64 re re))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (+.f64 (+.f64 (+.f64 (/.f64 (neg.f64 im) re) (/.f64 (*.f64 (neg.f64 im) im) (*.f64 re re))) (/.f64 im re)) #s(literal 1 binary64)) (*.f64 re re))) |
#s(approx (- re im) (*.f64 (+.f64 (/.f64 (neg.f64 im) re) #s(literal 1 binary64)) re)) |
#s(approx (+ im re) (*.f64 (+.f64 (/.f64 im re) #s(literal 1 binary64)) re)) |
#s(approx (* (- re im) (+ im re)) (*.f64 (+.f64 (neg.f64 (/.f64 (+.f64 (/.f64 (*.f64 im im) re) (neg.f64 (*.f64 #s(literal 0 binary64) im))) re)) #s(literal 1 binary64)) (*.f64 re re))) |
#s(approx (- re im) (*.f64 (neg.f64 re) (-.f64 (/.f64 im re) #s(literal 1 binary64)))) |
#s(approx (+ im re) (*.f64 (neg.f64 re) (-.f64 (/.f64 (neg.f64 im) re) #s(literal 1 binary64)))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (+.f64 im re) (-.f64 re im))) |
#s(approx (* (- re im) (+ im re)) (fma.f64 (*.f64 #s(literal 0 binary64) re) im (*.f64 re re))) |
#s(approx (* (- re im) (+ im re)) (fma.f64 (+.f64 (-.f64 re im) (neg.f64 re)) im (*.f64 re re))) |
#s(approx (- re im) (-.f64 re im)) |
#s(approx (* (- re im) (+ im re)) (*.f64 (-.f64 (/.f64 (*.f64 re re) (*.f64 im im)) #s(literal 1 binary64)) (*.f64 im im))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (fma.f64 #s(literal 0 binary64) (/.f64 re im) #s(literal -1 binary64)) (*.f64 im im))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (-.f64 (fma.f64 #s(literal 0 binary64) (/.f64 re im) (/.f64 (*.f64 re re) (*.f64 im im))) #s(literal 1 binary64)) (*.f64 im im))) |
#s(approx (- re im) (*.f64 (-.f64 (/.f64 re im) #s(literal 1 binary64)) im)) |
#s(approx (+ im re) (*.f64 (+.f64 (/.f64 re im) #s(literal 1 binary64)) im)) |
#s(approx (* (- re im) (+ im re)) (*.f64 (-.f64 (neg.f64 (*.f64 #s(literal 0 binary64) (/.f64 re im))) #s(literal 1 binary64)) (*.f64 im im))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (-.f64 (neg.f64 (/.f64 (fma.f64 #s(literal 0 binary64) re (neg.f64 (/.f64 (*.f64 re re) im))) im)) #s(literal 1 binary64)) (*.f64 im im))) |
#s(approx (- re im) (*.f64 (neg.f64 im) (+.f64 (/.f64 (neg.f64 re) im) #s(literal 1 binary64)))) |
#s(approx (+ im re) (*.f64 (neg.f64 im) (-.f64 (/.f64 (neg.f64 re) im) #s(literal 1 binary64)))) |
Compiled 348 to 186 computations (46.6% saved)
3 alts after pruning (1 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 60 | 1 | 61 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 0 | 0 |
| Total | 60 | 3 | 63 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (-.f64 re im) (+.f64 im re)) |
| ✓ | 57.8% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| ▶ | 50.3% | #s(approx (* (- re im) (+ im re)) (*.f64 re re)) |
Compiled 20 to 20 computations (0% saved)
| Inputs |
|---|
#s(approx (* (- re im) (+ im re)) (*.f64 re re)) |
(*.f64 re re) |
re |
| Outputs |
|---|
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* -1 (pow im 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* -1 (pow im 2)) (* re (+ im (* -1 im)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* -1 (pow im 2)) (* re (+ im (+ re (* -1 im))))))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (/ im re)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (+ (* -1 (/ (pow im 2) (pow re 2))) (/ im re))))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (* -1 (/ (+ (* -1 (+ im (* -1 im))) (/ (pow im 2) re)) re)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* im (+ re (* -1 re))) (pow re 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* im (+ re (+ (* -1 im) (* -1 re)))) (pow re 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (+ (* -1 (/ re im)) (/ re im)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (+ (* -1 (/ re im)) (+ (/ re im) (/ (pow re 2) (pow im 2)))) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (* -1 (/ (+ re (* -1 re)) im)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (* -1 (/ (+ re (+ (* -1 re) (* -1 (/ (pow re 2) im)))) im)) 1)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | re | @ | -inf | ((* (- re im) (+ im re)) (* re re) re) |
| 1.0ms | re | @ | inf | ((* (- re im) (+ im re)) (* re re) re) |
| 0.0ms | re | @ | 0 | ((* (- re im) (+ im re)) (* re re) re) |
| 0.0ms | im | @ | inf | ((* (- re im) (+ im re)) (* re re) re) |
| 0.0ms | im | @ | -inf | ((* (- re im) (+ im re)) (* re re) re) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 84 | 319 |
| 0 | 85 | 282 |
| 0 | 684 | 274 |
| 1 | 2055 | 274 |
| 1× | saturated |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (* (- re im) (+ im re)) (*.f64 re re)) |
(*.f64 re re) |
re |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* -1 (pow im 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* -1 (pow im 2)) (* re (+ im (* -1 im)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* -1 (pow im 2)) (* re (+ im (+ re (* -1 im))))))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (/ im re)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (+ (* -1 (/ im re)) (+ (* -1 (/ (pow im 2) (pow re 2))) (/ im re))))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow re 2) (+ 1 (* -1 (/ (+ (* -1 (+ im (* -1 im))) (/ (pow im 2) re)) re)))))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* im (+ re (* -1 re))) (pow re 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (+ (* im (+ re (+ (* -1 im) (* -1 re)))) (pow re 2)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (+ (* -1 (/ re im)) (/ re im)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (+ (* -1 (/ re im)) (+ (/ re im) (/ (pow re 2) (pow im 2)))) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (* -1 (/ (+ re (* -1 re)) im)) 1)))) |
#s(approx (* (- re im) (+ im re)) #s(hole binary64 (* (pow im 2) (- (* -1 (/ (+ re (+ (* -1 re) (* -1 (/ (pow re 2) im)))) im)) 1)))) |
| Outputs |
|---|
#s(approx (* (- re im) (+ im re)) (*.f64 re re)) |
(*.f64 (fabs.f64 re) (fabs.f64 re)) |
(*.f64 (neg.f64 re) (neg.f64 re)) |
(*.f64 re re) |
(pow.f64 (fabs.f64 re) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 re) #s(literal 2 binary64)) |
(pow.f64 re #s(literal 2 binary64)) |
(fabs.f64 (*.f64 re re)) |
re |
#s(approx (* (- re im) (+ im re)) (neg.f64 (*.f64 im im))) |
#s(approx (* (- re im) (+ im re)) (fma.f64 (*.f64 #s(literal 0 binary64) im) re (neg.f64 (*.f64 im im)))) |
#s(approx (* (- re im) (+ im re)) (fma.f64 (+.f64 (-.f64 re im) im) re (neg.f64 (*.f64 im im)))) |
#s(approx (* re re) (*.f64 re re)) |
#s(approx re re) |
#s(approx (* (- re im) (+ im re)) (*.f64 (fma.f64 #s(literal 0 binary64) (/.f64 im re) #s(literal 1 binary64)) (*.f64 re re))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (+.f64 (+.f64 (+.f64 (/.f64 (neg.f64 im) re) (/.f64 (neg.f64 (*.f64 im im)) (*.f64 re re))) (/.f64 im re)) #s(literal 1 binary64)) (*.f64 re re))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (+.f64 (neg.f64 (/.f64 (+.f64 (/.f64 (*.f64 im im) re) (neg.f64 (*.f64 #s(literal 0 binary64) im))) re)) #s(literal 1 binary64)) (*.f64 re re))) |
#s(approx (* (- re im) (+ im re)) (fma.f64 (*.f64 #s(literal 0 binary64) re) im (*.f64 re re))) |
#s(approx (* (- re im) (+ im re)) (fma.f64 (+.f64 (-.f64 re im) (neg.f64 re)) im (*.f64 re re))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (fma.f64 #s(literal 0 binary64) (/.f64 re im) #s(literal -1 binary64)) (*.f64 im im))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (-.f64 (fma.f64 #s(literal 0 binary64) (/.f64 re im) (/.f64 (*.f64 re re) (*.f64 im im))) #s(literal 1 binary64)) (*.f64 im im))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (-.f64 (neg.f64 (*.f64 #s(literal 0 binary64) (/.f64 re im))) #s(literal 1 binary64)) (*.f64 im im))) |
#s(approx (* (- re im) (+ im re)) (*.f64 (-.f64 (neg.f64 (/.f64 (fma.f64 #s(literal 0 binary64) re (neg.f64 (/.f64 (*.f64 re re) im))) im)) #s(literal 1 binary64)) (*.f64 im im))) |
Compiled 156 to 88 computations (43.6% saved)
3 alts after pruning (0 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 20 | 0 | 20 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 2 | 2 |
| Total | 20 | 3 | 23 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (-.f64 re im) (+.f64 im re)) |
| ✓ | 57.8% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| ✓ | 50.3% | #s(approx (* (- re im) (+ im re)) (*.f64 re re)) |
Compiled 39 to 38 computations (2.6% saved)
| Inputs |
|---|
#s(approx (* (- re im) (+ im re)) (*.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:
| 4.0ms | (*.f64 re re) |
| 2.0ms | re |
| 2.0ms | im |
| 2.0ms | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 1.0ms | (*.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 11 to 15 computations (-36.4% saved)
| Inputs |
|---|
#s(approx (* (- re im) (+ im re)) (*.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 im) (+ im re)) (*.f64 re re)) |
5 calls:
| 1.0ms | (*.f64 im im) |
| 1.0ms | im |
| 1.0ms | (*.f64 re re) |
| 1.0ms | re |
| 1.0ms | (-.f64 (*.f64 re re) (*.f64 im im)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 81.3% | 2 | (*.f64 im im) |
| 78.0% | 2 | (*.f64 re re) |
| 96.7% | 2 | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 78.0% | 2 | re |
| 81.3% | 2 | im |
Compiled 11 to 15 computations (-36.4% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
#s(approx (* (- re im) (+ im re)) (*.f64 re re)) |
| Outputs |
|---|
#s(approx (* (- re im) (+ im re)) (*.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 |
|---|---|---|
| 50.3% | 1 | (*.f64 re re) |
| 50.3% | 1 | re |
| 50.3% | 1 | (*.f64 im im) |
| 50.3% | 1 | im |
| 50.3% | 1 | (-.f64 (*.f64 re re) (*.f64 im im)) |
Compiled 11 to 15 computations (-36.4% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -1.5240841687700152e-289 | 0.0 |
Compiled 8 to 10 computations (-25% saved)
| 1× | done |
Compiled 22 to 21 computations (4.5% saved)
(abs im)
(abs re)
Compiled 151 to 146 computations (3.3% saved)
Loading profile data...