
Time bar (total: 1.8s)
| 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)
| 607.0ms | 8 256× | 0 | valid |
ival-mult: 401.0ms (89.7% of total)ival-sub: 36.0ms (8.1% of total)ival-true: 5.0ms (1.1% of total)ival-assert: 3.0ms (0.7% of total)adjust: 2.0ms (0.4% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 8 | 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 | 8 | 0 |
| ↳ | (*.f64 re re) | overflow | 63 | |
| ↳ | (*.f64 im im) | overflow | 60 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 8 | 0 |
| - | 0 | 248 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 8 | 0 | 0 |
| - | 0 | 0 | 248 |
| number | freq |
|---|---|
| 0 | 248 |
| 1 | 8 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 23.0ms | 512× | 0 | valid |
Compiled 41 to 19 computations (53.7% saved)
ival-mult: 7.0ms (63.6% of total)ival-sub: 3.0ms (27.2% 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 |
|---|---|---|
| ▶ | 96.9% | (-.f64 (*.f64 re re) (*.f64 im im)) |
Compiled 7 to 5 computations (28.6% saved)
| Inputs |
|---|
(-.f64 (*.f64 re re) (*.f64 im im)) |
(*.f64 re re) |
re |
(*.f64 im im) |
im |
| Outputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(pow re 2) |
re |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(pow im 2) |
im |
(* (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 | 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) |
| 1.0ms | re | @ | 0 | ((- (* re re) (* im im)) (* re re) re (* im im) im) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 46 |
| 1 | 40 | 46 |
| 2 | 152 | 46 |
| 3 | 943 | 46 |
| 4 | 5541 | 46 |
| 0 | 8458 | 45 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(pow re 2) |
re |
(* (pow re 2) (+ 1 (* -1 (/ (pow im 2) (pow re 2))))) |
(+ (* -1 (pow im 2)) (pow re 2)) |
(pow im 2) |
im |
(* (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) |
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) |
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 | 15 |
| 0 | 8 | 15 |
| 1 | 37 | 15 |
| 0 | 329 | 15 |
| 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) |
re |
(*.f64 im 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))) |
re |
(*.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))) |
im |
Compiled 894 to 181 computations (79.8% saved)
2 alts after pruning (2 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 80 | 2 | 82 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 81 | 2 | 83 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 (-.f64 re im) (+.f64 im re)) |
| ▶ | 51.9% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
Compiled 19 to 13 computations (31.6% 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 |
|---|
(* -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) |
re |
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 (+ 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) 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 | 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) |
re |
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 (+ 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) |
re |
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 (+ 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 | 33 |
| 0 | 16 | 33 |
| 1 | 68 | 33 |
| 0 | 610 | 33 |
| 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) |
im |
(*.f64 (-.f64 re im) (+.f64 im re)) |
(-.f64 re im) |
re |
(+.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) |
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))) |
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 813 to 296 computations (83.7% saved)
3 alts after pruning (1 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 115 | 1 | 116 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 0 | 0 |
| Total | 115 | 3 | 118 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (-.f64 re im) (+.f64 im re)) |
| ✓ | 51.9% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| ▶ | 54.8% | #s(approx (- (* re re) (* im im)) (*.f64 re re)) |
Compiled 30 to 20 computations (33.3% saved)
| Inputs |
|---|
#s(approx (- (* re re) (* im im)) (*.f64 re re)) |
(*.f64 re re) |
re |
| Outputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(pow re 2) |
re |
(* (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 | |
|---|---|---|---|---|
| 1.0ms | re | @ | -inf | ((- (* re re) (* im im)) (* re re) re) |
| 1.0ms | re | @ | inf | ((- (* re re) (* im im)) (* re re) re) |
| 0.0ms | re | @ | 0 | ((- (* re re) (* im im)) (* re re) re) |
| 0.0ms | im | @ | -inf | ((- (* re re) (* im im)) (* re re) re) |
| 0.0ms | im | @ | inf | ((- (* re re) (* im im)) (* re re) re) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 17 | 42 |
| 1 | 40 | 42 |
| 2 | 152 | 42 |
| 3 | 943 | 42 |
| 4 | 5541 | 42 |
| 0 | 8458 | 41 |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(* -1 (pow im 2)) |
(- (pow re 2) (pow im 2)) |
(pow re 2) |
re |
(* (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) |
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 | 15 |
| 0 | 8 | 15 |
| 1 | 37 | 15 |
| 0 | 329 | 15 |
| 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) |
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))) |
re |
Compiled 278 to 59 computations (78.8% saved)
3 alts after pruning (0 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 21 | 0 | 21 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 2 | 2 |
| Total | 21 | 3 | 24 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (-.f64 re im) (+.f64 im re)) |
| ✓ | 51.9% | #s(approx (- (* re re) (* im im)) (*.f64 (neg.f64 im) im)) |
| ✓ | 54.8% | #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 (*.f64 re re) (*.f64 im im)) |
| 2.0ms | (*.f64 re re) |
| 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 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:
| 4.0ms | re |
| 2.0ms | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 1.0ms | im |
| 1.0ms | (*.f64 im im) |
| 1.0ms | (*.f64 re re) |
| Accuracy | Segments | Branch |
|---|---|---|
| 83.4% | 2 | (*.f64 im im) |
| 81.2% | 2 | (*.f64 re re) |
| 97.1% | 2 | (-.f64 (*.f64 re re) (*.f64 im im)) |
| 81.2% | 2 | re |
| 83.4% | 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 re re) |
| 1.0ms | (*.f64 im im) |
| Accuracy | Segments | Branch |
|---|---|---|
| 54.8% | 1 | (*.f64 re re) |
| 54.8% | 1 | re |
| 54.8% | 1 | (*.f64 im im) |
| 54.8% | 1 | im |
| 54.8% | 1 | (-.f64 (*.f64 re re) (*.f64 im im)) |
Compiled 15 to 15 computations (0% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -3.681872723753311e-303 | 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 -6176826577981891/3088413288990945714607167766096760666649729152895234960279866913260350640380788374205938472006792060778611417607373228628384532735989280347702230834056678923362997806954442769843550227998248540363155634742320939156524772391123850992097524347673943425610505012700786888921103128284156837954503288400970554554866145951744 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 -6176826577981891/3088413288990945714607167766096760666649729152895234960279866913260350640380788374205938472006792060778611417607373228628384532735989280347702230834056678923362997806954442769843550227998248540363155634742320939156524772391123850992097524347673943425610505012700786888921103128284156837954503288400970554554866145951744 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...