
Time bar (total: 1.7s)
| 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)
| 693.0ms | 8 256× | 0 | valid |
ival-mult!: 141.0ms (70.4% of total)ival-neg: 58.0ms (28.9% of total)adjust: 1.0ms (0.5% of total)Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 21 | 46 |
| 1 | 69 | 34 |
| 2 | 258 | 34 |
| 3 | 569 | 34 |
| 4 | 1139 | 34 |
| 5 | 4730 | 34 |
| 6 | 7252 | 34 |
| 1× | node-limit |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 79.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 |
|---|---|---|
| 14.0ms | b | inf |
| 3.0ms | b | -inf |
| 2.0ms | a | inf |
| 1.0ms | a | 0 |
| 1.0ms | a | -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)
3 alts after pruning (2 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 14 | 2 | 16 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 14 | 3 | 17 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 79.1% | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| ▶ | 93.8% | (neg.f64 (*.f64 (*.f64 a (*.f64 a b)) b)) |
| ▶ | 72.2% | (neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
Compiled 24 to 18 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 |
|---|---|---|
| 2.0ms | b | -inf |
| 1.0ms | a | -inf |
| 1.0ms | b | inf |
| 1.0ms | a | 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 276 to 97 computations (64.9% saved)
5 alts after pruning (2 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 25 | 2 | 27 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 1 | 1 |
| Total | 25 | 5 | 30 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 79.1% | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| ✓ | 93.8% | (neg.f64 (*.f64 (*.f64 a (*.f64 a b)) b)) |
| ▶ | 99.7% | (neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
| ✓ | 72.2% | (neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
| ▶ | 93.5% | (neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
Compiled 40 to 29 computations (27.5% saved)
| Inputs |
|---|
(neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
(*.f64 a (*.f64 (*.f64 a b) b)) |
a |
(*.f64 (*.f64 a b) b) |
(*.f64 a b) |
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) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 1.0ms | a | -inf |
| 1.0ms | b | -inf |
| 1.0ms | b | inf |
| 1.0ms | a | inf |
| 1.0ms | a | 0 |
| Inputs |
|---|
(neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
(*.f64 a (*.f64 (*.f64 a b) b)) |
a |
(*.f64 (*.f64 a b) b) |
(*.f64 a b) |
b |
(neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
(*.f64 (*.f64 a b) (*.f64 a b)) |
| Outputs |
|---|
(*.f64 (neg.f64 (*.f64 b a)) (*.f64 b a)) |
(*.f64 (neg.f64 a) (*.f64 (*.f64 b a) b)) |
(*.f64 (*.f64 b a) (neg.f64 (*.f64 b a))) |
(*.f64 a (neg.f64 (*.f64 (*.f64 b a) b))) |
(neg.f64 (*.f64 (*.f64 b a) (*.f64 b a))) |
(*.f64 (*.f64 b a) (*.f64 b a)) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 (*.f64 (*.f64 b a) b) a) |
(*.f64 (*.f64 (*.f64 b a) a) b) |
(*.f64 (*.f64 a (*.f64 b a)) b) |
(*.f64 (fabs.f64 (*.f64 b a)) (fabs.f64 (*.f64 b a))) |
(*.f64 (neg.f64 (*.f64 b a)) (neg.f64 (*.f64 b a))) |
(*.f64 a (*.f64 (*.f64 b a) b)) |
(pow.f64 (*.f64 b a) #s(literal 2 binary64)) |
a |
(*.f64 (*.f64 b a) b) |
(*.f64 b (*.f64 b a)) |
(*.f64 a (*.f64 b b)) |
(*.f64 b a) |
(*.f64 a b) |
b |
(*.f64 (neg.f64 (*.f64 b a)) (*.f64 b a)) |
(*.f64 (neg.f64 a) (*.f64 (*.f64 b a) b)) |
(*.f64 (*.f64 b a) (neg.f64 (*.f64 b a))) |
(*.f64 a (neg.f64 (*.f64 (*.f64 b a) b))) |
(neg.f64 (*.f64 (*.f64 b a) (*.f64 b a))) |
(*.f64 (*.f64 b a) (*.f64 b a)) |
(*.f64 (*.f64 a a) (*.f64 b b)) |
(*.f64 (*.f64 (*.f64 b a) b) a) |
(*.f64 (*.f64 (*.f64 b a) a) b) |
(*.f64 (*.f64 a (*.f64 b a)) b) |
(*.f64 (fabs.f64 (*.f64 b a)) (fabs.f64 (*.f64 b a))) |
(*.f64 (neg.f64 (*.f64 b a)) (neg.f64 (*.f64 b a))) |
(*.f64 a (*.f64 (*.f64 b a) b)) |
(pow.f64 (*.f64 b a) #s(literal 2 binary64)) |
Compiled 270 to 75 computations (72.2% saved)
5 alts after pruning (0 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 27 | 0 | 27 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 3 | 3 |
| Total | 27 | 5 | 32 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 79.1% | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| ✓ | 93.8% | (neg.f64 (*.f64 (*.f64 a (*.f64 a b)) b)) |
| ✓ | 99.7% | (neg.f64 (*.f64 (*.f64 a b) (*.f64 a b))) |
| ✓ | 72.2% | (neg.f64 (*.f64 (*.f64 a a) (*.f64 b b))) |
| ✓ | 93.5% | (neg.f64 (*.f64 a (*.f64 (*.f64 a b) b))) |
Compiled 40 to 29 computations (27.5% saved)
Total -13.7b remaining (-313.5%)
Threshold costs -13.7b (-313.5%)
| Inputs |
|---|
(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 (*.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))) |
10 calls:
| 2.0ms | a |
| 2.0ms | b |
| 2.0ms | (*.f64 a a) |
| 1.0ms | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| 1.0ms | (*.f64 (*.f64 (*.f64 a a) b) b) |
| Accuracy | Segments | Branch |
|---|---|---|
| 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.7% | 1 | (*.f64 a a) |
| 99.7% | 1 | (*.f64 (*.f64 (*.f64 a a) b) b) |
| 99.7% | 1 | (neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b)) |
| 99.7% | 1 | a |
| 99.7% | 1 | b |
Compiled 80 to 54 computations (32.5% saved)
| 1× | done |
Compiled 16 to 8 computations (50% saved)
(abs b)
(abs a)
Compiled 136 to 92 computations (32.4% saved)
Loading profile data...