
Time bar (total: 3.1s)
| 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 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 4 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 5 |
| 15.4% | 12.5% | 68.6% | 0.1% | 0% | 18.7% | 0% | 6 |
| 23.1% | 18.7% | 62.4% | 0.1% | 0% | 18.7% | 0% | 7 |
| 24% | 18.7% | 59.3% | 0.1% | 0% | 21.8% | 0% | 8 |
| 41.9% | 28.1% | 39% | 0.1% | 0% | 32.8% | 0% | 9 |
| 48.8% | 32.8% | 34.3% | 0.1% | 0% | 32.8% | 0% | 10 |
| 50.6% | 32.8% | 32% | 0.1% | 0% | 35.1% | 0% | 11 |
| 64.9% | 38.2% | 20.7% | 0.1% | 0% | 41% | 0% | 12 |
Compiled 39 to 21 computations (46.2% saved)
| 45.0ms | 244× | 1 | valid |
| 4.0ms | 45× | 0 | invalid |
| 2.0ms | 16× | 0 | valid |
ival-mult: 10.0ms (24.1% of total)adjust: 6.0ms (14.4% of total)ival-cbrt: 6.0ms (14.4% of total)ival-sub: 5.0ms (12% of total)ival-div: 4.0ms (9.6% of total)ival-sqrt: 4.0ms (9.6% of total)ival-add: 4.0ms (9.6% of total)ival-neg: 1.0ms (2.4% of total)ival-assert: 0.0ms (0% of total)ival-true: 0.0ms (0% of total)exact: 0.0ms (0% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 129 | 0 | - | 1 | (-1.5447680357689817e-157 1.365602089299425e-198 -7.781200441258761e+21) | (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) |
| 94 | 4 | (-5.954109145341259e+291 2.9294661647527988e-33 2.8283297241886627e-123) | 51 | (-42188920593.63882 5.588508619828344e-300 4.656356398694054e-12) | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) |
| 89 | 6 | (1.8200557861204678e+252 9.992264828259251e-70 9.4989312458198e-240) | 65 | (1.587258301608196e-15 -2.144093652267245e-244 5.8833588923152766e+200) | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) |
| 83 | 66 | (4.806671496230888e-181 8.62803293751149e-256 7.232051842126124e+71) | 0 | - | (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) |
| 58 | 49 | (-5.954109145341259e+291 2.9294661647527988e-33 2.8283297241886627e-123) | 0 | - | (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) |
| 20 | 0 | - | 20 | (8.473147888869258e+159 9.602543571661585e-90 -3.903645065634869e-226) | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) |
| 19 | 0 | - | 0 | - | (-.f64 (*.f64 g g) (*.f64 h h)) |
| 9 | 0 | - | 9 | (-4.2663954886909055e-115 1.0605846430176643e-272 -7.0622962735821535e-177) | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) |
| 0 | 0 | - | 0 | - | (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) |
| 0 | 0 | - | 0 | - | a |
| 0 | 0 | - | 0 | - | #s(literal 1 binary64) |
| 0 | 0 | - | 0 | - | (*.f64 #s(literal 2 binary64) a) |
| 0 | 5 | (-2.6461286086900193e-179 -2.5753219044903464e-255 4.934066678679055e-113) | 0 | - | (+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
| 0 | 0 | - | 0 | - | (*.f64 h h) |
| 0 | 0 | - | 0 | - | (*.f64 g g) |
| 0 | 0 | - | 0 | - | (neg.f64 g) |
| 0 | 0 | - | 0 | - | #s(literal 2 binary64) |
| 0 | 0 | - | 0 | - | g |
| 0 | 0 | - | 0 | - | h |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
sqrt.f64 | (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) | oflow-rescue | 113 | 0 |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | overflow | 113 | |
| ↳ | (*.f64 g g) | overflow | 113 | |
| ↳ | (*.f64 h h) | overflow | 19 | |
+.f64 | (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) | cancellation | 96 | 0 |
-.f64 | (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) | cancellation | 66 | 0 |
cbrt.f64 | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | oflow-rescue | 42 | 0 |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | overflow | 113 | |
| ↳ | (*.f64 g g) | overflow | 113 | |
| ↳ | (*.f64 h h) | overflow | 19 | |
| ↳ | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) | overflow | 42 | |
cbrt.f64 | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | oflow-rescue | 27 | 0 |
| ↳ | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) | overflow | 27 | |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | overflow | 113 | |
| ↳ | (*.f64 g g) | overflow | 113 | |
| ↳ | (*.f64 h h) | overflow | 19 | |
-.f64 | (-.f64 (*.f64 g g) (*.f64 h h)) | nan-rescue | 19 | 0 |
| ↳ | (*.f64 g g) | overflow | 113 | |
| ↳ | (*.f64 h h) | overflow | 19 | |
sqrt.f64 | (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) | uflow-rescue | 15 | 0 |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | underflow | 15 | |
| ↳ | (*.f64 g g) | underflow | 15 | |
| ↳ | (*.f64 h h) | underflow | 103 | |
cbrt.f64 | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | uflow-rescue | 5 | 0 |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | underflow | 15 | |
| ↳ | (*.f64 h h) | underflow | 103 | |
| ↳ | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | underflow | 41 | |
| ↳ | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) | underflow | 46 | |
| ↳ | (*.f64 g g) | underflow | 15 | |
| ↳ | (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) | underflow | 41 | |
+.f64 | (+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) | cancellation | 5 | 0 |
cbrt.f64 | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | uflow-rescue | 3 | 0 |
| ↳ | (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) | underflow | 53 | |
| ↳ | (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))) | underflow | 56 | |
| ↳ | (-.f64 (*.f64 g g) (*.f64 h h)) | underflow | 15 | |
| ↳ | (*.f64 g g) | underflow | 15 | |
| ↳ | (*.f64 h h) | underflow | 103 | |
| ↳ | (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))) | underflow | 53 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 146 | 2 |
| - | 21 | 87 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 146 | 0 | 2 |
| - | 21 | 0 | 87 |
| number | freq |
|---|---|
| 0 | 89 |
| 1 | 35 |
| 2 | 67 |
| 3 | 42 |
| 4 | 19 |
| 5 | 4 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 339.0ms | 1 068× | 2 | valid |
| 281.0ms | 1 272× | 1 | valid |
| 250.0ms | 600× | 3 | valid |
| 15.0ms | 132× | 0 | valid |
Compiled 6 408 to 936 computations (85.4% saved)
ival-mult: 136.0ms (21.6% of total)adjust: 135.0ms (21.4% of total)ival-cbrt: 79.0ms (12.6% of total)ival-sub: 78.0ms (12.4% of total)ival-add: 70.0ms (11.1% of total)ival-sqrt: 67.0ms (10.6% of total)ival-div: 46.0ms (7.3% of total)ival-neg: 13.0ms (2.1% of total)exact: 3.0ms (0.5% of total)ival-true: 2.0ms (0.3% of total)ival-assert: 1.0ms (0.2% of total)| 1× | egg-herbie |
Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 79 | 292 |
| 1 | 272 | 287 |
| 2 | 858 | 287 |
| 3 | 2888 | 282 |
| 4 | 7209 | 282 |
| 0 | 19 | 37 |
| 0 | 33 | 33 |
| 1 | 66 | 32 |
| 2 | 158 | 32 |
| 3 | 432 | 31 |
| 4 | 1050 | 31 |
| 5 | 1923 | 31 |
| 6 | 2515 | 31 |
| 7 | 4175 | 31 |
| 8 | 5034 | 31 |
| 9 | 5709 | 31 |
| 10 | 6726 | 31 |
| 11 | 7088 | 31 |
| 12 | 7276 | 31 |
| 13 | 7516 | 31 |
| 14 | 7516 | 31 |
| 15 | 7786 | 31 |
| 0 | 8072 | 31 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
| Outputs |
|---|
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
(+.f64 (cbrt.f64 (*.f64 #s(literal -1/2 binary64) (/.f64 (+.f64 (sqrt.f64 (*.f64 (-.f64 g h) (+.f64 h g))) g) a))) (cbrt.f64 (*.f64 (-.f64 (sqrt.f64 (*.f64 (-.f64 g h) (+.f64 h g))) g) (/.f64 #s(literal 1/2 binary64) a)))) |
(abs h)
Compiled 37 to 19 computations (48.6% saved)
Compiled 0 to 3 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| 45.7% | (+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
Compiled 74 to 38 computations (48.6% saved)
| 1× | egg-herbie |
Useful iterations: 6 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 19 | 37 |
| 1 | 37 | 36 |
| 2 | 51 | 36 |
| 3 | 67 | 36 |
| 4 | 79 | 36 |
| 5 | 88 | 36 |
| 6 | 101 | 35 |
| 7 | 112 | 35 |
| 8 | 156 | 35 |
| 9 | 226 | 35 |
| 10 | 229 | 35 |
| 1× | saturated |
| Inputs |
|---|
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
| Outputs |
|---|
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (+.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h)))))) (cbrt.f64 (*.f64 (/.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) a)) (-.f64 (neg.f64 g) (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))))))) |
(+.f64 (cbrt.f64 (*.f64 (/.f64 #s(literal -1 binary64) (*.f64 a #s(literal 2 binary64))) (+.f64 (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) g))) (cbrt.f64 (*.f64 (-.f64 (sqrt.f64 (-.f64 (*.f64 g g) (*.f64 h h))) g) (/.f64 #s(literal 1 binary64) (*.f64 a #s(literal 2 binary64)))))) |
| 1× | fuel |
Compiled 35 to 20 computations (42.9% saved)
(abs h)
Compiled 284 to 158 computations (44.4% saved)
Loading profile data...