
Time bar (total: 1.7s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 0% | 100% | 0% | 0% | 0% | 0 |
| 0% | 0% | 0% | 100% | 0% | 0% | 0% | 1 |
| 0% | 0% | 0% | 100% | 0% | 0% | 0% | 2 |
| 50% | 0% | 0% | 100% | 0% | 0% | 0% | 3 |
| 50% | 0% | 0% | 100% | 0% | 0% | 0% | 4 |
| 75% | 0% | 0% | 100% | 0% | 0% | 0% | 5 |
| 75% | 0% | 0% | 100% | 0% | 0% | 0% | 6 |
| 87.5% | 0% | 0% | 100% | 0% | 0% | 0% | 7 |
| 87.5% | 0% | 0% | 100% | 0% | 0% | 0% | 8 |
| 93.8% | 0% | 0% | 100% | 0% | 0% | 0% | 9 |
| 93.8% | 0% | 0% | 100% | 0% | 0% | 0% | 10 |
| 96.9% | 0% | 0% | 100% | 0% | 0% | 0% | 11 |
| 96.9% | 0% | 0% | 100% | 0% | 0% | 0% | 12 |
Compiled 23 to 16 computations (30.4% saved)
| 821.0ms | 8 256× | 0 | valid |
ival-add!: 43.0ms (52.7% of total)ival-mult!: 36.0ms (44.2% of total)ival-and: 1.0ms (1.2% of total)adjust: 1.0ms (1.2% of total)ival-<=: 1.0ms (1.2% of total)ival-assert: 0.0ms (0% of total)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 14 | 36 |
| 1 | 69 | 36 |
| 2 | 223 | 36 |
| 3 | 827 | 36 |
| 4 | 1637 | 36 |
| 5 | 6877 | 36 |
| 1× | node-limit |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 (+.f64 a b) (+.f64 a b)) |
(sort a b)
Compiled 14 to 8 computations (42.9% saved)
| Inputs |
|---|
(*.f64 (+.f64 a b) (+.f64 a b)) |
(+.f64 a b) |
a |
b |
| Outputs |
|---|
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (pow b 2))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* 2 (* a b)) (pow b 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* a (+ a (* 2 b))) (pow b 2)))) |
#s(approx (+ a b) #s(hole binary64 b)) |
#s(approx (+ a b) #s(hole binary64 (+ a b))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (pow a 2))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (* 2 (/ b a)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (+ (* 2 (/ b a)) (/ (pow b 2) (pow a 2))))))) |
#s(approx (+ a b) #s(hole binary64 (* a (+ 1 (/ b a))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (* -1 (/ (+ (* -2 b) (* -1 (/ (pow b 2) a))) a)))))) |
#s(approx (+ a b) #s(hole binary64 (* -1 (* a (- (* -1 (/ b a)) 1))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* 2 (* a b)) (pow a 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* b (+ b (* 2 a))) (pow a 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (* 2 (/ a b)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (+ (* 2 (/ a b)) (/ (pow a 2) (pow b 2))))))) |
#s(approx (+ a b) #s(hole binary64 (* b (+ 1 (/ a b))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (* -1 (/ (+ (* -2 a) (* -1 (/ (pow a 2) b))) b)))))) |
#s(approx (+ a b) #s(hole binary64 (* -1 (* b (- (* -1 (/ a b)) 1))))) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 1.0ms | a | inf |
| 1.0ms | a | -inf |
| 0.0ms | b | -inf |
| 0.0ms | b | inf |
| 0.0ms | b | 0 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 87 | 323 |
| 0 | 89 | 287 |
| 1 | 496 | 277 |
| 0 | 4872 | 263 |
| 1× | iter-limit |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
(*.f64 (+.f64 a b) (+.f64 a b)) |
(+.f64 a b) |
a |
b |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (pow b 2))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* 2 (* a b)) (pow b 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* a (+ a (* 2 b))) (pow b 2)))) |
#s(approx (+ a b) #s(hole binary64 b)) |
#s(approx (+ a b) #s(hole binary64 (+ a b))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (pow a 2))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (* 2 (/ b a)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (+ (* 2 (/ b a)) (/ (pow b 2) (pow a 2))))))) |
#s(approx (+ a b) #s(hole binary64 (* a (+ 1 (/ b a))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (* -1 (/ (+ (* -2 b) (* -1 (/ (pow b 2) a))) a)))))) |
#s(approx (+ a b) #s(hole binary64 (* -1 (* a (- (* -1 (/ b a)) 1))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* 2 (* a b)) (pow a 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* b (+ b (* 2 a))) (pow a 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (* 2 (/ a b)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (+ (* 2 (/ a b)) (/ (pow a 2) (pow b 2))))))) |
#s(approx (+ a b) #s(hole binary64 (* b (+ 1 (/ a b))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (* -1 (/ (+ (* -2 a) (* -1 (/ (pow a 2) b))) b)))))) |
#s(approx (+ a b) #s(hole binary64 (* -1 (* b (- (* -1 (/ a b)) 1))))) |
| Outputs |
|---|
(*.f64 (fabs.f64 (fabs.f64 (+.f64 b a))) (fabs.f64 (fabs.f64 (+.f64 b a)))) |
(*.f64 (neg.f64 (fabs.f64 (+.f64 b a))) (neg.f64 (fabs.f64 (+.f64 b a)))) |
(*.f64 (neg.f64 (neg.f64 (+.f64 b a))) (neg.f64 (neg.f64 (+.f64 b a)))) |
(*.f64 (pow.f64 (+.f64 b a) #s(literal 1 binary64)) (pow.f64 (+.f64 b a) #s(literal 1 binary64))) |
(*.f64 (pow.f64 (+.f64 b a) #s(literal 1 binary64)) (+.f64 b a)) |
(*.f64 (fabs.f64 (+.f64 b a)) (fabs.f64 (+.f64 b a))) |
(*.f64 (neg.f64 (+.f64 b a)) (neg.f64 (+.f64 b a))) |
(*.f64 (+.f64 b a) (+.f64 b a)) |
(pow.f64 (fabs.f64 (+.f64 b a)) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 (+.f64 b a)) #s(literal 2 binary64)) |
(pow.f64 (+.f64 b a) #s(literal 2 binary64)) |
(/.f64 (*.f64 (+.f64 b a) (*.f64 (+.f64 b a) (-.f64 a b))) (-.f64 a b)) |
(/.f64 (*.f64 (+.f64 b a) (fma.f64 (*.f64 a a) a (*.f64 (*.f64 b b) b))) (fma.f64 b (-.f64 b a) (*.f64 a a))) |
(/.f64 (*.f64 (*.f64 (+.f64 b a) (-.f64 a b)) (+.f64 b a)) (-.f64 a b)) |
(/.f64 (*.f64 (fma.f64 (*.f64 a a) a (*.f64 (*.f64 b b) b)) (+.f64 b a)) (fma.f64 b (-.f64 b a) (*.f64 a a))) |
(/.f64 (-.f64 (*.f64 (*.f64 (+.f64 b a) a) (*.f64 (+.f64 b a) a)) (*.f64 (*.f64 (+.f64 b a) b) (*.f64 (+.f64 b a) b))) (-.f64 (*.f64 (+.f64 b a) a) (*.f64 (+.f64 b a) b))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (+.f64 b a) a) #s(literal 3 binary64)) (pow.f64 (*.f64 (+.f64 b a) b) #s(literal 3 binary64))) (fma.f64 (*.f64 (+.f64 b a) a) (*.f64 (+.f64 b a) a) (-.f64 (*.f64 (*.f64 (+.f64 b a) b) (*.f64 (+.f64 b a) b)) (*.f64 (*.f64 (+.f64 b a) a) (*.f64 (+.f64 b a) b))))) |
(/.f64 (*.f64 (*.f64 (+.f64 b a) (-.f64 a b)) (*.f64 (+.f64 b a) (-.f64 a b))) (*.f64 (-.f64 a b) (-.f64 a b))) |
(/.f64 (*.f64 (*.f64 (+.f64 b a) (-.f64 a b)) (fma.f64 (*.f64 a a) a (*.f64 (*.f64 b b) b))) (*.f64 (-.f64 a b) (fma.f64 b (-.f64 b a) (*.f64 a a)))) |
(/.f64 (*.f64 (fma.f64 (*.f64 a a) a (*.f64 (*.f64 b b) b)) (*.f64 (+.f64 b a) (-.f64 a b))) (*.f64 (fma.f64 b (-.f64 b a) (*.f64 a a)) (-.f64 a b))) |
(/.f64 (*.f64 (fma.f64 (*.f64 a a) a (*.f64 (*.f64 b b) b)) (fma.f64 (*.f64 a a) a (*.f64 (*.f64 b b) b))) (*.f64 (fma.f64 b (-.f64 b a) (*.f64 a a)) (fma.f64 b (-.f64 b a) (*.f64 a a)))) |
(neg.f64 (*.f64 (+.f64 b a) (neg.f64 (+.f64 b a)))) |
(neg.f64 (*.f64 (neg.f64 (+.f64 b a)) (+.f64 b a))) |
(fma.f64 (+.f64 b a) b (*.f64 (+.f64 b a) a)) |
(fma.f64 (+.f64 b a) a (*.f64 (+.f64 b a) b)) |
(fma.f64 b (+.f64 b a) (*.f64 (+.f64 b a) a)) |
(fma.f64 a (+.f64 b a) (*.f64 (+.f64 b a) b)) |
(-.f64 (*.f64 (+.f64 b a) a) (*.f64 (neg.f64 (+.f64 b a)) b)) |
(-.f64 (*.f64 (+.f64 b a) a) (*.f64 (neg.f64 b) (+.f64 b a))) |
(fabs.f64 (*.f64 (+.f64 b a) (+.f64 b a))) |
(exp.f64 (*.f64 (log.f64 (+.f64 b a)) #s(literal 2 binary64))) |
(+.f64 (*.f64 (+.f64 b a) b) (*.f64 (+.f64 b a) a)) |
(+.f64 (*.f64 (+.f64 b a) a) (*.f64 (+.f64 b a) b)) |
(/.f64 (-.f64 (*.f64 b b) (*.f64 a a)) (-.f64 b a)) |
(/.f64 (neg.f64 (*.f64 (+.f64 b a) (-.f64 a b))) (neg.f64 (-.f64 a b))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 a a) a (*.f64 (*.f64 b b) b))) (neg.f64 (fma.f64 b (-.f64 b a) (*.f64 a a)))) |
(/.f64 (*.f64 (+.f64 b a) (-.f64 a b)) (-.f64 a b)) |
(/.f64 (fma.f64 (*.f64 a a) a (*.f64 (*.f64 b b) b)) (fma.f64 b b (-.f64 (*.f64 a a) (*.f64 b a)))) |
(/.f64 (fma.f64 (*.f64 a a) a (*.f64 (*.f64 b b) b)) (fma.f64 b (-.f64 b a) (*.f64 a a))) |
(-.f64 (/.f64 (*.f64 a a) (-.f64 a b)) (/.f64 (*.f64 b b) (-.f64 a b))) |
(+.f64 (/.f64 (*.f64 (*.f64 a a) a) (fma.f64 b (-.f64 b a) (*.f64 a a))) (/.f64 (*.f64 (*.f64 b b) b) (fma.f64 b (-.f64 b a) (*.f64 a a)))) |
(+.f64 b a) |
(+.f64 a b) |
a |
b |
#s(approx (* (+ a b) (+ a b)) (*.f64 b b)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) a b) b)) |
#s(approx (* (+ a b) (+ a b)) (fma.f64 (fma.f64 #s(literal 2 binary64) a b) b (*.f64 a a))) |
#s(approx (+ a b) b) |
#s(approx (+ a b) (+.f64 b a)) |
#s(approx a a) |
#s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (fma.f64 (/.f64 b a) #s(literal 2 binary64) #s(literal 1 binary64)) a) a)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -2 binary64) b) (*.f64 b (/.f64 b a))) a)) a) a)) |
#s(approx (+ a b) (fma.f64 (/.f64 b a) a a)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -2 binary64) b) (*.f64 b (/.f64 b a))) a)) a) a)) |
#s(approx (+ a b) (*.f64 (neg.f64 a) (-.f64 (/.f64 (neg.f64 b) a) #s(literal 1 binary64)))) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
#s(approx (* (+ a b) (+ a b)) (fma.f64 (fma.f64 #s(literal 2 binary64) a b) b (*.f64 a a))) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (fma.f64 (/.f64 a b) #s(literal 2 binary64) #s(literal 1 binary64)) b) b)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -2 binary64) a) (*.f64 a (/.f64 a b))) b)) b) b)) |
#s(approx (+ a b) (fma.f64 (/.f64 a b) b b)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -2 binary64) a) (*.f64 a (/.f64 a b))) b)) b) b)) |
#s(approx (+ a b) (*.f64 (neg.f64 b) (-.f64 (/.f64 (neg.f64 a) b) #s(literal 1 binary64)))) |
Compiled 1 080 to 176 computations (83.7% saved)
3 alts after pruning (2 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 56 | 2 | 58 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 56 | 3 | 59 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (+.f64 a b) (+.f64 a b)) |
| ▶ | 5.3% | #s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
| ▶ | 4.2% | #s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
Compiled 32 to 18 computations (43.8% saved)
| Inputs |
|---|
#s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
(*.f64 a a) |
a |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
(*.f64 (fma.f64 #s(literal 2 binary64) b a) a) |
(fma.f64 #s(literal 2 binary64) b a) |
#s(literal 2 binary64) |
b |
| Outputs |
|---|
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (pow b 2))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* 2 (* a b)) (pow b 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* a (+ a (* 2 b))) (pow b 2)))) |
#s(approx (* a a) #s(hole binary64 (pow a 2))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (* (+ (* 2 b) a) a) #s(hole binary64 (* 2 (* a b)))) |
#s(approx (* (+ (* 2 b) a) a) #s(hole binary64 (* a (+ a (* 2 b))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* 2 b))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (+ a (* 2 b)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (* 2 (/ b a)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (+ (* 2 (/ b a)) (/ (pow b 2) (pow a 2))))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* a (+ 1 (* 2 (/ b a)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (* -1 (/ (+ (* -2 b) (* -1 (/ (pow b 2) a))) a)))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* -1 (* a (- (* -2 (/ b a)) 1))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* 2 (* a b)) (pow a 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* b (+ b (* 2 a))) (pow a 2)))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (* 2 (/ a b)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (+ (* 2 (/ a b)) (/ (pow a 2) (pow b 2))))))) |
#s(approx (* (+ (* 2 b) a) a) #s(hole binary64 (* b (+ (* 2 a) (/ (pow a 2) b))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* b (+ 2 (/ a b))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (* -1 (/ (+ (* -2 a) (* -1 (/ (pow a 2) b))) b)))))) |
#s(approx (* (+ (* 2 b) a) a) #s(hole binary64 (* -1 (* b (+ (* -2 a) (* -1 (/ (pow a 2) b))))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* -1 (* b (- (* -1 (/ a b)) 2))))) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 28.0ms | a | inf |
| 1.0ms | a | -inf |
| 1.0ms | a | 0 |
| 1.0ms | b | -inf |
| 1.0ms | b | inf |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 101 | 429 |
| 0 | 105 | 385 |
| 1 | 545 | 376 |
| 0 | 5282 | 365 |
| 1× | iter-limit |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
(*.f64 a a) |
a |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
(*.f64 (fma.f64 #s(literal 2 binary64) b a) a) |
(fma.f64 #s(literal 2 binary64) b a) |
#s(literal 2 binary64) |
b |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (pow b 2))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* 2 (* a b)) (pow b 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* a (+ a (* 2 b))) (pow b 2)))) |
#s(approx (* a a) #s(hole binary64 (pow a 2))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (* (+ (* 2 b) a) a) #s(hole binary64 (* 2 (* a b)))) |
#s(approx (* (+ (* 2 b) a) a) #s(hole binary64 (* a (+ a (* 2 b))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* 2 b))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (+ a (* 2 b)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (* 2 (/ b a)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (+ (* 2 (/ b a)) (/ (pow b 2) (pow a 2))))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* a (+ 1 (* 2 (/ b a)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow a 2) (+ 1 (* -1 (/ (+ (* -2 b) (* -1 (/ (pow b 2) a))) a)))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* -1 (* a (- (* -2 (/ b a)) 1))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* 2 (* a b)) (pow a 2)))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (+ (* b (+ b (* 2 a))) (pow a 2)))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (* 2 (/ a b)))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (+ (* 2 (/ a b)) (/ (pow a 2) (pow b 2))))))) |
#s(approx (* (+ (* 2 b) a) a) #s(hole binary64 (* b (+ (* 2 a) (/ (pow a 2) b))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* b (+ 2 (/ a b))))) |
#s(approx (* (+ a b) (+ a b)) #s(hole binary64 (* (pow b 2) (+ 1 (* -1 (/ (+ (* -2 a) (* -1 (/ (pow a 2) b))) b)))))) |
#s(approx (* (+ (* 2 b) a) a) #s(hole binary64 (* -1 (* b (+ (* -2 a) (* -1 (/ (pow a 2) b))))))) |
#s(approx (+ (* 2 b) a) #s(hole binary64 (* -1 (* b (- (* -1 (/ a b)) 2))))) |
| Outputs |
|---|
#s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
(*.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 a)) (*.f64 #s(literal 1 binary64) (fabs.f64 a))) |
(*.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 a)) (fabs.f64 a)) |
(*.f64 (*.f64 #s(literal 1 binary64) (neg.f64 a)) (*.f64 #s(literal 1 binary64) (neg.f64 a))) |
(*.f64 (*.f64 #s(literal 1 binary64) (neg.f64 a)) (neg.f64 a)) |
(*.f64 (*.f64 (fabs.f64 a) #s(literal 1 binary64)) (*.f64 (fabs.f64 a) #s(literal 1 binary64))) |
(*.f64 (*.f64 (neg.f64 a) #s(literal 1 binary64)) (*.f64 (neg.f64 a) #s(literal 1 binary64))) |
(*.f64 (fabs.f64 (fabs.f64 a)) (fabs.f64 (fabs.f64 a))) |
(*.f64 (neg.f64 (fabs.f64 a)) (neg.f64 (fabs.f64 a))) |
(*.f64 (exp.f64 (log.f64 a)) (exp.f64 (log.f64 a))) |
(*.f64 (fabs.f64 a) (*.f64 (fabs.f64 a) #s(literal 1 binary64))) |
(*.f64 (fabs.f64 a) (fabs.f64 a)) |
(*.f64 (neg.f64 a) (*.f64 (neg.f64 a) #s(literal 1 binary64))) |
(*.f64 (neg.f64 a) (neg.f64 a)) |
(*.f64 #s(literal 1 binary64) (*.f64 a a)) |
(*.f64 (*.f64 a a) #s(literal 1 binary64)) |
(*.f64 a a) |
(pow.f64 (exp.f64 (log.f64 a)) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 a) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 a) #s(literal 2 binary64)) |
(pow.f64 (*.f64 a a) #s(literal 1 binary64)) |
(pow.f64 a #s(literal 2 binary64)) |
(/.f64 (*.f64 (*.f64 a a) #s(literal 2 binary64)) #s(literal 2 binary64)) |
(/.f64 (*.f64 #s(literal 2 binary64) (*.f64 a a)) #s(literal 2 binary64)) |
(neg.f64 (*.f64 (neg.f64 a) a)) |
(fabs.f64 (*.f64 a a)) |
(exp.f64 (+.f64 #s(literal 0 binary64) (*.f64 (log.f64 a) #s(literal 2 binary64)))) |
(exp.f64 (fma.f64 (log.f64 a) #s(literal 2 binary64) #s(literal 0 binary64))) |
(exp.f64 (*.f64 (log.f64 a) #s(literal 2 binary64))) |
(+.f64 (cosh.f64 (*.f64 (log.f64 a) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 a) #s(literal 2 binary64)))) |
a |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
(*.f64 (fma.f64 #s(literal 2 binary64) b a) a) |
(*.f64 a (fma.f64 #s(literal 2 binary64) b a)) |
(/.f64 (*.f64 a (-.f64 (*.f64 #s(literal 4 binary64) (*.f64 b b)) (*.f64 a a))) (-.f64 (+.f64 b b) a)) |
(/.f64 (*.f64 a (-.f64 (*.f64 a a) (*.f64 #s(literal 4 binary64) (*.f64 b b)))) (-.f64 (-.f64 a b) b)) |
(/.f64 (*.f64 a (fma.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64) (*.f64 (*.f64 a a) a))) (fma.f64 #s(literal 4 binary64) (*.f64 b b) (*.f64 a (-.f64 (-.f64 a b) b)))) |
(/.f64 (*.f64 a (fma.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64) (*.f64 (*.f64 a a) a))) (fma.f64 (+.f64 b b) (-.f64 (+.f64 b b) a) (*.f64 a a))) |
(/.f64 (*.f64 (-.f64 (*.f64 #s(literal 4 binary64) (*.f64 b b)) (*.f64 a a)) a) (-.f64 (+.f64 b b) a)) |
(/.f64 (*.f64 (-.f64 (*.f64 a a) (*.f64 #s(literal 4 binary64) (*.f64 b b))) a) (-.f64 (-.f64 a b) b)) |
(/.f64 (*.f64 (fma.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64) (*.f64 (*.f64 a a) a)) a) (fma.f64 #s(literal 4 binary64) (*.f64 b b) (*.f64 a (-.f64 (-.f64 a b) b)))) |
(/.f64 (*.f64 (fma.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64) (*.f64 (*.f64 a a) a)) a) (fma.f64 (+.f64 b b) (-.f64 (+.f64 b b) a) (*.f64 a a))) |
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 a a) a) a) (*.f64 (*.f64 #s(literal 4 binary64) (*.f64 a a)) (*.f64 b b))) (*.f64 a (-.f64 (-.f64 a b) b))) |
(/.f64 (neg.f64 (*.f64 (*.f64 (fma.f64 #s(literal 2 binary64) b a) a) (-.f64 (*.f64 (+.f64 a a) b) (*.f64 a a)))) (neg.f64 (-.f64 (*.f64 (+.f64 a a) b) (*.f64 a a)))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 (*.f64 (*.f64 a a) a) a) (*.f64 a a) (*.f64 (*.f64 (*.f64 (*.f64 a a) a) #s(literal 8 binary64)) (*.f64 (*.f64 b b) b)))) (neg.f64 (fma.f64 (*.f64 (*.f64 b a) (*.f64 b a)) #s(literal 4 binary64) (*.f64 (*.f64 a a) (*.f64 a (-.f64 (-.f64 a b) b)))))) |
(/.f64 (*.f64 (*.f64 (fma.f64 #s(literal 2 binary64) b a) a) (-.f64 (*.f64 (+.f64 a a) b) (*.f64 a a))) (-.f64 (*.f64 (+.f64 a a) b) (*.f64 a a))) |
(/.f64 (fma.f64 (*.f64 (*.f64 (*.f64 a a) a) a) (*.f64 a a) (*.f64 (*.f64 (*.f64 (*.f64 a a) a) #s(literal 8 binary64)) (*.f64 (*.f64 b b) b))) (fma.f64 (*.f64 (*.f64 a a) a) a (-.f64 (*.f64 (*.f64 #s(literal 4 binary64) (*.f64 a a)) (*.f64 b b)) (*.f64 (+.f64 a a) (*.f64 b (*.f64 a a)))))) |
(/.f64 (fma.f64 (*.f64 (*.f64 (*.f64 a a) a) a) (*.f64 a a) (*.f64 (*.f64 (*.f64 (*.f64 a a) a) #s(literal 8 binary64)) (*.f64 (*.f64 b b) b))) (fma.f64 (*.f64 (*.f64 b a) (*.f64 b a)) #s(literal 4 binary64) (*.f64 (*.f64 a a) (*.f64 a (-.f64 (-.f64 a b) b))))) |
(fma.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 a)) (*.f64 #s(literal 1 binary64) (fabs.f64 a)) (*.f64 (+.f64 a a) b)) |
(fma.f64 (*.f64 #s(literal 1 binary64) (fabs.f64 a)) (fabs.f64 a) (*.f64 (+.f64 a a) b)) |
(fma.f64 (*.f64 #s(literal 1 binary64) (neg.f64 a)) (*.f64 #s(literal 1 binary64) (neg.f64 a)) (*.f64 (+.f64 a a) b)) |
(fma.f64 (*.f64 #s(literal 1 binary64) (neg.f64 a)) (neg.f64 a) (*.f64 (+.f64 a a) b)) |
(fma.f64 (*.f64 (fabs.f64 a) #s(literal 1 binary64)) (*.f64 (fabs.f64 a) #s(literal 1 binary64)) (*.f64 (+.f64 a a) b)) |
(fma.f64 (*.f64 (neg.f64 a) #s(literal 1 binary64)) (*.f64 (neg.f64 a) #s(literal 1 binary64)) (*.f64 (+.f64 a a) b)) |
(fma.f64 (fabs.f64 (fabs.f64 a)) (fabs.f64 (fabs.f64 a)) (*.f64 (+.f64 a a) b)) |
(fma.f64 (neg.f64 (fabs.f64 a)) (neg.f64 (fabs.f64 a)) (*.f64 (+.f64 a a) b)) |
(fma.f64 (exp.f64 (log.f64 a)) (exp.f64 (log.f64 a)) (*.f64 (+.f64 a a) b)) |
(fma.f64 (fabs.f64 a) (*.f64 (fabs.f64 a) #s(literal 1 binary64)) (*.f64 (+.f64 a a) b)) |
(fma.f64 (fabs.f64 a) (fabs.f64 a) (*.f64 (+.f64 a a) b)) |
(fma.f64 (neg.f64 a) (*.f64 (neg.f64 a) #s(literal 1 binary64)) (*.f64 (+.f64 a a) b)) |
(fma.f64 (neg.f64 a) (neg.f64 a) (*.f64 (+.f64 a a) b)) |
(fma.f64 (+.f64 a a) b (*.f64 a a)) |
(fma.f64 #s(literal 1 binary64) (*.f64 a a) (*.f64 (+.f64 a a) b)) |
(fma.f64 (*.f64 a a) #s(literal 1 binary64) (*.f64 (+.f64 a a) b)) |
(fma.f64 (+.f64 b b) a (*.f64 a a)) |
(fma.f64 (*.f64 b a) #s(literal 2 binary64) (*.f64 a a)) |
(fma.f64 #s(literal 2 binary64) (*.f64 b a) (*.f64 a a)) |
(fma.f64 (+.f64 b a) a (*.f64 b a)) |
(fma.f64 b (+.f64 a a) (*.f64 a a)) |
(fma.f64 b a (*.f64 (+.f64 b a) a)) |
(fma.f64 a (+.f64 b b) (*.f64 a a)) |
(fma.f64 a (+.f64 b a) (*.f64 b a)) |
(fma.f64 a b (*.f64 (+.f64 b a) a)) |
(fma.f64 a a (*.f64 (+.f64 a a) b)) |
(-.f64 (/.f64 (*.f64 (*.f64 #s(literal 4 binary64) (*.f64 a a)) (*.f64 b b)) (-.f64 (*.f64 (+.f64 a a) b) (*.f64 a a))) (/.f64 (*.f64 (*.f64 (*.f64 a a) a) a) (-.f64 (*.f64 (+.f64 a a) b) (*.f64 a a)))) |
(-.f64 (*.f64 a a) (*.f64 (neg.f64 (*.f64 b a)) #s(literal 2 binary64))) |
(-.f64 (*.f64 a a) (*.f64 (neg.f64 a) (+.f64 b b))) |
(-.f64 (*.f64 a a) (*.f64 (*.f64 #s(literal -2 binary64) a) b)) |
(-.f64 (*.f64 (+.f64 a a) b) (*.f64 (neg.f64 a) a)) |
(+.f64 (/.f64 (*.f64 (*.f64 (*.f64 (*.f64 a a) a) #s(literal 8 binary64)) (*.f64 (*.f64 b b) b)) (fma.f64 (*.f64 (*.f64 b a) (*.f64 b a)) #s(literal 4 binary64) (*.f64 (*.f64 a a) (*.f64 a (-.f64 (-.f64 a b) b))))) (/.f64 (*.f64 (*.f64 (*.f64 (*.f64 a a) a) a) (*.f64 a a)) (fma.f64 (*.f64 (*.f64 b a) (*.f64 b a)) #s(literal 4 binary64) (*.f64 (*.f64 a a) (*.f64 a (-.f64 (-.f64 a b) b)))))) |
(+.f64 (*.f64 (+.f64 b a) a) (*.f64 b a)) |
(+.f64 (*.f64 a a) (*.f64 (+.f64 a a) b)) |
(+.f64 (*.f64 (+.f64 a a) b) (*.f64 a a)) |
(+.f64 (*.f64 b a) (*.f64 (+.f64 b a) a)) |
(/.f64 (-.f64 (*.f64 (*.f64 a a) a) (*.f64 #s(literal -8 binary64) (*.f64 (*.f64 b b) b))) (fma.f64 a a (fma.f64 #s(literal 4 binary64) (*.f64 b b) (*.f64 (*.f64 #s(literal -2 binary64) a) b)))) |
(/.f64 (neg.f64 (-.f64 (*.f64 #s(literal 4 binary64) (*.f64 b b)) (*.f64 a a))) (neg.f64 (-.f64 (+.f64 b b) a))) |
(/.f64 (neg.f64 (-.f64 (*.f64 a a) (*.f64 #s(literal 4 binary64) (*.f64 b b)))) (neg.f64 (-.f64 (-.f64 a b) b))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64) (*.f64 (*.f64 a a) a))) (neg.f64 (fma.f64 #s(literal 4 binary64) (*.f64 b b) (*.f64 a (-.f64 (-.f64 a b) b))))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64) (*.f64 (*.f64 a a) a))) (neg.f64 (fma.f64 (+.f64 b b) (-.f64 (+.f64 b b) a) (*.f64 a a)))) |
(/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (*.f64 b b)) (*.f64 a a)) (-.f64 (+.f64 b b) a)) |
(/.f64 (-.f64 (*.f64 a a) (*.f64 #s(literal 4 binary64) (*.f64 b b))) (-.f64 (-.f64 a b) b)) |
(/.f64 (fma.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64) (*.f64 (*.f64 a a) a)) (fma.f64 #s(literal 4 binary64) (*.f64 b b) (*.f64 a (-.f64 (-.f64 a b) b)))) |
(/.f64 (fma.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64) (*.f64 (*.f64 a a) a)) (fma.f64 (+.f64 b b) (-.f64 (+.f64 b b) a) (*.f64 a a))) |
(fma.f64 #s(literal 2 binary64) b a) |
(fma.f64 b #s(literal 2 binary64) a) |
(-.f64 (/.f64 (*.f64 #s(literal 4 binary64) (*.f64 b b)) (-.f64 (+.f64 b b) a)) (/.f64 (*.f64 a a) (-.f64 (+.f64 b b) a))) |
(-.f64 (/.f64 (*.f64 a a) (-.f64 (-.f64 a b) b)) (/.f64 (*.f64 #s(literal 4 binary64) (*.f64 b b)) (-.f64 (-.f64 a b) b))) |
(-.f64 a (*.f64 (neg.f64 b) #s(literal 2 binary64))) |
(-.f64 a (*.f64 #s(literal -2 binary64) b)) |
(+.f64 (/.f64 (*.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64)) (fma.f64 #s(literal 4 binary64) (*.f64 b b) (*.f64 a (-.f64 (-.f64 a b) b)))) (/.f64 (*.f64 (*.f64 a a) a) (fma.f64 #s(literal 4 binary64) (*.f64 b b) (*.f64 a (-.f64 (-.f64 a b) b))))) |
(+.f64 (/.f64 (*.f64 (*.f64 a a) a) (fma.f64 (+.f64 b b) (-.f64 (+.f64 b b) a) (*.f64 a a))) (/.f64 (*.f64 (*.f64 (*.f64 b b) b) #s(literal 8 binary64)) (fma.f64 (+.f64 b b) (-.f64 (+.f64 b b) a) (*.f64 a a)))) |
(+.f64 (+.f64 b b) a) |
(+.f64 (+.f64 b a) b) |
(+.f64 b (+.f64 b a)) |
(+.f64 a (*.f64 (neg.f64 b) #s(literal -2 binary64))) |
(+.f64 a (+.f64 b b)) |
#s(literal 2 binary64) |
b |
#s(approx (* (+ a b) (+ a b)) (*.f64 b b)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) a b) b)) |
#s(approx (* (+ a b) (+ a b)) (fma.f64 (fma.f64 #s(literal 2 binary64) a b) b (*.f64 a a))) |
#s(approx (* a a) (*.f64 a a)) |
#s(approx a a) |
#s(approx (* (+ (* 2 b) a) a) (*.f64 (+.f64 a a) b)) |
#s(approx (* (+ (* 2 b) a) a) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
#s(approx (+ (* 2 b) a) (+.f64 b b)) |
#s(approx (+ (* 2 b) a) (fma.f64 #s(literal 2 binary64) b a)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 (/.f64 (+.f64 b b) a) a a) a)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -2 binary64) b) (*.f64 b (/.f64 b a))) a)) a) a)) |
#s(approx (+ (* 2 b) a) (fma.f64 (/.f64 (+.f64 b b) a) a a)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -2 binary64) b) (*.f64 b (/.f64 b a))) a)) a) a)) |
#s(approx (+ (* 2 b) a) (*.f64 (neg.f64 a) (fma.f64 #s(literal -2 binary64) (/.f64 b a) #s(literal -1 binary64)))) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
#s(approx (* (+ a b) (+ a b)) (fma.f64 (fma.f64 #s(literal 2 binary64) a b) b (*.f64 a a))) |
#s(approx b b) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (fma.f64 (/.f64 a b) #s(literal 2 binary64) #s(literal 1 binary64)) b) b)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -2 binary64) a) (*.f64 a (/.f64 a b))) b)) b) b)) |
#s(approx (* (+ (* 2 b) a) a) (*.f64 (fma.f64 a (/.f64 a b) (+.f64 a a)) b)) |
#s(approx (+ (* 2 b) a) (*.f64 (+.f64 (/.f64 a b) #s(literal 2 binary64)) b)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (*.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -2 binary64) a) (*.f64 a (/.f64 a b))) b)) b) b)) |
#s(approx (* (+ (* 2 b) a) a) (*.f64 (fma.f64 a (/.f64 a b) (neg.f64 (*.f64 #s(literal -2 binary64) a))) b)) |
#s(approx (+ (* 2 b) a) (*.f64 (neg.f64 b) (-.f64 (/.f64 (neg.f64 a) b) #s(literal 2 binary64)))) |
Compiled 2 651 to 418 computations (84.2% saved)
3 alts after pruning (0 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 121 | 0 | 121 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 2 | 2 |
| Done | 0 | 1 | 1 |
| Total | 121 | 3 | 124 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (*.f64 (+.f64 a b) (+.f64 a b)) |
| ✓ | 5.3% | #s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
| ✓ | 4.2% | #s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
Compiled 64 to 30 computations (53.1% saved)
| Inputs |
|---|
#s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
(*.f64 (+.f64 a b) (+.f64 a b)) |
| Outputs |
|---|
(*.f64 (+.f64 a b) (+.f64 a b)) |
4 calls:
| 4.0ms | (*.f64 (+.f64 a b) (+.f64 a b)) |
| 2.0ms | b |
| 2.0ms | (+.f64 a b) |
| 2.0ms | a |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | (+.f64 a b) |
| 100.0% | 1 | (*.f64 (+.f64 a b) (+.f64 a b)) |
| 100.0% | 1 | a |
| 100.0% | 1 | b |
Compiled 12 to 11 computations (8.3% saved)
| Inputs |
|---|
#s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
| Outputs |
|---|
#s(approx (* (+ a b) (+ a b)) (*.f64 (fma.f64 #s(literal 2 binary64) b a) a)) |
4 calls:
| 1.0ms | b |
| 1.0ms | (+.f64 a b) |
| 1.0ms | (*.f64 (+.f64 a b) (+.f64 a b)) |
| 1.0ms | a |
| Accuracy | Segments | Branch |
|---|---|---|
| 5.3% | 1 | (+.f64 a b) |
| 5.3% | 1 | (*.f64 (+.f64 a b) (+.f64 a b)) |
| 5.3% | 1 | a |
| 5.3% | 1 | b |
Compiled 12 to 11 computations (8.3% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
#s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
| Outputs |
|---|
#s(approx (* (+ a b) (+ a b)) (*.f64 a a)) |
4 calls:
| 1.0ms | (*.f64 (+.f64 a b) (+.f64 a b)) |
| 1.0ms | (+.f64 a b) |
| 1.0ms | a |
| 1.0ms | b |
| Accuracy | Segments | Branch |
|---|---|---|
| 4.2% | 1 | (+.f64 a b) |
| 4.2% | 1 | (*.f64 (+.f64 a b) (+.f64 a b)) |
| 4.2% | 1 | b |
| 4.2% | 1 | a |
Compiled 12 to 11 computations (8.3% saved)
| 1× | done |
Compiled 32 to 12 computations (62.5% saved)
(sort a b)
Compiled 118 to 60 computations (49.2% saved)
Loading profile data...