
Time bar (total: 3.2s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.7% | 0.3% | 0% | 0% | 0% | 0 |
| 100% | 99.7% | 0% | 0.3% | 0% | 0% | 0% | 1 |
Compiled 13 to 13 computations (0% saved)
| 777.0ms | 8 256× | 0 | valid |
ival-mult!: 260.0ms (78.7% of total)ival-add!: 68.0ms (20.6% of total)adjust: 1.0ms (0.3% of total)Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 89 | 318 |
| 1 | 320 | 308 |
| 2 | 947 | 308 |
| 3 | 1785 | 308 |
| 4 | 1816 | 308 |
| 1× | saturated |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 99.2% | (+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
(sort x y)
(sort z t)
(sort a b)
Compiled 22 to 22 computations (0% saved)
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 140 | 581 |
| 1× | iter-limit |
| Inputs |
|---|
(+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
(+.f64 (*.f64 x y) (*.f64 z t)) |
(*.f64 x y) |
x |
y |
(*.f64 z t) |
z |
t |
(*.f64 a b) |
a |
b |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (fma.f64 t z (*.f64 x y)))) |
#s(approx (+ (* x y) (* z t)) (*.f64 t z)) |
#s(approx (+ (* x y) (* z t)) (fma.f64 t z (*.f64 x y))) |
#s(approx (* x y) (*.f64 x y)) |
#s(approx x x) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x (+.f64 y (+.f64 (/.f64 (*.f64 a b) x) (/.f64 (*.f64 t z) x))))) |
#s(approx (+ (* x y) (* z t)) (*.f64 x (+.f64 y (/.f64 (*.f64 t z) x)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 t z)) x)))))) |
#s(approx (+ (* x y) (* z t)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) x)))))) |
#s(approx y y) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 y (+.f64 x (+.f64 (/.f64 (*.f64 a b) y) (/.f64 (*.f64 t z) y))))) |
#s(approx (+ (* x y) (* z t)) (*.f64 y (+.f64 x (/.f64 (*.f64 t z) y)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 t z)) y)))))) |
#s(approx (+ (* x y) (* z t)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) y)))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
#s(approx z z) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 z (+.f64 t (+.f64 (/.f64 (*.f64 a b) z) (/.f64 (*.f64 x y) z))))) |
#s(approx (+ (* x y) (* z t)) (*.f64 z (+.f64 t (/.f64 (*.f64 x y) z)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 x y)) z)))))) |
#s(approx (+ (* x y) (* z t)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)))))) |
#s(approx t t) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 t (+.f64 z (+.f64 (/.f64 (*.f64 a b) t) (/.f64 (*.f64 x y) t))))) |
#s(approx (+ (* x y) (* z t)) (*.f64 t (+.f64 z (/.f64 (*.f64 x y) t)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 t (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 x y)) t)))))) |
#s(approx (+ (* x y) (* z t)) (*.f64 #s(literal -1 binary64) (*.f64 t (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) t)))))) |
#s(approx (* a b) (*.f64 a b)) |
#s(approx a a) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 a (+.f64 b (+.f64 (/.f64 (*.f64 t z) a) (/.f64 (*.f64 x y) a))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 a (fma.f64 #s(literal -1 binary64) b (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 t z (*.f64 x y)) a)))))) |
#s(approx b b) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 b (+.f64 a (+.f64 (/.f64 (*.f64 t z) b) (/.f64 (*.f64 x y) b))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 b (fma.f64 #s(literal -1 binary64) a (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 t z (*.f64 x y)) b)))))) |
18 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 4.0ms | b | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* x y) (* z t)) (* x y) x y (* z t) z t (* a b) a b) |
| 1.0ms | z | @ | inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* x y) (* z t)) (* x y) x y (* z t) z t (* a b) a b) |
| 1.0ms | x | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* x y) (* z t)) (* x y) x y (* z t) z t (* a b) a b) |
| 1.0ms | x | @ | inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* x y) (* z t)) (* x y) x y (* z t) z t (* a b) a b) |
| 1.0ms | z | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* x y) (* z t)) (* x y) x y (* z t) z t (* a b) a b) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 11 | 33 |
| 0 | 16 | 33 |
| 1 | 65 | 33 |
| 2 | 233 | 33 |
| 3 | 697 | 33 |
| 4 | 1174 | 33 |
| 5 | 1534 | 33 |
| 6 | 4214 | 33 |
| 0 | 8290 | 30 |
| 1 | 14253 | 30 |
| 1× | saturated |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
(+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
(+.f64 (*.f64 x y) (*.f64 z t)) |
(*.f64 x y) |
x |
y |
(*.f64 z t) |
z |
t |
(*.f64 a b) |
a |
b |
| Outputs |
|---|
(neg.f64 (neg.f64 (fma.f64 b a (fma.f64 t z (*.f64 y x))))) |
(fma.f64 (neg.f64 y) (neg.f64 x) (fma.f64 b a (*.f64 t z))) |
(fma.f64 (neg.f64 x) (neg.f64 y) (fma.f64 b a (*.f64 t z))) |
(fma.f64 (neg.f64 t) (neg.f64 z) (fma.f64 b a (*.f64 y x))) |
(fma.f64 (neg.f64 b) (neg.f64 a) (fma.f64 t z (*.f64 y x))) |
(fma.f64 (neg.f64 z) (neg.f64 t) (fma.f64 b a (*.f64 y x))) |
(fma.f64 (neg.f64 a) (neg.f64 b) (fma.f64 t z (*.f64 y x))) |
(fma.f64 b a (fma.f64 t z (*.f64 y x))) |
(fma.f64 a b (fma.f64 t z (*.f64 y x))) |
(fma.f64 t z (fma.f64 b a (*.f64 y x))) |
(fma.f64 z t (fma.f64 b a (*.f64 y x))) |
(fma.f64 y x (fma.f64 b a (*.f64 t z))) |
(fma.f64 x y (fma.f64 b a (*.f64 t z))) |
(-.f64 (fma.f64 b a (*.f64 y x)) (*.f64 (neg.f64 z) t)) |
(-.f64 (fma.f64 b a (*.f64 t z)) (*.f64 (neg.f64 y) x)) |
(-.f64 (*.f64 b a) (neg.f64 (fma.f64 t z (*.f64 y x)))) |
(-.f64 (fma.f64 t z (*.f64 y x)) (*.f64 (neg.f64 a) b)) |
(-.f64 (*.f64 t z) (neg.f64 (fma.f64 b a (*.f64 y x)))) |
(-.f64 (*.f64 y x) (neg.f64 (fma.f64 b a (*.f64 t z)))) |
(+.f64 (fma.f64 b a (*.f64 y x)) (*.f64 t z)) |
(+.f64 (fma.f64 b a (*.f64 t z)) (*.f64 y x)) |
(+.f64 (*.f64 b a) (fma.f64 t z (*.f64 y x))) |
(+.f64 (fma.f64 t z (*.f64 y x)) (*.f64 b a)) |
(+.f64 (*.f64 t z) (fma.f64 b a (*.f64 y x))) |
(+.f64 (*.f64 y x) (fma.f64 b a (*.f64 t z))) |
(neg.f64 (neg.f64 (fma.f64 t z (*.f64 y x)))) |
(fma.f64 (neg.f64 y) (neg.f64 x) (*.f64 t z)) |
(fma.f64 (neg.f64 x) (neg.f64 y) (*.f64 t z)) |
(fma.f64 (neg.f64 t) (neg.f64 z) (*.f64 y x)) |
(fma.f64 (neg.f64 z) (neg.f64 t) (*.f64 y x)) |
(fma.f64 t z (*.f64 y x)) |
(fma.f64 z t (*.f64 y x)) |
(fma.f64 y x (*.f64 t z)) |
(fma.f64 x y (*.f64 t z)) |
(-.f64 (*.f64 t z) (*.f64 (neg.f64 y) x)) |
(-.f64 (*.f64 y x) (*.f64 (neg.f64 z) t)) |
(+.f64 (*.f64 t z) (*.f64 y x)) |
(+.f64 (*.f64 y x) (*.f64 t z)) |
(*.f64 (neg.f64 y) (neg.f64 x)) |
(*.f64 (neg.f64 x) (neg.f64 y)) |
(*.f64 y x) |
(*.f64 x y) |
(neg.f64 (*.f64 (neg.f64 y) x)) |
x |
y |
(*.f64 (neg.f64 t) (neg.f64 z)) |
(*.f64 (neg.f64 z) (neg.f64 t)) |
(*.f64 t z) |
(*.f64 z t) |
(neg.f64 (*.f64 (neg.f64 z) t)) |
z |
t |
(*.f64 (neg.f64 b) (neg.f64 a)) |
(*.f64 (neg.f64 a) (neg.f64 b)) |
(*.f64 b a) |
(*.f64 a b) |
(neg.f64 (*.f64 (neg.f64 a) b)) |
a |
b |
Compiled 528 to 264 computations (50% saved)
3 alts after pruning (3 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 80 | 3 | 83 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 81 | 3 | 84 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 99.6% | (fma.f64 z t (fma.f64 b a (*.f64 y x))) |
| ▶ | 69.2% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
| ▶ | 68.7% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
Compiled 37 to 37 computations (0% saved)
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 172 | 729 |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
(fma.f64 a b (*.f64 t z)) |
a |
b |
(*.f64 t z) |
t |
z |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
(fma.f64 a b (*.f64 x y)) |
(*.f64 x y) |
x |
y |
(fma.f64 z t (fma.f64 b a (*.f64 y x))) |
(fma.f64 b a (*.f64 y x)) |
(*.f64 y x) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (fma.f64 t z (*.f64 x y)))) |
#s(approx (+ (* a b) (* x y)) (*.f64 a b)) |
#s(approx (+ (* a b) (* x y)) (fma.f64 a b (*.f64 x y))) |
#s(approx (* x y) (*.f64 x y)) |
#s(approx x x) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x (+.f64 y (+.f64 (/.f64 (*.f64 a b) x) (/.f64 (*.f64 t z) x))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 x (+.f64 y (/.f64 (*.f64 a b) x)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 t z)) x)))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 a b) x)))))) |
#s(approx y y) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 y (+.f64 x (+.f64 (/.f64 (*.f64 a b) y) (/.f64 (*.f64 t z) y))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 y (+.f64 x (/.f64 (*.f64 a b) y)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 t z)) y)))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 a b) y)))))) |
#s(approx (* t z) (*.f64 t z)) |
#s(approx z z) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 z (+.f64 t (+.f64 (/.f64 (*.f64 a b) z) (/.f64 (*.f64 x y) z))))) |
#s(approx (+ (* a b) (* t z)) (*.f64 z (+.f64 t (/.f64 (*.f64 a b) z)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 x y)) z)))))) |
#s(approx (+ (* a b) (* t z)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 a b) z)))))) |
#s(approx t t) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 t (+.f64 z (+.f64 (/.f64 (*.f64 a b) t) (/.f64 (*.f64 x y) t))))) |
#s(approx (+ (* a b) (* t z)) (*.f64 t (+.f64 z (/.f64 (*.f64 a b) t)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 t (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 x y)) t)))))) |
#s(approx (+ (* a b) (* t z)) (*.f64 #s(literal -1 binary64) (*.f64 t (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 a b) t)))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
#s(approx a a) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 a (+.f64 b (+.f64 (/.f64 (*.f64 t z) a) (/.f64 (*.f64 x y) a))))) |
#s(approx (+ (* a b) (* t z)) (*.f64 a (+.f64 b (/.f64 (*.f64 t z) a)))) |
#s(approx (+ (* a b) (* x y)) (*.f64 a (+.f64 b (/.f64 (*.f64 x y) a)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 a (fma.f64 #s(literal -1 binary64) b (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 t z (*.f64 x y)) a)))))) |
#s(approx (+ (* a b) (* t z)) (*.f64 #s(literal -1 binary64) (*.f64 a (fma.f64 #s(literal -1 binary64) b (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) a)))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 a (fma.f64 #s(literal -1 binary64) b (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) a)))))) |
#s(approx b b) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 b (+.f64 a (+.f64 (/.f64 (*.f64 t z) b) (/.f64 (*.f64 x y) b))))) |
#s(approx (+ (* a b) (* t z)) (*.f64 b (+.f64 a (/.f64 (*.f64 t z) b)))) |
#s(approx (+ (* a b) (* x y)) (*.f64 b (+.f64 a (/.f64 (*.f64 x y) b)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 b (fma.f64 #s(literal -1 binary64) a (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 t z (*.f64 x y)) b)))))) |
#s(approx (+ (* a b) (* t z)) (*.f64 #s(literal -1 binary64) (*.f64 b (fma.f64 #s(literal -1 binary64) a (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) b)))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 b (fma.f64 #s(literal -1 binary64) a (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) b)))))) |
18 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 10.0ms | b | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* t z)) a b (* t z) t z (+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* x y) x y (+ (* z t) (+ (* b a) (* y x))) (+ (* b a) (* y x)) (* y x)) |
| 2.0ms | z | @ | inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* t z)) a b (* t z) t z (+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* x y) x y (+ (* z t) (+ (* b a) (* y x))) (+ (* b a) (* y x)) (* y x)) |
| 1.0ms | y | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* t z)) a b (* t z) t z (+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* x y) x y (+ (* z t) (+ (* b a) (* y x))) (+ (* b a) (* y x)) (* y x)) |
| 1.0ms | x | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* t z)) a b (* t z) t z (+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* x y) x y (+ (* z t) (+ (* b a) (* y x))) (+ (* b a) (* y x)) (* y x)) |
| 1.0ms | t | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* t z)) a b (* t z) t z (+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* x y) x y (+ (* z t) (+ (* b a) (* y x))) (+ (* b a) (* y x)) (* y x)) |
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 20 | 78 |
| 0 | 28 | 76 |
| 1 | 168 | 74 |
| 2 | 485 | 74 |
| 3 | 1012 | 74 |
| 4 | 1249 | 74 |
| 5 | 1576 | 74 |
| 6 | 4256 | 74 |
| 0 | 8332 | 74 |
| 1 | 14293 | 74 |
| 1× | saturated |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
(fma.f64 a b (*.f64 t z)) |
a |
b |
(*.f64 t z) |
t |
z |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
(fma.f64 a b (*.f64 x y)) |
(*.f64 x y) |
x |
y |
(fma.f64 z t (fma.f64 b a (*.f64 y x))) |
(fma.f64 b a (*.f64 y x)) |
(*.f64 y x) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 b a (*.f64 t z))) |
(neg.f64 (neg.f64 (fma.f64 b a (*.f64 t z)))) |
(fma.f64 (neg.f64 b) (neg.f64 a) (*.f64 t z)) |
(fma.f64 (neg.f64 z) (neg.f64 t) (*.f64 b a)) |
(fma.f64 (neg.f64 t) (neg.f64 z) (*.f64 b a)) |
(fma.f64 (neg.f64 a) (neg.f64 b) (*.f64 t z)) |
(fma.f64 b a (*.f64 t z)) |
(fma.f64 a b (*.f64 t z)) |
(fma.f64 t z (*.f64 b a)) |
(fma.f64 z t (*.f64 b a)) |
(-.f64 (*.f64 b a) (*.f64 (neg.f64 z) t)) |
(-.f64 (*.f64 t z) (*.f64 (neg.f64 b) a)) |
(+.f64 (*.f64 b a) (*.f64 t z)) |
(+.f64 (*.f64 t z) (*.f64 b a)) |
a |
b |
(*.f64 (neg.f64 z) (neg.f64 t)) |
(*.f64 (neg.f64 t) (neg.f64 z)) |
(*.f64 t z) |
(*.f64 z t) |
(neg.f64 (*.f64 (neg.f64 z) t)) |
t |
z |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 b a (*.f64 y x))) |
(neg.f64 (neg.f64 (fma.f64 b a (*.f64 y x)))) |
(fma.f64 (neg.f64 b) (neg.f64 a) (*.f64 y x)) |
(fma.f64 (neg.f64 x) (neg.f64 y) (*.f64 b a)) |
(fma.f64 (neg.f64 y) (neg.f64 x) (*.f64 b a)) |
(fma.f64 (neg.f64 a) (neg.f64 b) (*.f64 y x)) |
(fma.f64 b a (*.f64 y x)) |
(fma.f64 a b (*.f64 y x)) |
(fma.f64 y x (*.f64 b a)) |
(fma.f64 x y (*.f64 b a)) |
(-.f64 (*.f64 y x) (*.f64 (neg.f64 b) a)) |
(-.f64 (*.f64 b a) (*.f64 (neg.f64 x) y)) |
(+.f64 (*.f64 y x) (*.f64 b a)) |
(+.f64 (*.f64 b a) (*.f64 y x)) |
(*.f64 (neg.f64 x) (neg.f64 y)) |
(*.f64 (neg.f64 y) (neg.f64 x)) |
(*.f64 y x) |
(*.f64 x y) |
(neg.f64 (*.f64 (neg.f64 x) y)) |
x |
y |
(neg.f64 (neg.f64 (fma.f64 b a (fma.f64 y x (*.f64 t z))))) |
(fma.f64 (neg.f64 b) (neg.f64 a) (fma.f64 y x (*.f64 t z))) |
(fma.f64 (neg.f64 z) (neg.f64 t) (fma.f64 b a (*.f64 y x))) |
(fma.f64 (neg.f64 t) (neg.f64 z) (fma.f64 b a (*.f64 y x))) |
(fma.f64 (neg.f64 x) (neg.f64 y) (fma.f64 b a (*.f64 t z))) |
(fma.f64 (neg.f64 y) (neg.f64 x) (fma.f64 b a (*.f64 t z))) |
(fma.f64 (neg.f64 a) (neg.f64 b) (fma.f64 y x (*.f64 t z))) |
(fma.f64 b a (fma.f64 y x (*.f64 t z))) |
(fma.f64 a b (fma.f64 y x (*.f64 t z))) |
(fma.f64 t z (fma.f64 b a (*.f64 y x))) |
(fma.f64 z t (fma.f64 b a (*.f64 y x))) |
(fma.f64 y x (fma.f64 b a (*.f64 t z))) |
(fma.f64 x y (fma.f64 b a (*.f64 t z))) |
(-.f64 (fma.f64 b a (*.f64 t z)) (*.f64 (neg.f64 x) y)) |
(-.f64 (fma.f64 b a (*.f64 y x)) (*.f64 (neg.f64 z) t)) |
(-.f64 (*.f64 y x) (neg.f64 (fma.f64 b a (*.f64 t z)))) |
(-.f64 (*.f64 b a) (neg.f64 (fma.f64 y x (*.f64 t z)))) |
(-.f64 (fma.f64 y x (*.f64 t z)) (*.f64 (neg.f64 b) a)) |
(-.f64 (*.f64 t z) (neg.f64 (fma.f64 b a (*.f64 y x)))) |
(+.f64 (fma.f64 b a (*.f64 t z)) (*.f64 y x)) |
(+.f64 (fma.f64 b a (*.f64 y x)) (*.f64 t z)) |
(+.f64 (*.f64 y x) (fma.f64 b a (*.f64 t z))) |
(+.f64 (*.f64 b a) (fma.f64 y x (*.f64 t z))) |
(+.f64 (fma.f64 y x (*.f64 t z)) (*.f64 b a)) |
(+.f64 (*.f64 t z) (fma.f64 b a (*.f64 y x))) |
(neg.f64 (neg.f64 (fma.f64 b a (*.f64 y x)))) |
(fma.f64 (neg.f64 b) (neg.f64 a) (*.f64 y x)) |
(fma.f64 (neg.f64 x) (neg.f64 y) (*.f64 b a)) |
(fma.f64 (neg.f64 y) (neg.f64 x) (*.f64 b a)) |
(fma.f64 (neg.f64 a) (neg.f64 b) (*.f64 y x)) |
(fma.f64 b a (*.f64 y x)) |
(fma.f64 a b (*.f64 y x)) |
(fma.f64 y x (*.f64 b a)) |
(fma.f64 x y (*.f64 b a)) |
(-.f64 (*.f64 y x) (*.f64 (neg.f64 b) a)) |
(-.f64 (*.f64 b a) (*.f64 (neg.f64 x) y)) |
(+.f64 (*.f64 y x) (*.f64 b a)) |
(+.f64 (*.f64 b a) (*.f64 y x)) |
(*.f64 (neg.f64 x) (neg.f64 y)) |
(*.f64 (neg.f64 y) (neg.f64 x)) |
(*.f64 y x) |
(*.f64 x y) |
(neg.f64 (*.f64 (neg.f64 x) y)) |
Compiled 686 to 335 computations (51.2% saved)
4 alts after pruning (3 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 104 | 3 | 107 |
| Fresh | 0 | 0 | 0 |
| Picked | 2 | 1 | 3 |
| Done | 0 | 0 | 0 |
| Total | 106 | 4 | 110 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 68.7% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 z t (*.f64 b a))) |
| ▶ | 63.6% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
| ✓ | 69.2% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
| ▶ | 38.4% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
Compiled 59 to 57 computations (3.4% saved)
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 206 | 876 |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (* a b) (* x y)) (*.f64 a b)) |
(*.f64 a b) |
a |
b |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
(fma.f64 t z (*.f64 x y)) |
t |
z |
(*.f64 x y) |
x |
y |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 z t (*.f64 b a))) |
(fma.f64 z t (*.f64 b a)) |
(*.f64 b a) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (fma.f64 t z (*.f64 x y)))) |
#s(approx (+ (* a b) (* x y)) (*.f64 a b)) |
#s(approx (+ (* a b) (* x y)) (fma.f64 a b (*.f64 x y))) |
#s(approx (+ (* t z) (* x y)) (*.f64 t z)) |
#s(approx (+ (* t z) (* x y)) (fma.f64 t z (*.f64 x y))) |
#s(approx (* x y) (*.f64 x y)) |
#s(approx x x) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x (+.f64 y (+.f64 (/.f64 (*.f64 a b) x) (/.f64 (*.f64 t z) x))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 x (+.f64 y (/.f64 (*.f64 a b) x)))) |
#s(approx (+ (* t z) (* x y)) (*.f64 x (+.f64 y (/.f64 (*.f64 t z) x)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 t z)) x)))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 a b) x)))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) x)))))) |
#s(approx y y) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 y (+.f64 x (+.f64 (/.f64 (*.f64 a b) y) (/.f64 (*.f64 t z) y))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 y (+.f64 x (/.f64 (*.f64 a b) y)))) |
#s(approx (+ (* t z) (* x y)) (*.f64 y (+.f64 x (/.f64 (*.f64 t z) y)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 t z)) y)))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 a b) y)))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) y)))))) |
#s(approx z z) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 z (+.f64 t (+.f64 (/.f64 (*.f64 a b) z) (/.f64 (*.f64 x y) z))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 z (+.f64 t (/.f64 (*.f64 x y) z)))) |
#s(approx (+ (* z t) (* b a)) (*.f64 z (+.f64 t (/.f64 (*.f64 a b) z)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 x y)) z)))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)))))) |
#s(approx (+ (* z t) (* b a)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 a b) z)))))) |
#s(approx t t) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 t (+.f64 z (+.f64 (/.f64 (*.f64 a b) t) (/.f64 (*.f64 x y) t))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 t (+.f64 z (/.f64 (*.f64 x y) t)))) |
#s(approx (+ (* z t) (* b a)) (*.f64 t (+.f64 z (/.f64 (*.f64 a b) t)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 t (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 x y)) t)))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 t (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) t)))))) |
#s(approx (+ (* z t) (* b a)) (*.f64 #s(literal -1 binary64) (*.f64 t (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 a b) t)))))) |
#s(approx a a) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 a (+.f64 b (+.f64 (/.f64 (*.f64 t z) a) (/.f64 (*.f64 x y) a))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 a (+.f64 b (/.f64 (*.f64 x y) a)))) |
#s(approx (+ (* z t) (* b a)) (*.f64 a (+.f64 b (/.f64 (*.f64 t z) a)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 a (fma.f64 #s(literal -1 binary64) b (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 t z (*.f64 x y)) a)))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 a (fma.f64 #s(literal -1 binary64) b (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) a)))))) |
#s(approx (+ (* z t) (* b a)) (*.f64 #s(literal -1 binary64) (*.f64 a (fma.f64 #s(literal -1 binary64) b (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) a)))))) |
#s(approx b b) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 b (+.f64 a (+.f64 (/.f64 (*.f64 t z) b) (/.f64 (*.f64 x y) b))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 b (+.f64 a (/.f64 (*.f64 x y) b)))) |
#s(approx (+ (* z t) (* b a)) (*.f64 b (+.f64 a (/.f64 (*.f64 t z) b)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 b (fma.f64 #s(literal -1 binary64) a (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 t z (*.f64 x y)) b)))))) |
#s(approx (+ (* a b) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 b (fma.f64 #s(literal -1 binary64) a (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) b)))))) |
#s(approx (+ (* z t) (* b a)) (*.f64 #s(literal -1 binary64) (*.f64 b (fma.f64 #s(literal -1 binary64) a (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) b)))))) |
18 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 3.0ms | y | @ | 0 | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* a b) a b (+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) t z (* x y) x y (+ (+ (* x y) (* z t)) (* a b)) (+ (* z t) (* b a)) (* b a)) |
| 1.0ms | y | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* a b) a b (+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) t z (* x y) x y (+ (+ (* x y) (* z t)) (* a b)) (+ (* z t) (* b a)) (* b a)) |
| 1.0ms | b | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* a b) a b (+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) t z (* x y) x y (+ (+ (* x y) (* z t)) (* a b)) (+ (* z t) (* b a)) (* b a)) |
| 1.0ms | x | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* a b) a b (+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) t z (* x y) x y (+ (+ (* x y) (* z t)) (* a b)) (+ (* z t) (* b a)) (* b a)) |
| 1.0ms | a | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* a b) (* x y)) (* a b) a b (+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) t z (* x y) x y (+ (+ (* x y) (* z t)) (* a b)) (+ (* z t) (* b a)) (* b a)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 21 | 97 |
| 0 | 27 | 94 |
| 1 | 144 | 94 |
| 2 | 419 | 94 |
| 3 | 968 | 94 |
| 4 | 1271 | 94 |
| 5 | 1609 | 94 |
| 6 | 4289 | 94 |
| 0 | 8365 | 89 |
| 1 | 14328 | 89 |
| 1× | saturated |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (* a b) (* x y)) (*.f64 a b)) |
(*.f64 a b) |
a |
b |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
(fma.f64 t z (*.f64 x y)) |
t |
z |
(*.f64 x y) |
x |
y |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 z t (*.f64 b a))) |
(fma.f64 z t (*.f64 b a)) |
(*.f64 b a) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 b a))) |
#s(approx (+ (* a b) (* x y)) (*.f64 b a)) |
(*.f64 (neg.f64 a) (neg.f64 b)) |
(*.f64 (neg.f64 b) (neg.f64 a)) |
(*.f64 b a) |
(*.f64 a b) |
(neg.f64 (*.f64 (neg.f64 a) b)) |
a |
b |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 y x))) |
(neg.f64 (neg.f64 (fma.f64 t z (*.f64 y x)))) |
(fma.f64 (neg.f64 y) (neg.f64 x) (*.f64 t z)) |
(fma.f64 (neg.f64 t) (neg.f64 z) (*.f64 y x)) |
(fma.f64 (neg.f64 z) (neg.f64 t) (*.f64 y x)) |
(fma.f64 (neg.f64 x) (neg.f64 y) (*.f64 t z)) |
(fma.f64 t z (*.f64 y x)) |
(fma.f64 z t (*.f64 y x)) |
(fma.f64 y x (*.f64 t z)) |
(fma.f64 x y (*.f64 t z)) |
(-.f64 (*.f64 t z) (*.f64 (neg.f64 x) y)) |
(-.f64 (*.f64 y x) (*.f64 (neg.f64 z) t)) |
(+.f64 (*.f64 t z) (*.f64 y x)) |
(+.f64 (*.f64 y x) (*.f64 t z)) |
t |
z |
(*.f64 (neg.f64 y) (neg.f64 x)) |
(*.f64 (neg.f64 x) (neg.f64 y)) |
(*.f64 y x) |
(*.f64 x y) |
(neg.f64 (*.f64 (neg.f64 x) y)) |
x |
y |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 b a (*.f64 t z))) |
(neg.f64 (neg.f64 (fma.f64 b a (*.f64 t z)))) |
(fma.f64 (neg.f64 t) (neg.f64 z) (*.f64 b a)) |
(fma.f64 (neg.f64 z) (neg.f64 t) (*.f64 b a)) |
(fma.f64 (neg.f64 a) (neg.f64 b) (*.f64 t z)) |
(fma.f64 (neg.f64 b) (neg.f64 a) (*.f64 t z)) |
(fma.f64 b a (*.f64 t z)) |
(fma.f64 a b (*.f64 t z)) |
(fma.f64 t z (*.f64 b a)) |
(fma.f64 z t (*.f64 b a)) |
(-.f64 (*.f64 b a) (*.f64 (neg.f64 z) t)) |
(-.f64 (*.f64 t z) (*.f64 (neg.f64 a) b)) |
(+.f64 (*.f64 b a) (*.f64 t z)) |
(+.f64 (*.f64 t z) (*.f64 b a)) |
(*.f64 (neg.f64 a) (neg.f64 b)) |
(*.f64 (neg.f64 b) (neg.f64 a)) |
(*.f64 b a) |
(*.f64 a b) |
(neg.f64 (*.f64 (neg.f64 a) b)) |
Compiled 677 to 340 computations (49.8% saved)
5 alts after pruning (1 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 88 | 1 | 89 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 3 | 3 |
| Done | 0 | 1 | 1 |
| Total | 88 | 5 | 93 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 68.7% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 z t (*.f64 b a))) |
| ✓ | 63.6% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
| ✓ | 69.2% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
| ▶ | 33.1% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
| ✓ | 38.4% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
Compiled 76 to 73 computations (3.9% saved)
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 136 | 583 |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (* t z) (* x y)) (*.f64 t z)) |
(*.f64 t z) |
t |
z |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (fma.f64 t z (*.f64 x y)))) |
#s(approx (+ (* t z) (* x y)) (*.f64 t z)) |
#s(approx (+ (* t z) (* x y)) (fma.f64 t z (*.f64 x y))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x (+.f64 y (+.f64 (/.f64 (*.f64 a b) x) (/.f64 (*.f64 t z) x))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 x (+.f64 y (/.f64 (*.f64 t z) x)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 t z)) x)))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) x)))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 y (+.f64 x (+.f64 (/.f64 (*.f64 a b) y) (/.f64 (*.f64 t z) y))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 y (+.f64 x (/.f64 (*.f64 t z) y)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 t z)) y)))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 t z) y)))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
#s(approx z z) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 z (+.f64 t (+.f64 (/.f64 (*.f64 a b) z) (/.f64 (*.f64 x y) z))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 z (+.f64 t (/.f64 (*.f64 x y) z)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 x y)) z)))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 z (fma.f64 #s(literal -1 binary64) t (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) z)))))) |
#s(approx t t) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 t (+.f64 z (+.f64 (/.f64 (*.f64 a b) t) (/.f64 (*.f64 x y) t))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 t (+.f64 z (/.f64 (*.f64 x y) t)))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 t (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 a b (*.f64 x y)) t)))))) |
#s(approx (+ (* t z) (* x y)) (*.f64 #s(literal -1 binary64) (*.f64 t (fma.f64 #s(literal -1 binary64) z (*.f64 #s(literal -1 binary64) (/.f64 (*.f64 x y) t)))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 a b)) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 a (+.f64 b (+.f64 (/.f64 (*.f64 t z) a) (/.f64 (*.f64 x y) a))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 a (fma.f64 #s(literal -1 binary64) b (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 t z (*.f64 x y)) a)))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 b (+.f64 a (+.f64 (/.f64 (*.f64 t z) b) (/.f64 (*.f64 x y) b))))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 #s(literal -1 binary64) (*.f64 b (fma.f64 #s(literal -1 binary64) a (*.f64 #s(literal -1 binary64) (/.f64 (fma.f64 t z (*.f64 x y)) b)))))) |
18 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 11.0ms | z | @ | 0 | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) (* t z) t z) |
| 1.0ms | t | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) (* t z) t z) |
| 1.0ms | z | @ | -inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) (* t z) t z) |
| 1.0ms | z | @ | inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) (* t z) t z) |
| 0.0ms | t | @ | inf | ((+ (+ (* x y) (* z t)) (* a b)) (+ (* t z) (* x y)) (* t z) t z) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 16 | 39 |
| 0 | 17 | 39 |
| 1 | 92 | 39 |
| 2 | 292 | 39 |
| 3 | 824 | 39 |
| 4 | 1203 | 39 |
| 5 | 1541 | 39 |
| 6 | 4221 | 39 |
| 0 | 8297 | 35 |
| 1 | 14264 | 35 |
| 1× | saturated |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (* t z) (* x y)) (*.f64 t z)) |
(*.f64 t z) |
t |
z |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (* t z) (* x y)) (*.f64 t z)) |
(*.f64 (neg.f64 t) (neg.f64 z)) |
(*.f64 (neg.f64 z) (neg.f64 t)) |
(*.f64 t z) |
(*.f64 z t) |
(neg.f64 (*.f64 (neg.f64 z) t)) |
t |
z |
Compiled 315 to 162 computations (48.6% saved)
6 alts after pruning (1 fresh and 5 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 30 | 1 | 31 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 4 | 4 |
| Total | 30 | 6 | 36 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 68.7% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 z t (*.f64 b a))) |
| ✓ | 63.6% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
| ✓ | 69.2% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
| 32.9% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) | |
| ✓ | 33.1% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
| ✓ | 38.4% | #s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
Compiled 149 to 123 computations (17.4% saved)
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 z t (*.f64 b a))) |
(fma.f64 z t (fma.f64 b a (*.f64 y x))) |
(+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
| Outputs |
|---|
(fma.f64 z t (fma.f64 b a (*.f64 y x))) |
11 calls:
| 6.0ms | a |
| 5.0ms | x |
| 3.0ms | y |
| 3.0ms | b |
| 3.0ms | (+.f64 (*.f64 x y) (*.f64 z t)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.6% | 1 | (*.f64 a b) |
| 99.6% | 1 | (*.f64 z t) |
| 99.6% | 1 | (*.f64 x y) |
| 99.6% | 1 | (+.f64 (*.f64 x y) (*.f64 z t)) |
| 99.6% | 1 | (+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
| 99.6% | 1 | x |
| 99.6% | 1 | y |
| 99.6% | 1 | z |
| 99.6% | 1 | t |
| 99.6% | 1 | a |
| 99.6% | 1 | b |
Compiled 33 to 77 computations (-133.3% saved)
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 z t (*.f64 b a))) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 z t (*.f64 b a))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
11 calls:
| 50.0ms | b |
| 37.0ms | (+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
| 4.0ms | (*.f64 a b) |
| 3.0ms | a |
| 2.0ms | z |
| Accuracy | Segments | Branch |
|---|---|---|
| 89.0% | 3 | (*.f64 a b) |
| 87.6% | 3 | (*.f64 z t) |
| 90.8% | 3 | (*.f64 x y) |
| 84.5% | 4 | (+.f64 (*.f64 x y) (*.f64 z t)) |
| 76.1% | 3 | (+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
| 85.4% | 3 | x |
| 85.3% | 3 | y |
| 88.8% | 4 | z |
| 83.3% | 3 | t |
| 82.8% | 3 | a |
| 83.3% | 3 | b |
Compiled 33 to 77 computations (-133.3% saved)
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 t z (*.f64 x y))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
1 calls:
| 2.0ms | (*.f64 x y) |
| Accuracy | Segments | Branch |
|---|---|---|
| 90.8% | 3 | (*.f64 x y) |
Compiled 3 to 7 computations (-133.3% saved)
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 x y))) |
1 calls:
| 2.0ms | (*.f64 x y) |
| Accuracy | Segments | Branch |
|---|---|---|
| 90.0% | 3 | (*.f64 x y) |
Compiled 3 to 7 computations (-133.3% saved)
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (fma.f64 a b (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
6 calls:
| 3.0ms | z |
| 2.0ms | x |
| 2.0ms | y |
| 2.0ms | (*.f64 a b) |
| 2.0ms | (*.f64 x y) |
| Accuracy | Segments | Branch |
|---|---|---|
| 77.1% | 3 | y |
| 77.4% | 3 | x |
| 72.7% | 3 | z |
| 68.7% | 1 | (*.f64 z t) |
| 68.7% | 1 | (*.f64 a b) |
| 83.8% | 3 | (*.f64 x y) |
Compiled 12 to 39 computations (-225% saved)
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) (*.f64 x y)) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
11 calls:
| 72.0ms | y |
| 2.0ms | (+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
| 2.0ms | a |
| 2.0ms | b |
| 2.0ms | z |
| Accuracy | Segments | Branch |
|---|---|---|
| 61.8% | 4 | (*.f64 a b) |
| 56.4% | 4 | (*.f64 z t) |
| 56.3% | 4 | z |
| 49.0% | 5 | (+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
| 51.1% | 3 | y |
| 57.5% | 5 | x |
| 57.3% | 5 | a |
| 56.4% | 5 | (+.f64 (*.f64 x y) (*.f64 z t)) |
| 58.0% | 5 | b |
| 51.1% | 3 | t |
| 58.0% | 3 | (*.f64 x y) |
Compiled 33 to 77 computations (-133.3% saved)
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* t z) (* x y)) (*.f64 t z))) |
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
1 calls:
| 1.0ms | (*.f64 a b) |
| Accuracy | Segments | Branch |
|---|---|---|
| 58.1% | 3 | (*.f64 a b) |
Compiled 3 to 7 computations (-133.3% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
| Outputs |
|---|
#s(approx (+ (+ (* x y) (* z t)) (* a b)) #s(approx (+ (* a b) (* x y)) (*.f64 a b))) |
11 calls:
| 9.0ms | z |
| 1.0ms | x |
| 1.0ms | b |
| 1.0ms | y |
| 1.0ms | a |
| Accuracy | Segments | Branch |
|---|---|---|
| 38.4% | 1 | (+.f64 (+.f64 (*.f64 x y) (*.f64 z t)) (*.f64 a b)) |
| 38.4% | 1 | t |
| 38.4% | 1 | y |
| 38.4% | 1 | (+.f64 (*.f64 x y) (*.f64 z t)) |
| 38.4% | 1 | a |
| 38.4% | 1 | x |
| 38.4% | 1 | z |
| 38.4% | 1 | (*.f64 z t) |
| 38.4% | 1 | b |
| 38.4% | 1 | (*.f64 x y) |
| 38.4% | 1 | (*.f64 a b) |
Compiled 33 to 77 computations (-133.3% saved)
| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 10.0ms | 8.574026723989476e+46 | 1.5235722375724e+48 |
| 6.0ms | -0.7412973826978356 | -0.3685845140015757 |
| 8.0ms | 192× | 0 | valid |
Compiled 350 to 368 computations (-5.1% saved)
ival-mult!: 2.0ms (73.8% of total)ival-add!: 1.0ms (36.9% of total)adjust: 0.0ms (0% of total)| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 1.0ms | 8.574026723989476e+46 | 1.5235722375724e+48 |
| 0.0ms | -0.7412973826978356 | -0.3685845140015757 |
Compiled 350 to 368 computations (-5.1% saved)
| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 1.0ms | 8.574026723989476e+46 | 1.5235722375724e+48 |
| 2.0ms | -0.7412973826978356 | -0.3685845140015757 |
| 1.0ms | 16× | 0 | valid |
Compiled 350 to 368 computations (-5.1% saved)
adjust: 0.0ms (0% of total)ival-add!: 0.0ms (0% of total)ival-mult!: 0.0ms (0% of total)| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 8.0ms | 8.574026723989476e+46 | 1.5235722375724e+48 |
| 14.0ms | -5.383438913062144e+105 | -4.272700245567405e+100 |
| 9.0ms | 208× | 0 | valid |
Compiled 446 to 468 computations (-4.9% saved)
ival-mult!: 2.0ms (62% of total)ival-add!: 1.0ms (31% of total)adjust: 0.0ms (0% of total)| 3× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 13.0ms | 2.9805024805583145e+30 | 3.6680198450799464e+30 |
| 10.0ms | 4.780305520475145e-160 | 1.9868922416637748e-156 |
| 11.0ms | -3.2148425996955005e-10 | -1.0474803788148808e-11 |
| 12.0ms | 288× | 0 | valid |
Compiled 582 to 579 computations (0.5% saved)
ival-mult!: 3.0ms (74.2% of total)ival-add!: 1.0ms (24.7% of total)adjust: 0.0ms (0% of total)| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 17.0ms | 1.0877820309131807e+51 | 6.27581580237907e+61 |
| 1.0ms | -3.2148425996955005e-10 | -1.0474803788148808e-11 |
| 7.0ms | 160× | 0 | valid |
Compiled 592 to 564 computations (4.7% saved)
ival-mult!: 2.0ms (89.5% of total)ival-add!: 1.0ms (44.8% of total)adjust: 0.0ms (0% of total)| 1× | fuel |
Compiled 96 to 64 computations (33.3% saved)
(sort a b)
(sort z t)
(sort x y)
Compiled 1 529 to 1 131 computations (26% saved)
Loading profile data...