
Time bar (total: 1.4s)
| 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)
| 417.0ms | 8 256× | 0 | valid |
ival-mult!: 226.0ms (91.6% of total)ival-add!: 19.0ms (7.7% of total)adjust: 1.0ms (0.4% of total)Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 28 | 77 |
| 1 | 103 | 71 |
| 2 | 288 | 71 |
| 3 | 561 | 71 |
| 4 | 773 | 71 |
| 5 | 1326 | 71 |
| 6 | 4659 | 71 |
| 1× | node-limit |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 99.9% | (+.f64 x (*.f64 (*.f64 y z) z)) |
(abs z)
Compiled 12 to 12 computations (0% saved)
| Inputs |
|---|
(+.f64 x (*.f64 (*.f64 y z) z)) |
x |
(*.f64 (*.f64 y z) z) |
(*.f64 y z) |
y |
z |
| Outputs |
|---|
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (pow z 2)))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (+ x (* y (pow z 2))))) |
#s(approx x #s(hole binary64 x)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* x (+ 1 (/ (* y (pow z 2)) x))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* x (- (* -1 (/ (* y (pow z 2)) x)) 1))))) |
#s(approx (* y z) #s(hole binary64 (* y z))) |
#s(approx y #s(hole binary64 y)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (+ (/ x y) (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* y (+ (* -1 (/ x y)) (* -1 (pow z 2))))))) |
#s(approx z #s(hole binary64 z)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* (pow z 2) (+ y (/ x (pow z 2)))))) |
9 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | z | @ | inf | ((+ x (* (* y z) z)) x (* (* y z) z) (* y z) y z) |
| 1.0ms | y | @ | -inf | ((+ x (* (* y z) z)) x (* (* y z) z) (* y z) y z) |
| 1.0ms | y | @ | 0 | ((+ x (* (* y z) z)) x (* (* y z) z) (* y z) y z) |
| 1.0ms | z | @ | -inf | ((+ x (* (* y z) z)) x (* (* y z) z) (* y z) y z) |
| 1.0ms | y | @ | inf | ((+ x (* (* y z) z)) x (* (* y z) z) (* y z) y z) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 44 | 163 |
| 0 | 47 | 153 |
| 1 | 246 | 153 |
| 0 | 1960 | 139 |
| 1 | 5915 | 139 |
| 1× | saturated |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
(+.f64 x (*.f64 (*.f64 y z) z)) |
x |
(*.f64 (*.f64 y z) z) |
(*.f64 y z) |
y |
z |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (pow z 2)))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (+ x (* y (pow z 2))))) |
#s(approx x #s(hole binary64 x)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* x (+ 1 (/ (* y (pow z 2)) x))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* x (- (* -1 (/ (* y (pow z 2)) x)) 1))))) |
#s(approx (* y z) #s(hole binary64 (* y z))) |
#s(approx y #s(hole binary64 y)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (+ (/ x y) (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* y (+ (* -1 (/ x y)) (* -1 (pow z 2))))))) |
#s(approx z #s(hole binary64 z)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* (pow z 2) (+ y (/ x (pow z 2)))))) |
| Outputs |
|---|
(neg.f64 (-.f64 (*.f64 (*.f64 (neg.f64 y) z) z) x)) |
(fma.f64 (*.f64 z z) y x) |
(fma.f64 (*.f64 z y) z x) |
(fma.f64 z (*.f64 z y) x) |
(fma.f64 y (*.f64 z z) x) |
(-.f64 (*.f64 (*.f64 z z) y) (neg.f64 x)) |
(-.f64 x (*.f64 (*.f64 (neg.f64 y) z) z)) |
(+.f64 (*.f64 (*.f64 z z) y) x) |
(+.f64 x (*.f64 (neg.f64 (neg.f64 y)) (*.f64 z z))) |
(+.f64 x (*.f64 (neg.f64 (*.f64 (neg.f64 y) z)) z)) |
(+.f64 x (neg.f64 (*.f64 (*.f64 (neg.f64 y) z) z))) |
(+.f64 x (*.f64 (*.f64 z z) y)) |
x |
(*.f64 (*.f64 z z) y) |
(*.f64 (*.f64 z y) z) |
(*.f64 z (*.f64 z y)) |
(*.f64 y (*.f64 z z)) |
(*.f64 z y) |
(*.f64 y z) |
y |
z |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (*.f64 z y) z x)) |
#s(approx x x) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (/.f64 (*.f64 (*.f64 z z) y) x) x x)) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (/.f64 (*.f64 (*.f64 z z) y) x) x x)) |
#s(approx (* y z) (*.f64 z y)) |
#s(approx y y) |
#s(approx (+ x (* (* y z) z)) (*.f64 (fma.f64 z z (/.f64 x y)) y)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (fma.f64 z z (/.f64 x y)) y)) |
#s(approx z z) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 (+.f64 (/.f64 x (*.f64 z z)) y) z) z)) |
Compiled 114 to 66 computations (42.1% saved)
3 alts after pruning (3 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 23 | 3 | 26 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 24 | 3 | 27 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 92.0% | (fma.f64 (*.f64 z z) y x) |
| ▶ | 99.9% | (fma.f64 (*.f64 z y) z x) |
| ▶ | 44.6% | #s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
Compiled 19 to 19 computations (0% saved)
| Inputs |
|---|
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
(*.f64 (*.f64 z z) y) |
(*.f64 z z) |
z |
y |
(fma.f64 (*.f64 z y) z x) |
(*.f64 z y) |
x |
(fma.f64 (*.f64 z z) y x) |
| Outputs |
|---|
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (pow z 2)))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (+ x (* y (pow z 2))))) |
#s(approx x #s(hole binary64 x)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* x (+ 1 (/ (* y (pow z 2)) x))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* x (- (* -1 (/ (* y (pow z 2)) x)) 1))))) |
#s(approx y #s(hole binary64 y)) |
#s(approx (* z y) #s(hole binary64 (* y z))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (+ (/ x y) (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* y (+ (* -1 (/ x y)) (* -1 (pow z 2))))))) |
#s(approx (* z z) #s(hole binary64 (pow z 2))) |
#s(approx z #s(hole binary64 z)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* (pow z 2) (+ y (/ x (pow z 2)))))) |
9 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | z | @ | -inf | ((+ x (* (* y z) z)) (* (* z z) y) (* z z) z y (+ (* (* z y) z) x) (* z y) x (+ (* (* z z) y) x)) |
| 1.0ms | y | @ | -inf | ((+ x (* (* y z) z)) (* (* z z) y) (* z z) z y (+ (* (* z y) z) x) (* z y) x (+ (* (* z z) y) x)) |
| 1.0ms | z | @ | inf | ((+ x (* (* y z) z)) (* (* z z) y) (* z z) z y (+ (* (* z y) z) x) (* z y) x (+ (* (* z z) y) x)) |
| 1.0ms | y | @ | inf | ((+ x (* (* y z) z)) (* (* z z) y) (* z z) z y (+ (* (* z y) z) x) (* z y) x (+ (* (* z z) y) x)) |
| 1.0ms | y | @ | 0 | ((+ x (* (* y z) z)) (* (* z z) y) (* z z) z y (+ (* (* z y) z) x) (* z y) x (+ (* (* z z) y) x)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 50 | 191 |
| 0 | 56 | 172 |
| 1 | 292 | 172 |
| 0 | 2178 | 167 |
| 1 | 6831 | 167 |
| 1× | saturated |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
(*.f64 (*.f64 z z) y) |
(*.f64 z z) |
z |
y |
(fma.f64 (*.f64 z y) z x) |
(*.f64 z y) |
x |
(fma.f64 (*.f64 z z) y x) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (pow z 2)))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (+ x (* y (pow z 2))))) |
#s(approx x #s(hole binary64 x)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* x (+ 1 (/ (* y (pow z 2)) x))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* x (- (* -1 (/ (* y (pow z 2)) x)) 1))))) |
#s(approx y #s(hole binary64 y)) |
#s(approx (* z y) #s(hole binary64 (* y z))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (+ (/ x y) (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* y (+ (* -1 (/ x y)) (* -1 (pow z 2))))))) |
#s(approx (* z z) #s(hole binary64 (pow z 2))) |
#s(approx z #s(hole binary64 z)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* (pow z 2) (+ y (/ x (pow z 2)))))) |
| Outputs |
|---|
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
(*.f64 (*.f64 y (fabs.f64 z)) (fabs.f64 z)) |
(*.f64 (*.f64 (neg.f64 y) z) (neg.f64 z)) |
(*.f64 (fabs.f64 z) (*.f64 (fabs.f64 z) y)) |
(*.f64 (neg.f64 z) (*.f64 (neg.f64 y) z)) |
(*.f64 (*.f64 z z) y) |
(*.f64 (*.f64 z y) z) |
(*.f64 z (*.f64 z y)) |
(*.f64 y (*.f64 z z)) |
(*.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 z)) (*.f64 #s(literal 1 binary64) (fabs.f64 z))) |
(*.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 z)) (fabs.f64 z)) |
(*.f64 (*.f64 #s(literal 1 binary64) (neg.f64 z)) (*.f64 #s(literal 1 binary64) (neg.f64 z))) |
(*.f64 (*.f64 #s(literal 1 binary64) (neg.f64 z)) (neg.f64 z)) |
(*.f64 (*.f64 #s(literal 1 binary64) z) (*.f64 #s(literal 1 binary64) z)) |
(*.f64 (*.f64 #s(literal 1 binary64) z) z) |
(*.f64 (fabs.f64 (fabs.f64 z)) (fabs.f64 (fabs.f64 z))) |
(*.f64 (neg.f64 (fabs.f64 z)) (neg.f64 (fabs.f64 z))) |
(*.f64 (neg.f64 (neg.f64 z)) (neg.f64 (neg.f64 z))) |
(*.f64 (fabs.f64 z) (fabs.f64 z)) |
(*.f64 (neg.f64 z) (neg.f64 z)) |
(*.f64 (*.f64 (neg.f64 z) z) #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) (*.f64 (neg.f64 z) z)) |
(*.f64 #s(literal 1 binary64) (*.f64 z z)) |
(*.f64 (*.f64 z z) #s(literal 1 binary64)) |
(*.f64 z z) |
(pow.f64 (fabs.f64 (fabs.f64 z)) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 (fabs.f64 z)) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 (neg.f64 z)) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 z) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 z) #s(literal 2 binary64)) |
(pow.f64 z #s(literal 2 binary64)) |
(/.f64 (*.f64 #s(literal 2 binary64) (*.f64 z z)) #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 z) z)) |
(sqrt.f64 (*.f64 (*.f64 (*.f64 z z) z) z)) |
(fabs.f64 (*.f64 (neg.f64 z) z)) |
(fabs.f64 (*.f64 z z)) |
z |
y |
(neg.f64 (-.f64 (neg.f64 x) (*.f64 (*.f64 z z) y))) |
(neg.f64 (-.f64 (*.f64 (*.f64 (neg.f64 y) z) z) x)) |
(fma.f64 (*.f64 y (fabs.f64 z)) (fabs.f64 z) x) |
(fma.f64 (*.f64 (neg.f64 y) z) (neg.f64 z) x) |
(fma.f64 (fabs.f64 z) (*.f64 (fabs.f64 z) y) x) |
(fma.f64 (neg.f64 z) (*.f64 (neg.f64 y) z) x) |
(fma.f64 (*.f64 z z) y x) |
(fma.f64 (*.f64 z y) z x) |
(fma.f64 z (*.f64 z y) x) |
(fma.f64 y (*.f64 z z) x) |
(-.f64 (*.f64 (*.f64 z z) y) (neg.f64 x)) |
(-.f64 x (*.f64 (*.f64 (neg.f64 y) z) z)) |
(+.f64 (*.f64 (*.f64 z z) y) x) |
(+.f64 x (*.f64 (neg.f64 (*.f64 (neg.f64 y) z)) z)) |
(+.f64 x (*.f64 (neg.f64 (neg.f64 y)) (*.f64 z z))) |
(+.f64 x (neg.f64 (*.f64 (*.f64 (neg.f64 y) z) z))) |
(+.f64 x (*.f64 (*.f64 z z) y)) |
(*.f64 z y) |
(*.f64 y z) |
x |
(neg.f64 (-.f64 (neg.f64 x) (*.f64 (*.f64 z z) y))) |
(neg.f64 (-.f64 (*.f64 (*.f64 (neg.f64 y) z) z) x)) |
(fma.f64 (*.f64 y (fabs.f64 z)) (fabs.f64 z) x) |
(fma.f64 (*.f64 (neg.f64 y) z) (neg.f64 z) x) |
(fma.f64 (fabs.f64 z) (*.f64 (fabs.f64 z) y) x) |
(fma.f64 (neg.f64 z) (*.f64 (neg.f64 y) z) x) |
(fma.f64 (*.f64 z z) y x) |
(fma.f64 (*.f64 z y) z x) |
(fma.f64 z (*.f64 z y) x) |
(fma.f64 y (*.f64 z z) x) |
(-.f64 (*.f64 (*.f64 z z) y) (neg.f64 x)) |
(-.f64 x (*.f64 (*.f64 (neg.f64 y) z) z)) |
(+.f64 (*.f64 (*.f64 z z) y) x) |
(+.f64 x (*.f64 (neg.f64 (*.f64 (neg.f64 y) z)) z)) |
(+.f64 x (*.f64 (neg.f64 (neg.f64 y)) (*.f64 z z))) |
(+.f64 x (neg.f64 (*.f64 (*.f64 (neg.f64 y) z) z))) |
(+.f64 x (*.f64 (*.f64 z z) y)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (*.f64 z y) z x)) |
#s(approx x x) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (/.f64 (*.f64 (*.f64 z z) y) x) x x)) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (/.f64 (*.f64 (*.f64 z z) y) x) x x)) |
#s(approx y y) |
#s(approx (* z y) (*.f64 z y)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (fma.f64 z z (/.f64 x y)) y)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (fma.f64 z z (/.f64 x y)) y)) |
#s(approx (* z z) (*.f64 z z)) |
#s(approx z z) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 (+.f64 (/.f64 x (*.f64 z z)) y) z) z)) |
Compiled 414 to 210 computations (49.3% saved)
4 alts after pruning (1 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 89 | 1 | 90 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 3 | 3 |
| Done | 0 | 0 | 0 |
| Total | 89 | 4 | 93 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 92.0% | (fma.f64 (*.f64 z z) y x) |
| ✓ | 99.9% | (fma.f64 (*.f64 z y) z x) |
| ✓ | 44.6% | #s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
| ▶ | 51.0% | #s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z y) z)) |
Compiled 28 to 28 computations (0% saved)
| Inputs |
|---|
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z y) z)) |
(*.f64 (*.f64 z y) z) |
(*.f64 z y) |
z |
y |
| Outputs |
|---|
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (pow z 2)))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (+ x (* y (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 x)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* x (+ 1 (/ (* y (pow z 2)) x))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* x (- (* -1 (/ (* y (pow z 2)) x)) 1))))) |
#s(approx (* z y) #s(hole binary64 (* y z))) |
#s(approx y #s(hole binary64 y)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (+ (/ x y) (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* y (+ (* -1 (/ x y)) (* -1 (pow z 2))))))) |
#s(approx z #s(hole binary64 z)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* (pow z 2) (+ y (/ x (pow z 2)))))) |
9 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 4.0ms | z | @ | -inf | ((+ x (* (* y z) z)) (* (* z y) z) (* z y) z y) |
| 1.0ms | y | @ | -inf | ((+ x (* (* y z) z)) (* (* z y) z) (* z y) z y) |
| 1.0ms | y | @ | inf | ((+ x (* (* y z) z)) (* (* z y) z) (* z y) z y) |
| 1.0ms | z | @ | inf | ((+ x (* (* y z) z)) (* (* z y) z) (* z y) z y) |
| 0.0ms | y | @ | 0 | ((+ x (* (* y z) z)) (* (* z y) z) (* z y) z y) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 45 | 174 |
| 0 | 47 | 164 |
| 1 | 246 | 164 |
| 0 | 1960 | 149 |
| 1 | 5916 | 149 |
| 1× | saturated |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z y) z)) |
(*.f64 (*.f64 z y) z) |
(*.f64 z y) |
z |
y |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (pow z 2)))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (+ x (* y (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 x)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* x (+ 1 (/ (* y (pow z 2)) x))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* x (- (* -1 (/ (* y (pow z 2)) x)) 1))))) |
#s(approx (* z y) #s(hole binary64 (* y z))) |
#s(approx y #s(hole binary64 y)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (+ (/ x y) (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* y (+ (* -1 (/ x y)) (* -1 (pow z 2))))))) |
#s(approx z #s(hole binary64 z)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* (pow z 2) (+ y (/ x (pow z 2)))))) |
| Outputs |
|---|
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
(*.f64 (*.f64 z z) y) |
(*.f64 (*.f64 z y) z) |
(*.f64 z (*.f64 z y)) |
(*.f64 y (*.f64 z z)) |
(*.f64 z y) |
(*.f64 y z) |
z |
y |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (*.f64 z y) z x)) |
#s(approx (+ x (* (* y z) z)) x) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (/.f64 (*.f64 (*.f64 z z) y) x) x x)) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (/.f64 (*.f64 (*.f64 z z) y) x) x x)) |
#s(approx (* z y) (*.f64 z y)) |
#s(approx y y) |
#s(approx (+ x (* (* y z) z)) (*.f64 (fma.f64 z z (/.f64 x y)) y)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (fma.f64 z z (/.f64 x y)) y)) |
#s(approx z z) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 (+.f64 (/.f64 x (*.f64 z z)) y) z) z)) |
Compiled 63 to 43 computations (31.7% saved)
5 alts after pruning (1 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 10 | 1 | 11 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 3 | 3 |
| Total | 10 | 5 | 15 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 92.0% | (fma.f64 (*.f64 z z) y x) |
| ✓ | 99.9% | (fma.f64 (*.f64 z y) z x) |
| ✓ | 44.6% | #s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
| ✓ | 51.0% | #s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z y) z)) |
| ▶ | 51.1% | #s(approx (+ x (* (* y z) z)) x) |
Compiled 35 to 35 computations (0% saved)
| Inputs |
|---|
#s(approx (+ x (* (* y z) z)) x) |
x |
| Outputs |
|---|
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (pow z 2)))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (+ x (* y (pow z 2))))) |
#s(approx x #s(hole binary64 x)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* x (+ 1 (/ (* y (pow z 2)) x))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* x (- (* -1 (/ (* y (pow z 2)) x)) 1))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (+ (/ x y) (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* y (+ (* -1 (/ x y)) (* -1 (pow z 2))))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* (pow z 2) (+ y (/ x (pow z 2)))))) |
9 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 0.0ms | x | @ | -inf | ((+ x (* (* y z) z)) x) |
| 0.0ms | x | @ | inf | ((+ x (* (* y z) z)) x) |
| 0.0ms | y | @ | -inf | ((+ x (* (* y z) z)) x) |
| 0.0ms | x | @ | 0 | ((+ x (* (* y z) z)) x) |
| 0.0ms | z | @ | -inf | ((+ x (* (* y z) z)) x) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 39 | 142 |
| 0 | 39 | 132 |
| 1 | 237 | 132 |
| 0 | 1952 | 118 |
| 1 | 5910 | 118 |
| 1× | saturated |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | saturated |
| Inputs |
|---|
#s(approx (+ x (* (* y z) z)) x) |
x |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (pow z 2)))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (+ x (* y (pow z 2))))) |
#s(approx x #s(hole binary64 x)) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* x (+ 1 (/ (* y (pow z 2)) x))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* x (- (* -1 (/ (* y (pow z 2)) x)) 1))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* y (+ (/ x y) (pow z 2))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* -1 (* y (+ (* -1 (/ x y)) (* -1 (pow z 2))))))) |
#s(approx (+ x (* (* y z) z)) #s(hole binary64 (* (pow z 2) (+ y (/ x (pow z 2)))))) |
| Outputs |
|---|
#s(approx (+ x (* (* y z) z)) x) |
x |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (*.f64 z y) z x)) |
#s(approx x x) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (/.f64 (*.f64 (*.f64 z z) y) x) x x)) |
#s(approx (+ x (* (* y z) z)) (fma.f64 (/.f64 (*.f64 (*.f64 z z) y) x) x x)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (fma.f64 z z (/.f64 x y)) y)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (fma.f64 z z (/.f64 x y)) y)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 (+.f64 (/.f64 x (*.f64 z z)) y) z) z)) |
Compiled 38 to 25 computations (34.2% saved)
5 alts after pruning (0 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 5 | 0 | 5 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 4 | 4 |
| Total | 5 | 5 | 10 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 92.0% | (fma.f64 (*.f64 z z) y x) |
| ✓ | 99.9% | (fma.f64 (*.f64 z y) z x) |
| ✓ | 44.6% | #s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
| ✓ | 51.0% | #s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z y) z)) |
| ✓ | 51.1% | #s(approx (+ x (* (* y z) z)) x) |
Compiled 58 to 53 computations (8.6% saved)
| Inputs |
|---|
#s(approx (+ x (* (* y z) z)) x) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z y) z)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
(fma.f64 (*.f64 z y) z x) |
(fma.f64 (*.f64 z z) y x) |
(+.f64 x (*.f64 (*.f64 y z) z)) |
| Outputs |
|---|
(fma.f64 (*.f64 z y) z x) |
5 calls:
| 4.0ms | x |
| 2.0ms | z |
| 2.0ms | y |
| 2.0ms | (+.f64 x (*.f64 (*.f64 y z) z)) |
| 2.0ms | (*.f64 (*.f64 y z) z) |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.9% | 1 | (*.f64 (*.f64 y z) z) |
| 99.9% | 1 | (+.f64 x (*.f64 (*.f64 y z) z)) |
| 99.9% | 1 | x |
| 99.9% | 1 | y |
| 99.9% | 1 | z |
Compiled 13 to 20 computations (-53.8% saved)
| Inputs |
|---|
#s(approx (+ x (* (* y z) z)) x) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z y) z)) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z z) y)) |
| Outputs |
|---|
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z y) z)) |
#s(approx (+ x (* (* y z) z)) x) |
#s(approx (+ x (* (* y z) z)) (*.f64 (*.f64 z y) z)) |
5 calls:
| 3.0ms | (+.f64 x (*.f64 (*.f64 y z) z)) |
| 2.0ms | x |
| 1.0ms | z |
| 1.0ms | y |
| 1.0ms | (*.f64 (*.f64 y z) z) |
| Accuracy | Segments | Branch |
|---|---|---|
| 89.4% | 3 | (*.f64 (*.f64 y z) z) |
| 75.4% | 3 | (+.f64 x (*.f64 (*.f64 y z) z)) |
| 66.0% | 3 | x |
| 65.3% | 3 | y |
| 83.7% | 2 | z |
Compiled 13 to 20 computations (-53.8% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
#s(approx (+ x (* (* y z) z)) x) |
| Outputs |
|---|
#s(approx (+ x (* (* y z) z)) x) |
5 calls:
| 1.0ms | z |
| 1.0ms | x |
| 1.0ms | y |
| 1.0ms | (+.f64 x (*.f64 (*.f64 y z) z)) |
| 1.0ms | (*.f64 (*.f64 y z) z) |
| Accuracy | Segments | Branch |
|---|---|---|
| 51.1% | 1 | y |
| 51.1% | 1 | x |
| 51.1% | 1 | (+.f64 x (*.f64 (*.f64 y z) z)) |
| 51.1% | 1 | z |
| 51.1% | 1 | (*.f64 (*.f64 y z) z) |
Compiled 13 to 20 computations (-53.8% saved)
| 2× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 1.2665520892447413e-60 | 1.7813851505968383e-47 |
| 0.0ms | -6.401408267787907e-112 | -1.467001159730059e-116 |
Compiled 9 to 12 computations (-33.3% saved)
| 1× | done |
Compiled 23 to 19 computations (17.4% saved)
(abs z)
Compiled 95 to 85 computations (10.5% saved)
Loading profile data...