Optimal throwing angle

Time bar (total: 5.3s)

start0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

analyze27.0ms (0.5%)

Memory
-6.6MiB live, 9.4MiB allocated
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
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
25%25%74.9%0.1%0%0%0%3
37.5%37.5%62.4%0.1%0%0%0%4
50%43.7%43.7%0.1%0%12.5%0%5
60.7%53.1%34.3%0.1%0%12.5%0%6
72.2%60.9%23.4%0.1%0%15.6%0%7
79.4%63.2%16.4%0.1%0%20.3%0%8
85.6%67.5%11.3%0.1%0%21.1%0%9
89.6%68.9%8%0.1%0%23%0%10
92.7%71.1%5.6%0.1%0%23.2%0%11
94.8%71.9%4%0.1%0%24.1%0%12
Compiler

Compiled 15 to 13 computations (13.3% saved)

sample27.0ms (0.5%)

Memory
1.6MiB live, 9.1MiB allocated
Samples
20.0ms260×0valid
0.0ms0invalid
Precisions
Click to see histograms. Total time spent on operations: 14.0ms
ival-mult: 4.0ms (28% of total)
const: 3.0ms (21% of total)
ival-div: 2.0ms (14% of total)
ival-atan: 2.0ms (14% of total)
ival-sqrt: 2.0ms (14% of total)
ival-sub: 1.0ms (7% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
Bogosity

explain5.2s (97.7%)

Memory
-91.0MiB live, 2 863.4MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
880-0-(sqrt.f64 (-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H)))
00-0-(*.f64 v v)
00-0-(*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64))
00-0-(atan.f64 (/.f64 v (sqrt.f64 (-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H)))))
00-0-v
00-0-#s(literal 2 binary64)
00-0-(*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H)
00-0-(-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H))
00-0-H
00-0-#s(literal 49/5 binary64)
00-0-(/.f64 v (sqrt.f64 (-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H))))
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
sqrt.f64(sqrt.f64 (-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H)))oflow-rescue880
(-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H))overflow88
(*.f64 v v)overflow88
Confusion
Predicted +Predicted -
+881
-0167
Precision
1.0
Recall
0.9887640449438202
Confusion?
Predicted +Predicted MaybePredicted -
+8801
-00167
Precision?
1.0
Recall?
0.9887640449438202
Freqs
test
numberfreq
0168
188
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Total Time
25.919921875
Average Time
0.10124969482421875
Samples
2.0s22 860×0valid
90.0ms180×5exit
Compiler

Compiled 8 730 to 2 160 computations (75.3% saved)

Precisions
Click to see histograms. Total time spent on operations: 1.4s
ival-mult: 409.0ms (29.5% of total)
const: 311.0ms (22.4% of total)
ival-atan: 204.0ms (14.7% of total)
ival-sqrt: 156.0ms (11.3% of total)
ival-div: 147.0ms (10.6% of total)
ival-sub: 99.0ms (7.1% of total)
ival-true: 21.0ms (1.5% of total)
exact: 15.0ms (1.1% of total)
adjust: 14.0ms (1% of total)
ival-assert: 9.0ms (0.6% of total)

preprocess46.0ms (0.9%)

Memory
-1.0MiB live, 6.6MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02861
16359
211859
322359
439159
563959
686659
7100959
8115459
9118859
10120459
01111
01911
12611
23611
34511
46111
58211
612611
717311
822911
928611
1037511
1141511
1250411
1352611
1453411
053410
Stop Event
iter limit
saturated
iter limit
saturated
Calls
Call 1
Inputs
(atan.f64 (/.f64 v (sqrt.f64 (-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H)))))
Outputs
(atan.f64 (/.f64 v (sqrt.f64 (-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H)))))
(atan.f64 (/.f64 v (sqrt.f64 (fma.f64 #s(literal -98/5 binary64) H (*.f64 v v)))))
Compiler

Compiled 13 to 11 computations (15.4% saved)

eval0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated
Compiler

Compiled 0 to 2 computations (-∞% saved)

prune1.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
66.2%
(atan.f64 (/.f64 v (sqrt.f64 (-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H)))))
Compiler

Compiled 26 to 22 computations (15.4% saved)

simplify21.0ms (0.4%)

Memory
-3.3MiB live, 18.2MiB allocated
Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01113
11813
23613
34613
45413
55713
Stop Event
saturated
Calls
Call 1
Inputs
(atan.f64 (/.f64 v (sqrt.f64 (-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H)))))
Outputs
(atan.f64 (/.f64 v (sqrt.f64 (-.f64 (*.f64 v v) (*.f64 (*.f64 #s(literal 2 binary64) #s(literal 49/5 binary64)) H)))))
(atan.f64 (/.f64 v (sqrt.f64 (-.f64 (*.f64 v v) (*.f64 H (*.f64 #s(literal 49/5 binary64) #s(literal 2 binary64)))))))

soundness0.0ms (0%)

Memory
0.2MiB live, 0.2MiB allocated
Stop Event
fuel
Compiler

Compiled 13 to 11 computations (15.4% saved)

preprocess1.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated
Compiler

Compiled 52 to 44 computations (15.4% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...