
Time bar (total: 2.4s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 0 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 1 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 2 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 3 |
| 25% | 25% | 74.9% | 0.1% | 0% | 0% | 0% | 4 |
| 25% | 25% | 74.9% | 0.1% | 0% | 0% | 0% | 5 |
| 34.4% | 34.3% | 65.5% | 0.1% | 0% | 0% | 0% | 6 |
| 36.7% | 34.3% | 59.3% | 0.1% | 0% | 6.2% | 0% | 7 |
| 40.8% | 38.2% | 55.4% | 0.1% | 0% | 6.2% | 0% | 8 |
| 51.3% | 46.8% | 44.5% | 0.1% | 0% | 8.6% | 0% | 9 |
| 56.5% | 49% | 37.6% | 0.1% | 0% | 13.3% | 0% | 10 |
| 61.9% | 53.1% | 32.7% | 0.1% | 0% | 14% | 0% | 11 |
| 69.7% | 58.2% | 25.3% | 0.1% | 0% | 16.4% | 0% | 12 |
Compiled 40 to 22 computations (45% saved)
| 805.0ms | 8 256× | 0 | valid |
| 85.0ms | 1 014× | 0 | invalid |
ival-mult: 302.0ms (48.3% of total)ival-sub: 97.0ms (15.5% of total)ival-div: 70.0ms (11.2% of total)ival-sqrt: 60.0ms (9.6% of total)ival-neg: 46.0ms (7.4% of total)ival-add: 27.0ms (4.3% of total)exact: 13.0ms (2.1% of total)ival-if: 4.0ms (0.6% of total)adjust: 3.0ms (0.5% of total)ival-assert: 3.0ms (0.5% of total)ival->=: 1.0ms (0.2% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 103 | 0 | - | 1 | (3.24424938748568e-176 -4.193672248846343e-157 2.7937641682773712e-282) | (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c))) |
| 70 | 0 | - | 0 | - | (+.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)))) |
| 58 | 0 | - | 0 | - | (-.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)))) |
| 16 | 1 | (-3.2466194149874685e-250 2132875230544412400.0 -2.5467272565131753e-305) | 2 | (1.2331990377176566e-228 4.854244634537611e+192 -5.648733918263758e+101) | (/.f64 (+.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)))) (*.f64 #s(literal 2 binary64) a)) |
| 14 | 0 | - | 0 | - | (/.f64 (*.f64 #s(literal 2 binary64) c) (-.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c))))) |
| 5 | 0 | - | 0 | - | (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)) |
| 0 | 0 | - | 0 | - | a |
| 0 | 0 | - | 0 | - | (*.f64 #s(literal 2 binary64) c) |
| 0 | 0 | - | 0 | - | (*.f64 b b) |
| 0 | 0 | - | 0 | - | (*.f64 #s(literal 2 binary64) a) |
| 0 | 0 | - | 0 | - | c |
| 0 | 0 | - | 0 | - | (*.f64 #s(literal 4 binary64) a) |
| 0 | 0 | - | 0 | - | (neg.f64 b) |
| 0 | 0 | - | 0 | - | (>=.f64 b #s(literal 0 binary64)) |
| 0 | 0 | - | 0 | - | (if (>=.f64 b #s(literal 0 binary64)) (/.f64 (*.f64 #s(literal 2 binary64) c) (-.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c))))) (/.f64 (+.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)))) (*.f64 #s(literal 2 binary64) a))) |
| 0 | 0 | - | 0 | - | #s(literal 4 binary64) |
| 0 | 0 | - | 0 | - | #s(literal 0 binary64) |
| 0 | 0 | - | 0 | - | (*.f64 (*.f64 #s(literal 4 binary64) a) c) |
| 0 | 0 | - | 0 | - | #s(literal 2 binary64) |
| 0 | 0 | - | 0 | - | b |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
sqrt.f64 | (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c))) | oflow-rescue | 97 | 0 |
| ↳ | (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)) | overflow | 97 | |
| ↳ | (*.f64 (*.f64 #s(literal 4 binary64) a) c) | overflow | 21 | |
| ↳ | (*.f64 b b) | overflow | 87 | |
+.f64 | (+.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)))) | cancellation | 70 | 0 |
-.f64 | (-.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)))) | cancellation | 58 | 0 |
/.f64 | (/.f64 (+.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)))) (*.f64 #s(literal 2 binary64) a)) | u/n | 15 | 0 |
| ↳ | (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)) | underflow | 5 | |
| ↳ | (+.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)))) | underflow | 29 | |
| ↳ | (*.f64 (*.f64 #s(literal 4 binary64) a) c) | underflow | 43 | |
| ↳ | (*.f64 b b) | underflow | 43 | |
/.f64 | (/.f64 (*.f64 #s(literal 2 binary64) c) (-.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c))))) | n/u | 14 | 0 |
| ↳ | (-.f64 (neg.f64 b) (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)))) | underflow | 28 | |
| ↳ | (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)) | underflow | 5 | |
| ↳ | (*.f64 (*.f64 #s(literal 4 binary64) a) c) | underflow | 43 | |
| ↳ | (*.f64 b b) | underflow | 43 | |
sqrt.f64 | (sqrt.f64 (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c))) | uflow-rescue | 5 | 0 |
| ↳ | (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)) | underflow | 5 | |
| ↳ | (*.f64 (*.f64 #s(literal 4 binary64) a) c) | underflow | 43 | |
| ↳ | (*.f64 b b) | underflow | 43 | |
-.f64 | (-.f64 (*.f64 b b) (*.f64 (*.f64 #s(literal 4 binary64) a) c)) | nan-rescue | 5 | 0 |
| ↳ | (*.f64 b b) | overflow | 87 | |
| ↳ | (*.f64 (*.f64 #s(literal 4 binary64) a) c) | overflow | 21 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 76 | 0 |
| - | 115 | 65 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 76 | 0 | 0 |
| - | 115 | 0 | 65 |
| number | freq |
|---|---|
| 0 | 65 |
| 1 | 123 |
| 2 | 63 |
| 3 | 5 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 60.0ms | 166× | 2 | valid |
| 52.0ms | 142× | 0 | valid |
| 49.0ms | 168× | 1 | valid |
| 17.0ms | 36× | 3 | valid |
Compiled 332 to 64 computations (80.7% saved)
ival-mult: 50.0ms (38.4% of total)adjust: 24.0ms (18.4% of total)ival-div: 14.0ms (10.8% of total)ival-sub: 11.0ms (8.5% of total)ival-sqrt: 10.0ms (7.7% of total)ival-add: 10.0ms (7.7% of total)ival-if: 5.0ms (3.8% of total)ival->=: 2.0ms (1.5% of total)ival-neg: 2.0ms (1.5% of total)exact: 1.0ms (0.8% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)| 1× | egg-herbie |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 85 | 393 |
| 1 | 219 | 381 |
| 2 | 540 | 381 |
| 3 | 1092 | 379 |
| 4 | 2334 | 373 |
| 0 | 20 | 38 |
| 0 | 33 | 38 |
| 1 | 57 | 38 |
| 2 | 124 | 38 |
| 3 | 263 | 38 |
| 4 | 510 | 38 |
| 5 | 1589 | 38 |
| 6 | 7914 | 38 |
| 0 | 8056 | 38 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
Loading profile data...