
Time bar (total: 1.6s)
| 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 10 to 8 computations (20% saved)
| 632.0ms | 8 256× | 0 | valid |
ival-mult!: 399.0ms (90.5% of total)ival-neg: 40.0ms (9.1% of total)adjust: 2.0ms (0.5% of total)Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 21 | 46 |
| 1 | 69 | 34 |
| 2 | 258 | 34 |
| 1× | node-limit |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 83.1% | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
(abs a)
(abs b)
(sort a b)
Compiled 16 to 12 computations (25% saved)
| Inputs |
|---|
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
(*.f64 (*.f64 (*.f64 a a) b) b) |
(*.f64 (*.f64 a a) b) |
(*.f64 a a) |
a |
b |
| Outputs |
|---|
#s(approx (neg (* (* (* a a) b) b)) (*.f64 #s(literal -1 binary64) (*.f64 (pow.f64 a #s(literal 2 binary64)) (pow.f64 b #s(literal 2 binary64))))) |
#s(approx (* (* (* a a) b) b) (*.f64 (pow.f64 a #s(literal 2 binary64)) (pow.f64 b #s(literal 2 binary64)))) |
#s(approx (* (* a a) b) (*.f64 (pow.f64 a #s(literal 2 binary64)) b)) |
#s(approx (* a a) (pow.f64 a #s(literal 2 binary64))) |
#s(approx a a) |
#s(approx b b) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 2.0ms | b | -inf |
| 2.0ms | a | inf |
| 1.0ms | a | 0 |
| 1.0ms | a | -inf |
| 1.0ms | b | inf |
| Inputs |
|---|
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
(*.f64 (*.f64 (*.f64 a a) b) b) |
(*.f64 (*.f64 a a) b) |
(*.f64 a a) |
a |
b |
| Outputs |
|---|
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b)) |
(*.f64 (neg.f64 (*.f64 (*.f64 a a) b)) b) |
(neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 (*.f64 (*.f64 a a) b) b) |
(*.f64 b (*.f64 (*.f64 a a) b)) |
(*.f64 (*.f64 a a) b) |
(*.f64 a (*.f64 a b)) |
(*.f64 b (*.f64 a a)) |
(*.f64 a a) |
(*.f64 (fabs.f64 a) (fabs.f64 a)) |
(*.f64 (neg.f64 a) (neg.f64 a)) |
(pow.f64 a #s(literal 2 binary64)) |
a |
b |
Compiled 168 to 62 computations (63.1% saved)
2 alts after pruning (2 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 14 | 2 | 16 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 15 | 2 | 17 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 95.0% | (neg.f64 (*.f64 (*.f64 a (*.f64 a b)) b)) |
| ▶ | 77.4% | (neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
Compiled 16 to 12 computations (25% saved)
| Inputs |
|---|
(neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 a a) |
a |
(*.f64 b b) |
b |
(neg.f64 (*.f64 (*.f64 a (*.f64 a b)) b)) |
(*.f64 (*.f64 a (*.f64 a b)) b) |
(*.f64 a (*.f64 a b)) |
(*.f64 a b) |
| Outputs |
|---|
#s(approx (neg (* (* a a) (* b b))) (*.f64 #s(literal -1 binary64) (*.f64 (pow.f64 a #s(literal 2 binary64)) (pow.f64 b #s(literal 2 binary64))))) |
#s(approx (* (* a a) (* b b)) (*.f64 (pow.f64 a #s(literal 2 binary64)) (pow.f64 b #s(literal 2 binary64)))) |
#s(approx (* a a) (pow.f64 a #s(literal 2 binary64))) |
#s(approx a a) |
#s(approx (* a (* a b)) (*.f64 (pow.f64 a #s(literal 2 binary64)) b)) |
#s(approx (* a b) (*.f64 a b)) |
#s(approx (* b b) (pow.f64 b #s(literal 2 binary64))) |
#s(approx b b) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 20.0ms | a | -inf |
| 2.0ms | b | -inf |
| 1.0ms | a | inf |
| 1.0ms | b | inf |
| 1.0ms | a | 0 |
| Inputs |
|---|
(neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 a a) |
a |
(*.f64 b b) |
b |
(neg.f64 (*.f64 (*.f64 a (*.f64 a b)) b)) |
(*.f64 (*.f64 a (*.f64 a b)) b) |
(*.f64 a (*.f64 a b)) |
(*.f64 a b) |
| Outputs |
|---|
(*.f64 (*.f64 a (*.f64 a b)) (neg.f64 b)) |
(*.f64 (neg.f64 (*.f64 a a)) (*.f64 b b)) |
(*.f64 (*.f64 a a) (neg.f64 (*.f64 b b))) |
(*.f64 (neg.f64 (*.f64 a (*.f64 a b))) b) |
(neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 (*.f64 a b) (*.f64 a b)) |
(*.f64 (*.f64 b b) (*.f64 a a)) |
(*.f64 (*.f64 a (*.f64 a b)) b) |
(*.f64 b (*.f64 a (*.f64 a b))) |
(*.f64 a (*.f64 (*.f64 a b) b)) |
(*.f64 a (*.f64 a (*.f64 b b))) |
(*.f64 a a) |
(*.f64 (fabs.f64 a) (fabs.f64 a)) |
(*.f64 (neg.f64 a) (neg.f64 a)) |
(pow.f64 a #s(literal 2 binary64)) |
a |
(*.f64 b b) |
(*.f64 (fabs.f64 b) (fabs.f64 b)) |
(*.f64 (neg.f64 b) (neg.f64 b)) |
(pow.f64 b #s(literal 2 binary64)) |
b |
(*.f64 (*.f64 a (*.f64 a b)) (neg.f64 b)) |
(*.f64 (neg.f64 (*.f64 a a)) (*.f64 b b)) |
(*.f64 (*.f64 a a) (neg.f64 (*.f64 b b))) |
(*.f64 (neg.f64 (*.f64 a (*.f64 a b))) b) |
(neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 (*.f64 a b) (*.f64 a b)) |
(*.f64 (*.f64 b b) (*.f64 a a)) |
(*.f64 (*.f64 a (*.f64 a b)) b) |
(*.f64 b (*.f64 a (*.f64 a b))) |
(*.f64 a (*.f64 (*.f64 a b) b)) |
(*.f64 a (*.f64 a (*.f64 b b))) |
(*.f64 a (*.f64 a b)) |
(*.f64 (*.f64 a a) b) |
(*.f64 (*.f64 a b) a) |
(*.f64 a b) |
(*.f64 b a) |
Compiled 284 to 100 computations (64.8% saved)
5 alts after pruning (3 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 25 | 3 | 28 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 0 | 0 |
| Total | 25 | 5 | 30 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 95.0% | (neg.f64 (*.f64 (*.f64 a (*.f64 a b)) b)) |
| ▶ | 99.6% | (neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
| ✓ | 77.4% | (neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
| ▶ | 93.5% | (neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
| ▶ | 84.1% | (neg.f64 (*.f64 a (*.f64 a (*.f64 b b)))) |
Compiled 40 to 29 computations (27.5% saved)
| Inputs |
|---|
(neg.f64 (*.f64 a (*.f64 a (*.f64 b b)))) |
(*.f64 a (*.f64 a (*.f64 b b))) |
a |
(*.f64 a (*.f64 b b)) |
(*.f64 b b) |
b |
(neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
(*.f64 a (*.f64 (*.f64 a b) b)) |
(*.f64 (*.f64 a b) b) |
(*.f64 a b) |
(neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
(*.f64 (*.f64 a b) (*.f64 a b)) |
| Outputs |
|---|
#s(approx (neg (* a (* a (* b b)))) (*.f64 #s(literal -1 binary64) (*.f64 (pow.f64 a #s(literal 2 binary64)) (pow.f64 b #s(literal 2 binary64))))) |
#s(approx (* a (* a (* b b))) (*.f64 (pow.f64 a #s(literal 2 binary64)) (pow.f64 b #s(literal 2 binary64)))) |
#s(approx a a) |
#s(approx (* a (* b b)) (*.f64 a (pow.f64 b #s(literal 2 binary64)))) |
#s(approx (* a b) (*.f64 a b)) |
#s(approx (* b b) (pow.f64 b #s(literal 2 binary64))) |
#s(approx b b) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 2.0ms | a | -inf |
| 2.0ms | b | -inf |
| 1.0ms | b | inf |
| 1.0ms | a | inf |
| 1.0ms | a | 0 |
| Inputs |
|---|
(neg.f64 (*.f64 a (*.f64 a (*.f64 b b)))) |
(*.f64 a (*.f64 a (*.f64 b b))) |
a |
(*.f64 a (*.f64 b b)) |
(*.f64 b b) |
b |
(neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
(*.f64 a (*.f64 (*.f64 a b) b)) |
(*.f64 (*.f64 a b) b) |
(*.f64 a b) |
(neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
(*.f64 (*.f64 a b) (*.f64 a b)) |
| Outputs |
|---|
(*.f64 (neg.f64 (*.f64 a b)) (*.f64 a b)) |
(*.f64 (neg.f64 a) (*.f64 a (*.f64 b b))) |
(*.f64 (*.f64 a b) (neg.f64 (*.f64 a b))) |
(*.f64 a (neg.f64 (*.f64 a (*.f64 b b)))) |
(neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
(*.f64 (*.f64 a b) (*.f64 a b)) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 (*.f64 a (*.f64 b b)) a) |
(*.f64 (*.f64 (*.f64 a b) a) b) |
(*.f64 (*.f64 a (*.f64 a b)) b) |
(*.f64 (fabs.f64 (*.f64 a b)) (fabs.f64 (*.f64 a b))) |
(*.f64 (neg.f64 (*.f64 a b)) (neg.f64 (*.f64 a b))) |
(*.f64 a (*.f64 a (*.f64 b b))) |
(pow.f64 (*.f64 a b) #s(literal 2 binary64)) |
a |
(*.f64 a (*.f64 b b)) |
(*.f64 (*.f64 a b) b) |
(*.f64 (*.f64 b b) a) |
(*.f64 b (*.f64 a b)) |
(*.f64 b b) |
(*.f64 (fabs.f64 b) (fabs.f64 b)) |
(*.f64 (neg.f64 b) (neg.f64 b)) |
(pow.f64 b #s(literal 2 binary64)) |
b |
(*.f64 (neg.f64 (*.f64 a b)) (*.f64 a b)) |
(*.f64 (neg.f64 a) (*.f64 a (*.f64 b b))) |
(*.f64 (*.f64 a b) (neg.f64 (*.f64 a b))) |
(*.f64 a (neg.f64 (*.f64 a (*.f64 b b)))) |
(neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
(*.f64 (*.f64 a b) (*.f64 a b)) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 (*.f64 a (*.f64 b b)) a) |
(*.f64 (*.f64 (*.f64 a b) a) b) |
(*.f64 (*.f64 a (*.f64 a b)) b) |
(*.f64 (fabs.f64 (*.f64 a b)) (fabs.f64 (*.f64 a b))) |
(*.f64 (neg.f64 (*.f64 a b)) (neg.f64 (*.f64 a b))) |
(*.f64 a (*.f64 a (*.f64 b b))) |
(pow.f64 (*.f64 a b) #s(literal 2 binary64)) |
(*.f64 a (*.f64 b b)) |
(*.f64 (*.f64 a b) b) |
(*.f64 (*.f64 b b) a) |
(*.f64 b (*.f64 a b)) |
(*.f64 a b) |
(*.f64 b a) |
(*.f64 (neg.f64 (*.f64 a b)) (*.f64 a b)) |
(*.f64 (neg.f64 a) (*.f64 a (*.f64 b b))) |
(*.f64 (*.f64 a b) (neg.f64 (*.f64 a b))) |
(*.f64 a (neg.f64 (*.f64 a (*.f64 b b)))) |
(neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
(*.f64 (*.f64 a b) (*.f64 a b)) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 (*.f64 a (*.f64 b b)) a) |
(*.f64 (*.f64 (*.f64 a b) a) b) |
(*.f64 (*.f64 a (*.f64 a b)) b) |
(*.f64 (fabs.f64 (*.f64 a b)) (fabs.f64 (*.f64 a b))) |
(*.f64 (neg.f64 (*.f64 a b)) (neg.f64 (*.f64 a b))) |
(*.f64 a (*.f64 a (*.f64 b b))) |
(pow.f64 (*.f64 a b) #s(literal 2 binary64)) |
Compiled 294 to 97 computations (67% saved)
5 alts after pruning (0 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 28 | 0 | 28 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 3 | 3 |
| Done | 0 | 2 | 2 |
| Total | 28 | 5 | 33 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 95.0% | (neg.f64 (*.f64 (*.f64 a (*.f64 a b)) b)) |
| ✓ | 99.6% | (neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
| ✓ | 77.4% | (neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
| ✓ | 93.5% | (neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
| ✓ | 84.1% | (neg.f64 (*.f64 a (*.f64 a (*.f64 b b)))) |
Compiled 40 to 29 computations (27.5% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
(neg.f64 (*.f64 a (*.f64 a (*.f64 b b)))) |
| Outputs |
|---|
(neg.f64 (*.f64 a (*.f64 a (*.f64 b b)))) |
| Inputs |
|---|
(neg.f64 (*.f64 a (*.f64 a (*.f64 b b)))) |
(neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
(neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
| Outputs |
|---|
(neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
| Inputs |
|---|
(neg.f64 (*.f64 a (*.f64 a (*.f64 b b)))) |
(neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
(neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
(neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
(neg.f64 (*.f64 (*.f64 a (*.f64 a b)) b)) |
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| Outputs |
|---|
(neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
15 calls:
| 11.0ms | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| 2.0ms | a |
| 2.0ms | b |
| 2.0ms | (*.f64 a a) |
| 2.0ms | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 84.1% | 1 | (*.f64 a a) |
| 84.1% | 1 | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| 84.1% | 1 | a |
| 84.1% | 1 | b |
| 84.1% | 1 | (*.f64 (*.f64 (*.f64 a a) b) b) |
| 93.5% | 1 | (*.f64 a a) |
| 93.5% | 1 | (*.f64 (*.f64 (*.f64 a a) b) b) |
| 93.5% | 1 | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| 93.5% | 1 | a |
| 93.5% | 1 | b |
| 99.6% | 1 | (*.f64 a a) |
| 99.6% | 1 | (*.f64 (*.f64 (*.f64 a a) b) b) |
| 99.6% | 1 | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| 99.6% | 1 | a |
| 99.6% | 1 | b |
Compiled 108 to 75 computations (30.6% saved)
| 1× | done |
Compiled 24 to 12 computations (50% saved)
(abs b)
Compiled 240 to 168 computations (30% saved)
Loading profile data...