
Time bar (total: 1.5s)
| 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 8 computations (11.1% saved)
| 434.0ms | 8 256× | 0 | valid |
ival-add!: 55.0ms (50.3% of total)ival-mult!: 53.0ms (48.5% of total)adjust: 1.0ms (0.9% of total)Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 29 | 75 |
| 1 | 118 | 70 |
| 2 | 496 | 70 |
| 3 | 935 | 70 |
| 4 | 1116 | 70 |
| 5 | 1243 | 70 |
| 6 | 1491 | 70 |
| 7 | 5605 | 70 |
| 1× | node-limit |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (+.f64 x (*.f64 y (+.f64 z x))) |
Compiled 14 to 12 computations (14.3% saved)
| Inputs |
|---|
(+.f64 x (*.f64 y (+.f64 z x))) |
x |
(*.f64 y (+.f64 z x)) |
y |
(+.f64 z x) |
z |
| Outputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
#s(approx (+ x (* y (+ z x))) (fma.f64 x (+.f64 #s(literal 1 binary64) y) (*.f64 y z))) |
#s(approx x x) |
#s(approx (* y (+ z x)) (fma.f64 x y (*.f64 y z))) |
#s(approx (+ z x) z) |
#s(approx (+ z x) (+.f64 x z)) |
#s(approx (+ x (* y (+ z x))) (*.f64 x (+.f64 #s(literal 1 binary64) y))) |
#s(approx (+ x (* y (+ z x))) (*.f64 x (+.f64 #s(literal 1 binary64) (+.f64 y (/.f64 (*.f64 y z) x))))) |
#s(approx (* y (+ z x)) (*.f64 x y)) |
#s(approx (* y (+ z x)) (*.f64 x (+.f64 y (/.f64 (*.f64 y z) x)))) |
#s(approx (+ z x) (*.f64 x (+.f64 #s(literal 1 binary64) (/.f64 z x)))) |
#s(approx (+ x (* y (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) y) #s(literal 1 binary64))))) |
#s(approx (+ x (* y (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x))) #s(literal 1 binary64))))) |
#s(approx (* y (+ z x)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x)))))) |
#s(approx (+ z x) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z x)) #s(literal 1 binary64))))) |
#s(approx (+ x (* y (+ z x))) (+.f64 x (*.f64 y (+.f64 x z)))) |
#s(approx (* y (+ z x)) (*.f64 y (+.f64 x z))) |
#s(approx y y) |
#s(approx (+ x (* y (+ z x))) (*.f64 y (+.f64 x (+.f64 z (/.f64 x y))))) |
#s(approx (+ x (* y (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) (+.f64 x z) (*.f64 #s(literal -1 binary64) (/.f64 x y)))))) |
#s(approx (+ x (* y (+ z x))) (+.f64 x (*.f64 x y))) |
#s(approx (+ x (* y (+ z x))) (+.f64 x (fma.f64 x y (*.f64 y z)))) |
#s(approx (+ x (* y (+ z x))) (*.f64 z (+.f64 y (+.f64 (/.f64 x z) (/.f64 (*.f64 x y) z))))) |
#s(approx (* y (+ z x)) (*.f64 z (+.f64 y (/.f64 (*.f64 x y) z)))) |
#s(approx (+ z x) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 x z)))) |
#s(approx (+ x (* y (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (*.f64 x y)) z)))))) |
#s(approx (* y (+ z x)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)))))) |
#s(approx (+ z x) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x z)) #s(literal 1 binary64))))) |
9 calls:
| Time | Variable | Point |
|---|---|---|
| 1.0ms | z | -inf |
| 1.0ms | y | inf |
| 1.0ms | x | inf |
| 1.0ms | x | -inf |
| 1.0ms | y | -inf |
| Inputs |
|---|
(+.f64 x (*.f64 y (+.f64 z x))) |
x |
(*.f64 y (+.f64 z x)) |
y |
(+.f64 z x) |
z |
| Outputs |
|---|
(+.f64 (*.f64 y (+.f64 z x)) x) |
(+.f64 x (*.f64 y (+.f64 z x))) |
(-.f64 x (*.f64 (neg.f64 y) (+.f64 z x))) |
(-.f64 x (neg.f64 (*.f64 y (+.f64 z x)))) |
(fma.f64 (+.f64 z x) y x) |
(fma.f64 y (+.f64 z x) x) |
x |
(*.f64 y (+.f64 z x)) |
(*.f64 (+.f64 z x) y) |
(+.f64 (*.f64 z y) (*.f64 x y)) |
(+.f64 (*.f64 y z) (*.f64 y x)) |
(fma.f64 z y (*.f64 x y)) |
(fma.f64 y z (*.f64 y x)) |
y |
(+.f64 z x) |
(+.f64 x z) |
(-.f64 z (neg.f64 x)) |
z |
Compiled 543 to 150 computations (72.4% saved)
4 alts after pruning (4 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 36 | 4 | 40 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 37 | 4 | 41 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (fma.f64 (+.f64 z x) y x) |
| ▶ | 74.1% | (+.f64 x (*.f64 y #s(approx (+ z x) z))) |
| ▶ | 62.3% | (+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
| ▶ | 40.5% | #s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
Compiled 37 to 28 computations (24.3% saved)
| Inputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
(*.f64 y z) |
y |
z |
(+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
x |
#s(approx (* y (+ z x)) (*.f64 x y)) |
(*.f64 x y) |
(+.f64 x (*.f64 y #s(approx (+ z x) z))) |
(*.f64 y #s(approx (+ z x) z)) |
#s(approx (+ z x) z) |
(fma.f64 (+.f64 z x) y x) |
(+.f64 z x) |
| Outputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
#s(approx (+ x (* y (+ z x))) (fma.f64 x (+.f64 #s(literal 1 binary64) y) (*.f64 y z))) |
#s(approx x x) |
#s(approx (* y (+ z x)) (fma.f64 x y (*.f64 y z))) |
#s(approx (* x y) (*.f64 x y)) |
#s(approx (+ z x) z) |
#s(approx (+ z x) (+.f64 x z)) |
#s(approx (+ x (* y (+ z x))) (*.f64 x (+.f64 #s(literal 1 binary64) y))) |
#s(approx (+ x (* y (+ z x))) (*.f64 x (+.f64 #s(literal 1 binary64) (+.f64 y (/.f64 (*.f64 y z) x))))) |
#s(approx (* y (+ z x)) (*.f64 x (+.f64 y (/.f64 (*.f64 y z) x)))) |
#s(approx (+ z x) (*.f64 x (+.f64 #s(literal 1 binary64) (/.f64 z x)))) |
#s(approx (+ x (* y (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) y) #s(literal 1 binary64))))) |
#s(approx (+ x (* y (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x))) #s(literal 1 binary64))))) |
#s(approx (* y (+ z x)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 y z) x)))))) |
#s(approx (+ z x) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 z x)) #s(literal 1 binary64))))) |
#s(approx (+ x (* y (+ z x))) (+.f64 x (*.f64 y (+.f64 x z)))) |
#s(approx y y) |
#s(approx (* y (+ z x)) (*.f64 y (+.f64 x z))) |
#s(approx (+ x (* y (+ z x))) (*.f64 y (+.f64 x (+.f64 z (/.f64 x y))))) |
#s(approx (+ x (* y (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) (+.f64 x z) (*.f64 #s(literal -1 binary64) (/.f64 x y)))))) |
#s(approx (+ x (* y (+ z x))) (+.f64 x (*.f64 x y))) |
#s(approx (+ x (* y (+ z x))) (+.f64 x (fma.f64 x y (*.f64 y z)))) |
#s(approx (+ x (* y (+ z x))) (*.f64 z (+.f64 y (+.f64 (/.f64 x z) (/.f64 (*.f64 x y) z))))) |
#s(approx (* y (+ z x)) (*.f64 z (+.f64 y (/.f64 (*.f64 x y) z)))) |
#s(approx (+ z x) (*.f64 z (+.f64 #s(literal 1 binary64) (/.f64 x z)))) |
#s(approx (+ x (* y (+ z x))) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 x (*.f64 x y)) z)))))) |
#s(approx (* y (+ z x)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)))))) |
#s(approx (+ z x) (*.f64 #s(literal -1 binary64) (*.f64 z (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x z)) #s(literal 1 binary64))))) |
9 calls:
| Time | Variable | Point |
|---|---|---|
| 6.0ms | y | inf |
| 1.0ms | x | -inf |
| 1.0ms | y | -inf |
| 1.0ms | y | 0 |
| 1.0ms | x | inf |
| Inputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
(*.f64 y z) |
y |
z |
(+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
x |
#s(approx (* y (+ z x)) (*.f64 x y)) |
(*.f64 x y) |
(+.f64 x (*.f64 y #s(approx (+ z x) z))) |
(*.f64 y #s(approx (+ z x) z)) |
#s(approx (+ z x) z) |
(fma.f64 (+.f64 z x) y x) |
(+.f64 z x) |
| Outputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
(*.f64 y z) |
(*.f64 z y) |
y |
z |
(+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
x |
#s(approx (* y (+ z x)) (*.f64 x y)) |
(*.f64 x y) |
(*.f64 y x) |
(+.f64 x (*.f64 y #s(approx (+ z x) z))) |
(*.f64 y #s(approx (+ z x) z)) |
#s(approx (+ z x) z) |
(+.f64 (*.f64 (+.f64 z x) y) x) |
(+.f64 x (*.f64 (+.f64 z x) y)) |
(-.f64 (*.f64 (+.f64 z x) y) (neg.f64 x)) |
(-.f64 x (*.f64 (neg.f64 y) (+.f64 z x))) |
(-.f64 x (neg.f64 (*.f64 (+.f64 z x) y))) |
(fma.f64 (+.f64 z x) y x) |
(fma.f64 y (+.f64 z x) x) |
(+.f64 z x) |
(+.f64 x z) |
(-.f64 z (neg.f64 x)) |
Compiled 576 to 153 computations (73.4% saved)
4 alts after pruning (0 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 41 | 0 | 41 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 4 | 4 |
| Done | 0 | 0 | 0 |
| Total | 41 | 4 | 45 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (fma.f64 (+.f64 z x) y x) |
| ✓ | 74.1% | (+.f64 x (*.f64 y #s(approx (+ z x) z))) |
| ✓ | 62.3% | (+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
| ✓ | 40.5% | #s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
Compiled 37 to 28 computations (24.3% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
| Outputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
| Inputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
(+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
| Outputs |
|---|
(+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
(+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
| Inputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
(+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
(+.f64 x (*.f64 y #s(approx (+ z x) z))) |
| Outputs |
|---|
(+.f64 x (*.f64 y #s(approx (+ z x) z))) |
(+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
(+.f64 x (*.f64 y #s(approx (+ z x) z))) |
| Inputs |
|---|
#s(approx (+ x (* y (+ z x))) (*.f64 y z)) |
(+.f64 x #s(approx (* y (+ z x)) (*.f64 x y))) |
(+.f64 x (*.f64 y #s(approx (+ z x) z))) |
(fma.f64 (+.f64 z x) y x) |
(+.f64 x (*.f64 y (+.f64 z x))) |
| Outputs |
|---|
(fma.f64 (+.f64 z x) y x) |
15 calls:
| 2.0ms | y |
| 2.0ms | x |
| 2.0ms | x |
| 2.0ms | (+.f64 x (*.f64 y (+.f64 z x))) |
| 2.0ms | z |
| Accuracy | Segments | Branch |
|---|---|---|
| 40.5% | 1 | y |
| 40.5% | 1 | (+.f64 x (*.f64 y (+.f64 z x))) |
| 40.5% | 1 | z |
| 40.5% | 1 | x |
| 70.7% | 5 | y |
| 80.3% | 3 | x |
| 78.4% | 3 | z |
| 76.4% | 2 | (+.f64 x (*.f64 y (+.f64 z x))) |
| 87.2% | 3 | x |
| 81.8% | 3 | y |
| 88.1% | 3 | z |
| 100.0% | 1 | (+.f64 x (*.f64 y (+.f64 z x))) |
| 100.0% | 1 | x |
| 100.0% | 1 | y |
| 100.0% | 1 | z |
Compiled 77 to 72 computations (6.5% saved)
| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 5.0ms | 6.3409622114821046e-49 | 1.4119011023120134e-48 |
| 8.0ms | -1.370016449934991e-19 | -2.3725495961246867e-23 |
| 6.0ms | 208× | 0 | valid |
Compiled 270 to 233 computations (13.7% saved)
ival-add!: 1.0ms (47.4% of total)ival-mult!: 1.0ms (47.4% of total)adjust: 0.0ms (0% of total)| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 10.0ms | 5.714027296282703e-153 | 7.867545037408001e-146 |
| 7.0ms | -9209891787357062.0 | -54061626682970.94 |
| 8.0ms | 256× | 0 | valid |
Compiled 362 to 300 computations (17.1% saved)
ival-add!: 1.0ms (38.6% of total)ival-mult!: 1.0ms (38.6% of total)adjust: 0.0ms (0% of total)| 1× | done |
Compiled 95 to 28 computations (70.5% saved)
Compiled 102 to 34 computations (66.7% saved)
Loading profile data...