
Time bar (total: 13.4s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.8% | 0.2% | 0% | 0% | 0% | 0 |
| 100% | 99.8% | 0% | 0.2% | 0% | 0% | 0% | 1 |
Compiled 9 to 9 computations (0% saved)
| 356.0ms | 8 255× | 0 | valid |
| 0.0ms | 1× | 1 | valid |
ival-mult!: 134.0ms (87.9% of total)ival-sub!: 17.0ms (11.2% of total)adjust: 1.0ms (0.7% of total)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 37 | 109 |
| 1 | 106 | 109 |
| 2 | 216 | 109 |
| 3 | 355 | 109 |
| 4 | 356 | 109 |
| 1× | saturated |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 98.8% | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
(sort x.re y.re)
(sort x.im y.im)
Compiled 14 to 14 computations (0% saved)
| Inputs |
|---|
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
(*.f64 x.re y.re) |
x.re |
y.re |
(*.f64 x.im y.im) |
x.im |
y.im |
| Outputs |
|---|
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))) |
#s(approx (* x.re y.re) (*.f64 x.re y.re)) |
#s(approx x.re x.re) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 x.re (+.f64 y.re (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.im y.im) x.re))))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.re (fma.f64 #s(literal -1 binary64) y.re (/.f64 (*.f64 x.im y.im) x.re))))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (fma.f64 #s(literal -1 binary64) (*.f64 x.im y.im) (*.f64 x.re y.re))) |
#s(approx (* x.im y.im) (*.f64 x.im y.im)) |
#s(approx x.im x.im) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 x.im (-.f64 (/.f64 (*.f64 x.re y.re) x.im) y.im))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) x.im)) (*.f64 #s(literal -1 binary64) y.im))))) |
#s(approx y.re y.re) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re (+.f64 x.re (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.im y.im) y.re))))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 y.re (fma.f64 #s(literal -1 binary64) x.re (/.f64 (*.f64 x.im y.im) y.re))))) |
#s(approx y.im y.im) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.im (-.f64 (/.f64 (*.f64 x.re y.re) y.im) x.im))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 y.im (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) y.im)) (*.f64 #s(literal -1 binary64) x.im))))) |
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y.re | @ | -inf | ((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im) |
| 1.0ms | x.re | @ | -inf | ((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im) |
| 1.0ms | x.re | @ | inf | ((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im) |
| 1.0ms | y.im | @ | -inf | ((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im) |
| 1.0ms | x.im | @ | -inf | ((- (* x.re y.re) (* x.im y.im)) (* x.re y.re) x.re y.re (* x.im y.im) x.im y.im) |
| Inputs |
|---|
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
(*.f64 x.re y.re) |
x.re |
y.re |
(*.f64 x.im y.im) |
x.im |
y.im |
| Outputs |
|---|
(+.f64 (neg.f64 (*.f64 x.im y.im)) (*.f64 x.re y.re)) |
(+.f64 (*.f64 x.re y.re) (neg.f64 (*.f64 x.im y.im))) |
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
(-.f64 (neg.f64 (*.f64 x.im y.im)) (neg.f64 (*.f64 x.re y.re))) |
(fma.f64 (neg.f64 x.im) y.im (*.f64 x.re y.re)) |
(fma.f64 (neg.f64 y.im) x.im (*.f64 x.re y.re)) |
(fma.f64 x.im (neg.f64 y.im) (*.f64 x.re y.re)) |
(fma.f64 y.im (neg.f64 x.im) (*.f64 x.re y.re)) |
(fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 x.re y.re (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 (neg.f64 y.re) (neg.f64 x.re) (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 (neg.f64 x.re) (neg.f64 y.re) (neg.f64 (*.f64 x.im y.im))) |
(neg.f64 (-.f64 (*.f64 x.im y.im) (*.f64 x.re y.re))) |
(*.f64 x.re y.re) |
(*.f64 y.re x.re) |
(*.f64 (neg.f64 x.re) (neg.f64 y.re)) |
(*.f64 (neg.f64 y.re) (neg.f64 x.re)) |
(neg.f64 (neg.f64 (*.f64 x.re y.re))) |
x.re |
(neg.f64 (neg.f64 x.re)) |
y.re |
(neg.f64 (neg.f64 y.re)) |
(*.f64 x.im y.im) |
(*.f64 y.im x.im) |
(*.f64 (neg.f64 x.im) (neg.f64 y.im)) |
(*.f64 (neg.f64 y.im) (neg.f64 x.im)) |
(neg.f64 (neg.f64 (*.f64 x.im y.im))) |
x.im |
(neg.f64 (neg.f64 x.im)) |
y.im |
(neg.f64 (neg.f64 y.im)) |
Compiled 210 to 117 computations (44.3% saved)
4 alts after pruning (3 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 38 | 3 | 41 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 38 | 4 | 42 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 99.2% | (fma.f64 (neg.f64 y.im) x.im (*.f64 x.re y.re)) |
| ▶ | 99.6% | (fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
| ✓ | 98.8% | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| ▶ | 50.3% | #s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
Compiled 32 to 32 computations (0% saved)
| Inputs |
|---|
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
(*.f64 #s(literal -1 binary64) (*.f64 x.im y.im)) |
#s(literal -1 binary64) |
(*.f64 x.im y.im) |
x.im |
y.im |
(fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
y.re |
x.re |
(neg.f64 (*.f64 x.im y.im)) |
(fma.f64 (neg.f64 y.im) x.im (*.f64 x.re y.re)) |
(neg.f64 y.im) |
(*.f64 x.re y.re) |
| Outputs |
|---|
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))) |
#s(approx x.re x.re) |
#s(approx (+ (* (neg y.im) x.im) (* x.re y.re)) (fma.f64 #s(literal -1 binary64) (*.f64 x.im y.im) (*.f64 x.re y.re))) |
#s(approx (* x.re y.re) (*.f64 x.re y.re)) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 x.re (+.f64 y.re (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.im y.im) x.re))))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.re (fma.f64 #s(literal -1 binary64) y.re (/.f64 (*.f64 x.im y.im) x.re))))) |
#s(approx (* x.im y.im) (*.f64 x.im y.im)) |
#s(approx x.im x.im) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 x.im (-.f64 (/.f64 (*.f64 x.re y.re) x.im) y.im))) |
#s(approx (+ (* (neg y.im) x.im) (* x.re y.re)) (*.f64 x.im (fma.f64 #s(literal -1 binary64) y.im (/.f64 (*.f64 x.re y.re) x.im)))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) x.im)) (*.f64 #s(literal -1 binary64) y.im))))) |
#s(approx (+ (* (neg y.im) x.im) (* x.re y.re)) (*.f64 #s(literal -1 binary64) (*.f64 x.im (+.f64 y.im (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) x.im)))))) |
#s(approx y.re y.re) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.re (+.f64 x.re (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.im y.im) y.re))))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 y.re (fma.f64 #s(literal -1 binary64) x.re (/.f64 (*.f64 x.im y.im) y.re))))) |
#s(approx y.im y.im) |
#s(approx (neg y.im) (*.f64 #s(literal -1 binary64) y.im)) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 y.im (-.f64 (/.f64 (*.f64 x.re y.re) y.im) x.im))) |
#s(approx (+ (* (neg y.im) x.im) (* x.re y.re)) (*.f64 y.im (fma.f64 #s(literal -1 binary64) x.im (/.f64 (*.f64 x.re y.re) y.im)))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 y.im (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) y.im)) (*.f64 #s(literal -1 binary64) x.im))))) |
#s(approx (+ (* (neg y.im) x.im) (* x.re y.re)) (*.f64 #s(literal -1 binary64) (*.f64 y.im (+.f64 x.im (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) y.im)))))) |
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y.im | @ | -inf | ((- (* x.re y.re) (* x.im y.im)) (* -1 (* x.im y.im)) -1 (* x.im y.im) x.im y.im (+ (* y.re x.re) (neg (* x.im y.im))) y.re x.re (neg (* x.im y.im)) (+ (* (neg y.im) x.im) (* x.re y.re)) (neg y.im) (* x.re y.re)) |
| 1.0ms | x.im | @ | -inf | ((- (* x.re y.re) (* x.im y.im)) (* -1 (* x.im y.im)) -1 (* x.im y.im) x.im y.im (+ (* y.re x.re) (neg (* x.im y.im))) y.re x.re (neg (* x.im y.im)) (+ (* (neg y.im) x.im) (* x.re y.re)) (neg y.im) (* x.re y.re)) |
| 1.0ms | y.im | @ | inf | ((- (* x.re y.re) (* x.im y.im)) (* -1 (* x.im y.im)) -1 (* x.im y.im) x.im y.im (+ (* y.re x.re) (neg (* x.im y.im))) y.re x.re (neg (* x.im y.im)) (+ (* (neg y.im) x.im) (* x.re y.re)) (neg y.im) (* x.re y.re)) |
| 1.0ms | x.re | @ | -inf | ((- (* x.re y.re) (* x.im y.im)) (* -1 (* x.im y.im)) -1 (* x.im y.im) x.im y.im (+ (* y.re x.re) (neg (* x.im y.im))) y.re x.re (neg (* x.im y.im)) (+ (* (neg y.im) x.im) (* x.re y.re)) (neg y.im) (* x.re y.re)) |
| 1.0ms | y.re | @ | -inf | ((- (* x.re y.re) (* x.im y.im)) (* -1 (* x.im y.im)) -1 (* x.im y.im) x.im y.im (+ (* y.re x.re) (neg (* x.im y.im))) y.re x.re (neg (* x.im y.im)) (+ (* (neg y.im) x.im) (* x.re y.re)) (neg y.im) (* x.re y.re)) |
| Inputs |
|---|
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
(*.f64 #s(literal -1 binary64) (*.f64 x.im y.im)) |
#s(literal -1 binary64) |
(*.f64 x.im y.im) |
x.im |
y.im |
(fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
y.re |
x.re |
(neg.f64 (*.f64 x.im y.im)) |
(fma.f64 (neg.f64 y.im) x.im (*.f64 x.re y.re)) |
(neg.f64 y.im) |
(*.f64 x.re y.re) |
| Outputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
(*.f64 #s(literal -1 binary64) (*.f64 x.im y.im)) |
(*.f64 (neg.f64 x.im) y.im) |
(*.f64 (neg.f64 y.im) x.im) |
(*.f64 (*.f64 x.im y.im) #s(literal -1 binary64)) |
(*.f64 x.im (neg.f64 y.im)) |
(*.f64 y.im (neg.f64 x.im)) |
(*.f64 (neg.f64 (*.f64 x.im y.im)) (neg.f64 #s(literal -1 binary64))) |
(*.f64 (neg.f64 #s(literal -1 binary64)) (neg.f64 (*.f64 x.im y.im))) |
(neg.f64 (*.f64 x.im y.im)) |
#s(literal -1 binary64) |
(*.f64 (neg.f64 #s(literal -1 binary64)) #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) (neg.f64 #s(literal -1 binary64))) |
(neg.f64 (neg.f64 #s(literal -1 binary64))) |
(pow.f64 #s(literal -1 binary64) #s(literal 3 binary64)) |
(pow.f64 #s(literal -1 binary64) (+.f64 #s(literal 2 binary64) #s(literal 1 binary64))) |
(pow.f64 #s(literal -1 binary64) (+.f64 #s(literal 3 binary64) #s(literal 2 binary64))) |
(pow.f64 #s(literal -1 binary64) (fma.f64 #s(literal 2 binary64) #s(literal 2 binary64) #s(literal 3 binary64))) |
(pow.f64 #s(literal -1 binary64) (+.f64 #s(literal 2 binary64) #s(literal 3 binary64))) |
(pow.f64 #s(literal -1 binary64) (fma.f64 #s(literal 2 binary64) #s(literal 2 binary64) #s(literal 1 binary64))) |
(pow.f64 #s(literal -1 binary64) (fma.f64 #s(literal 2 binary64) #s(literal 2 binary64) (+.f64 #s(literal 2 binary64) #s(literal 1 binary64)))) |
(pow.f64 #s(literal -1 binary64) (+.f64 (+.f64 #s(literal 2 binary64) #s(literal 1 binary64)) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))) |
(pow.f64 #s(literal -1 binary64) (+.f64 (+.f64 #s(literal 2 binary64) #s(literal 1 binary64)) #s(literal 2 binary64))) |
(pow.f64 #s(literal -1 binary64) (+.f64 #s(literal 3 binary64) (+.f64 #s(literal 2 binary64) #s(literal 2 binary64)))) |
(pow.f64 #s(literal -1 binary64) (+.f64 #s(literal 2 binary64) (+.f64 #s(literal 2 binary64) #s(literal 1 binary64)))) |
(*.f64 x.im y.im) |
(*.f64 y.im x.im) |
(*.f64 (neg.f64 #s(literal -1 binary64)) (*.f64 x.im y.im)) |
(*.f64 (neg.f64 x.im) (neg.f64 y.im)) |
(*.f64 (neg.f64 y.im) (neg.f64 x.im)) |
(*.f64 (*.f64 x.im y.im) (neg.f64 #s(literal -1 binary64))) |
(*.f64 (neg.f64 (*.f64 x.im y.im)) #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) (neg.f64 (*.f64 x.im y.im))) |
(neg.f64 (neg.f64 (*.f64 x.im y.im))) |
x.im |
(*.f64 (neg.f64 #s(literal -1 binary64)) x.im) |
(*.f64 (neg.f64 x.im) #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) (neg.f64 x.im)) |
(*.f64 x.im (neg.f64 #s(literal -1 binary64))) |
(neg.f64 (neg.f64 x.im)) |
y.im |
(*.f64 (neg.f64 #s(literal -1 binary64)) y.im) |
(*.f64 (neg.f64 y.im) #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) (neg.f64 y.im)) |
(*.f64 y.im (neg.f64 #s(literal -1 binary64))) |
(neg.f64 (neg.f64 y.im)) |
(+.f64 (neg.f64 (*.f64 x.im y.im)) (*.f64 x.re y.re)) |
(+.f64 (*.f64 x.re y.re) (neg.f64 (*.f64 x.im y.im))) |
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
(-.f64 (neg.f64 (*.f64 x.im y.im)) (neg.f64 (*.f64 x.re y.re))) |
(fma.f64 (neg.f64 y.im) x.im (*.f64 x.re y.re)) |
(fma.f64 (neg.f64 x.im) y.im (*.f64 x.re y.re)) |
(fma.f64 (*.f64 x.im y.im) #s(literal -1 binary64) (*.f64 x.re y.re)) |
(fma.f64 #s(literal -1 binary64) (*.f64 x.im y.im) (*.f64 x.re y.re)) |
(fma.f64 x.im (neg.f64 y.im) (*.f64 x.re y.re)) |
(fma.f64 y.im (neg.f64 x.im) (*.f64 x.re y.re)) |
(fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 (neg.f64 (*.f64 x.im y.im)) (neg.f64 #s(literal -1 binary64)) (*.f64 x.re y.re)) |
(fma.f64 (neg.f64 #s(literal -1 binary64)) (neg.f64 (*.f64 x.im y.im)) (*.f64 x.re y.re)) |
(fma.f64 x.re y.re (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 (neg.f64 y.re) (neg.f64 x.re) (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 (neg.f64 x.re) (neg.f64 y.re) (neg.f64 (*.f64 x.im y.im))) |
(neg.f64 (-.f64 (*.f64 x.im y.im) (*.f64 x.re y.re))) |
y.re |
(neg.f64 (neg.f64 y.re)) |
x.re |
(neg.f64 (neg.f64 x.re)) |
(*.f64 #s(literal -1 binary64) (*.f64 x.im y.im)) |
(*.f64 (neg.f64 x.im) y.im) |
(*.f64 (neg.f64 y.im) x.im) |
(*.f64 (*.f64 x.im y.im) #s(literal -1 binary64)) |
(*.f64 x.im (neg.f64 y.im)) |
(*.f64 y.im (neg.f64 x.im)) |
(*.f64 (neg.f64 (*.f64 x.im y.im)) (neg.f64 #s(literal -1 binary64))) |
(*.f64 (neg.f64 #s(literal -1 binary64)) (neg.f64 (*.f64 x.im y.im))) |
(neg.f64 (*.f64 x.im y.im)) |
(+.f64 (neg.f64 (*.f64 x.im y.im)) (*.f64 x.re y.re)) |
(+.f64 (*.f64 x.re y.re) (neg.f64 (*.f64 x.im y.im))) |
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
(-.f64 (neg.f64 (*.f64 x.im y.im)) (neg.f64 (*.f64 x.re y.re))) |
(fma.f64 (neg.f64 y.im) x.im (*.f64 x.re y.re)) |
(fma.f64 (neg.f64 x.im) y.im (*.f64 x.re y.re)) |
(fma.f64 (*.f64 x.im y.im) #s(literal -1 binary64) (*.f64 x.re y.re)) |
(fma.f64 #s(literal -1 binary64) (*.f64 x.im y.im) (*.f64 x.re y.re)) |
(fma.f64 x.im (neg.f64 y.im) (*.f64 x.re y.re)) |
(fma.f64 y.im (neg.f64 x.im) (*.f64 x.re y.re)) |
(fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 (neg.f64 (*.f64 x.im y.im)) (neg.f64 #s(literal -1 binary64)) (*.f64 x.re y.re)) |
(fma.f64 (neg.f64 #s(literal -1 binary64)) (neg.f64 (*.f64 x.im y.im)) (*.f64 x.re y.re)) |
(fma.f64 x.re y.re (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 (neg.f64 y.re) (neg.f64 x.re) (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 (neg.f64 x.re) (neg.f64 y.re) (neg.f64 (*.f64 x.im y.im))) |
(neg.f64 (-.f64 (*.f64 x.im y.im) (*.f64 x.re y.re))) |
(*.f64 y.im #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) y.im) |
(*.f64 (neg.f64 #s(literal -1 binary64)) (neg.f64 y.im)) |
(*.f64 (neg.f64 y.im) (neg.f64 #s(literal -1 binary64))) |
(neg.f64 y.im) |
(*.f64 x.re y.re) |
(*.f64 y.re x.re) |
(*.f64 (neg.f64 x.re) (neg.f64 y.re)) |
(*.f64 (neg.f64 y.re) (neg.f64 x.re)) |
(neg.f64 (neg.f64 (*.f64 x.re y.re))) |
Compiled 595 to 335 computations (43.7% saved)
4 alts after pruning (1 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 122 | 1 | 123 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 2 | 3 |
| Done | 0 | 1 | 1 |
| Total | 123 | 4 | 127 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 99.2% | (fma.f64 (neg.f64 y.im) x.im (*.f64 x.re y.re)) |
| ✓ | 99.6% | (fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
| ✓ | 98.8% | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| ▶ | 50.3% | #s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
Compiled 31 to 31 computations (0% saved)
| Inputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
(neg.f64 (*.f64 x.im y.im)) |
(*.f64 x.im y.im) |
x.im |
y.im |
| Outputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re (+.f64 y.re (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.im y.im) x.re))))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.re (fma.f64 #s(literal -1 binary64) y.re (/.f64 (*.f64 x.im y.im) x.re))))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (fma.f64 #s(literal -1 binary64) (*.f64 x.im y.im) (*.f64 x.re y.re))) |
#s(approx (* x.im y.im) (*.f64 x.im y.im)) |
#s(approx x.im x.im) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.im (-.f64 (/.f64 (*.f64 x.re y.re) x.im) y.im))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) x.im)) (*.f64 #s(literal -1 binary64) y.im))))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 y.re (+.f64 x.re (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.im y.im) y.re))))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 y.re (fma.f64 #s(literal -1 binary64) x.re (/.f64 (*.f64 x.im y.im) y.re))))) |
#s(approx y.im y.im) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 y.im (-.f64 (/.f64 (*.f64 x.re y.re) y.im) x.im))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 y.im (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) y.im)) (*.f64 #s(literal -1 binary64) x.im))))) |
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y.im | @ | -inf | ((- (* y.re x.re) (* y.im x.im)) (neg (* x.im y.im)) (* x.im y.im) x.im y.im) |
| 1.0ms | x.im | @ | -inf | ((- (* y.re x.re) (* y.im x.im)) (neg (* x.im y.im)) (* x.im y.im) x.im y.im) |
| 0.0ms | x.im | @ | inf | ((- (* y.re x.re) (* y.im x.im)) (neg (* x.im y.im)) (* x.im y.im) x.im y.im) |
| 0.0ms | y.im | @ | inf | ((- (* y.re x.re) (* y.im x.im)) (neg (* x.im y.im)) (* x.im y.im) x.im y.im) |
| 0.0ms | x.im | @ | 0 | ((- (* y.re x.re) (* y.im x.im)) (neg (* x.im y.im)) (* x.im y.im) x.im y.im) |
| Inputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
(neg.f64 (*.f64 x.im y.im)) |
(*.f64 x.im y.im) |
x.im |
y.im |
| Outputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
(*.f64 (neg.f64 x.im) y.im) |
(*.f64 (neg.f64 y.im) x.im) |
(*.f64 x.im (neg.f64 y.im)) |
(*.f64 y.im (neg.f64 x.im)) |
(neg.f64 (*.f64 x.im y.im)) |
(*.f64 x.im y.im) |
(*.f64 y.im x.im) |
(*.f64 (neg.f64 x.im) (neg.f64 y.im)) |
(*.f64 (neg.f64 y.im) (neg.f64 x.im)) |
(neg.f64 (neg.f64 (*.f64 x.im y.im))) |
x.im |
(neg.f64 (neg.f64 x.im)) |
y.im |
(neg.f64 (neg.f64 y.im)) |
Compiled 160 to 98 computations (38.8% saved)
4 alts after pruning (1 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 24 | 1 | 25 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 1 | 2 | 3 |
| Total | 25 | 4 | 29 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 99.6% | (fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
| ✓ | 98.8% | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| ▶ | 52.3% | #s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
| ✓ | 50.3% | #s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
Compiled 33 to 33 computations (0% saved)
| Inputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
(*.f64 x.re y.re) |
x.re |
y.re |
| Outputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im))) |
#s(approx (* x.re y.re) (*.f64 x.re y.re)) |
#s(approx x.re x.re) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re (+.f64 y.re (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.im y.im) x.re))))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.re (fma.f64 #s(literal -1 binary64) y.re (/.f64 (*.f64 x.im y.im) x.re))))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (fma.f64 #s(literal -1 binary64) (*.f64 x.im y.im) (*.f64 x.re y.re))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.im (-.f64 (/.f64 (*.f64 x.re y.re) x.im) y.im))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) x.im)) (*.f64 #s(literal -1 binary64) y.im))))) |
#s(approx y.re y.re) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 y.re (+.f64 x.re (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.im y.im) y.re))))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 y.re (fma.f64 #s(literal -1 binary64) x.re (/.f64 (*.f64 x.im y.im) y.re))))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 y.im (-.f64 (/.f64 (*.f64 x.re y.re) y.im) x.im))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 #s(literal -1 binary64) (*.f64 y.im (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x.re y.re) y.im)) (*.f64 #s(literal -1 binary64) x.im))))) |
12 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | y.re | @ | -inf | ((- (* y.re x.re) (* y.im x.im)) (* x.re y.re) x.re y.re) |
| 1.0ms | x.re | @ | -inf | ((- (* y.re x.re) (* y.im x.im)) (* x.re y.re) x.re y.re) |
| 1.0ms | x.re | @ | inf | ((- (* y.re x.re) (* y.im x.im)) (* x.re y.re) x.re y.re) |
| 0.0ms | y.re | @ | inf | ((- (* y.re x.re) (* y.im x.im)) (* x.re y.re) x.re y.re) |
| 0.0ms | x.re | @ | 0 | ((- (* y.re x.re) (* y.im x.im)) (* x.re y.re) x.re y.re) |
| Inputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
(*.f64 x.re y.re) |
x.re |
y.re |
| Outputs |
|---|
#s(approx (- (* y.re x.re) (* x.im y.im)) (*.f64 x.re y.re)) |
(*.f64 x.re y.re) |
(*.f64 y.re x.re) |
(*.f64 (neg.f64 x.re) (neg.f64 y.re)) |
(*.f64 (neg.f64 y.re) (neg.f64 x.re)) |
(neg.f64 (neg.f64 (*.f64 x.re y.re))) |
x.re |
(neg.f64 (neg.f64 x.re)) |
y.re |
(neg.f64 (neg.f64 y.re)) |
Compiled 139 to 83 computations (40.3% saved)
4 alts after pruning (0 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 21 | 0 | 21 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 3 | 3 |
| Total | 21 | 4 | 25 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 99.6% | (fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
| ✓ | 98.8% | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| ✓ | 52.3% | #s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
| ✓ | 50.3% | #s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
Compiled 64 to 55 computations (14.1% saved)
| Inputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
(fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
(fma.f64 (neg.f64 y.im) x.im (*.f64 x.re y.re)) |
| Outputs |
|---|
(fma.f64 y.re x.re (neg.f64 (*.f64 x.im y.im))) |
7 calls:
| 4.0ms | (*.f64 x.re y.re) |
| 2.0ms | y.re |
| 2.0ms | y.im |
| 2.0ms | x.re |
| 2.0ms | x.im |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.6% | 1 | (*.f64 x.im y.im) |
| 99.6% | 1 | (*.f64 x.re y.re) |
| 99.6% | 1 | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| 99.6% | 1 | x.re |
| 99.6% | 1 | x.im |
| 99.6% | 1 | y.re |
| 99.6% | 1 | y.im |
Compiled 17 to 33 computations (-94.1% saved)
| Inputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| Outputs |
|---|
(-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
7 calls:
| 2.0ms | y.im |
| 2.0ms | y.re |
| 2.0ms | x.re |
| 2.0ms | x.im |
| 2.0ms | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.8% | 1 | (*.f64 x.im y.im) |
| 98.8% | 1 | (*.f64 x.re y.re) |
| 98.8% | 1 | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| 98.8% | 1 | x.re |
| 98.8% | 1 | x.im |
| 98.8% | 1 | y.re |
| 98.8% | 1 | y.im |
Compiled 17 to 33 computations (-94.1% saved)
| Inputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
#s(approx (- (* x.re y.re) (* x.im y.im)) (*.f64 #s(literal -1 binary64) (*.f64 x.im y.im))) |
| Outputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
#s(approx (- (* y.re x.re) (* y.im x.im)) (neg.f64 (*.f64 x.im y.im))) |
7 calls:
| 9.0ms | (*.f64 x.im y.im) |
| 1.0ms | y.re |
| 1.0ms | x.re |
| 1.0ms | y.im |
| 1.0ms | x.im |
| Accuracy | Segments | Branch |
|---|---|---|
| 79.0% | 3 | (*.f64 x.im y.im) |
| 76.6% | 3 | (*.f64 x.re y.re) |
| 55.6% | 2 | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| 72.8% | 3 | x.re |
| 68.4% | 3 | x.im |
| 73.5% | 3 | y.re |
| 72.3% | 3 | y.im |
Compiled 17 to 33 computations (-94.1% saved)
Total 0.0b remaining (0%)
Threshold costs 0b (0%)
| Inputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
| Outputs |
|---|
#s(approx (- (* y.re x.re) (* y.im x.im)) (*.f64 x.re y.re)) |
7 calls:
| 1.0ms | (*.f64 x.im y.im) |
| 1.0ms | y.re |
| 1.0ms | x.re |
| 1.0ms | y.im |
| 1.0ms | x.im |
| Accuracy | Segments | Branch |
|---|---|---|
| 52.3% | 1 | (-.f64 (*.f64 x.re y.re) (*.f64 x.im y.im)) |
| 52.3% | 1 | x.im |
| 52.3% | 1 | y.im |
| 52.3% | 1 | x.re |
| 52.3% | 1 | y.re |
| 52.3% | 1 | (*.f64 x.re y.re) |
| 52.3% | 1 | (*.f64 x.im y.im) |
Compiled 17 to 33 computations (-94.1% saved)
| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 7.0ms | 2187463.627323604 | 60423876.03443364 |
| 9.0ms | -3.197997324544816e-58 | -4.337929117692312e-65 |
| 8.0ms | 256× | 0 | valid |
Compiled 314 to 334 computations (-6.4% saved)
ival-sub!: 1.0ms (50.5% of total)ival-mult!: 1.0ms (50.5% of total)adjust: 0.0ms (0% of total)| 1× | done |
Compiled 27 to 20 computations (25.9% saved)
(sort x.im y.im)
(sort x.re y.re)
Compiled 214 to 191 computations (10.7% saved)
Loading profile data...