From Warwick Tucker's Validated Numerics

Time bar (total: 6.1s)

analyze0.0ms (0%)

Algorithm
random
Compiler

Compiled 46 to 33 computations (28.3% saved)

sample5.0s (81.6%)

Results
3.9s8256×1valid
Precisions
Click to see histograms. Total time spent on operations: 3.6s
ival-mult: 1.1s (30.6% of total)
ival-pow: 810.0ms (22.7% of total)
ival-add: 715.0ms (20% of total)
ival-div: 398.0ms (11.1% of total)
adjust: 335.0ms (9.4% of total)
ival-neg: 148.0ms (4.1% of total)
...in/eval/compile.rkt:70:19: 61.0ms (1.7% of total)
ival-true: 6.0ms (0.2% of total)
ival-assert: 5.0ms (0.1% of total)
Bogosity

preprocess37.0ms (0.6%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0532
Stop Event
saturated
Calls
Call 1
Inputs
(+.f64 (+.f64 (+.f64 (*.f64 #s(literal 1335/4 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))) (*.f64 (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)) (+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64)))) (*.f64 #s(literal 11/2 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 8 binary64)))) (/.f64 #s(literal 77617 binary64) (*.f64 #s(literal 2 binary64) #s(literal 33096 binary64))))
(+.f64 (+.f64 (+.f64 (*.f64 #s(literal 1335/4 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))) (*.f64 (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)) (+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64)))) (*.f64 #s(literal 11/2 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 8 binary64)))) (/.f64 #s(literal 77617 binary64) (*.f64 #s(literal 2 binary64) #s(literal 33096 binary64))))
Outputs
(+.f64 (+.f64 (+.f64 (*.f64 #s(literal 1335/4 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))) (*.f64 (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)) (+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64)))) (*.f64 #s(literal 11/2 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 8 binary64)))) (/.f64 #s(literal 77617 binary64) (*.f64 #s(literal 2 binary64) #s(literal 33096 binary64))))
#s(literal -54767/66192 binary64)
(+.f64 (+.f64 (+.f64 (*.f64 #s(literal 1335/4 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))) (*.f64 (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)) (+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64)))) (*.f64 #s(literal 11/2 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 8 binary64)))) (/.f64 #s(literal 77617 binary64) (*.f64 #s(literal 2 binary64) #s(literal 33096 binary64))))
#s(literal -54767/66192 binary64)

explain888.0ms (14.5%)

FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
2560-0-(+.f64 (+.f64 (*.f64 #s(literal 1335/4 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))) (*.f64 (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)) (+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64)))) (*.f64 #s(literal 11/2 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 8 binary64))))
00-0-(+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64))))
00-0-(*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64)))
00-0-#s(literal 8 binary64)
00-0-(*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)))
00-0-(pow.f64 #s(literal 33096 binary64) #s(literal 8 binary64))
00-0-(*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))
00-0-#s(literal 11/2 binary64)
00-0-(+.f64 (*.f64 #s(literal 1335/4 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))) (*.f64 (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)) (+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64))))
00-0-#s(literal 77617 binary64)
00-0-#s(literal 33096 binary64)
00-0-(pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))
00-0-(*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))
00-0-(*.f64 #s(literal 1335/4 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))
00-0-#s(literal 1335/4 binary64)
00-0-#s(literal -121 binary64)
00-0-(+.f64 (+.f64 (+.f64 (*.f64 #s(literal 1335/4 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))) (*.f64 (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)) (+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64)))) (*.f64 #s(literal 11/2 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 8 binary64)))) (/.f64 #s(literal 77617 binary64) (*.f64 #s(literal 2 binary64) #s(literal 33096 binary64))))
00-0-(/.f64 #s(literal 77617 binary64) (*.f64 #s(literal 2 binary64) #s(literal 33096 binary64)))
00-0-(*.f64 #s(literal 11/2 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 8 binary64)))
00-0-#s(literal 4 binary64)
00-0-(neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))
00-0-(*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))
00-0-#s(literal 6 binary64)
00-0-#s(literal 2 binary64)
00-0-#s(literal -2 binary64)
00-0-(pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64))
00-0-(+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))))
00-0-(+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64))
00-0-(*.f64 (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)) (+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64)))
00-0-#s(literal 11 binary64)
00-0-(*.f64 #s(literal 2 binary64) #s(literal 33096 binary64))
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
+.f64(+.f64 (+.f64 (*.f64 #s(literal 1335/4 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64))) (*.f64 (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64)) (+.f64 (+.f64 (+.f64 (*.f64 (*.f64 #s(literal 11 binary64) (*.f64 #s(literal 77617 binary64) #s(literal 77617 binary64))) (*.f64 #s(literal 33096 binary64) #s(literal 33096 binary64))) (neg.f64 (pow.f64 #s(literal 33096 binary64) #s(literal 6 binary64)))) (*.f64 #s(literal -121 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 4 binary64)))) #s(literal -2 binary64)))) (*.f64 #s(literal 11/2 binary64) (pow.f64 #s(literal 33096 binary64) #s(literal 8 binary64))))cancellation10
Confusion
Predicted +Predicted -
+2560
-00
Precision
1.0
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+25600
-000
Precision?
1.0
Recall?
1.0
Freqs
test
numberfreq
1256
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Results
388.0ms512×1valid
Compiler

Compiled 618 to 128 computations (79.3% saved)

Precisions
Click to see histograms. Total time spent on operations: 275.0ms
adjust: 137.0ms (49.9% of total)
ival-mult: 58.0ms (21.1% of total)
ival-pow: 34.0ms (12.4% of total)
ival-add: 27.0ms (9.8% of total)
ival-div: 8.0ms (2.9% of total)
ival-neg: 5.0ms (1.8% of total)
...in/eval/compile.rkt:70:19: 4.0ms (1.5% of total)
ival-true: 1.0ms (0.4% of total)
ival-assert: 0.0ms (0% of total)

eval0.0ms (0%)

Compiler

Compiled 1 to 1 computations (0% saved)

prune0.0ms (0%)

Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
#s(literal -54767/66192 binary64)
Compiler

Compiled 1 to 1 computations (0% saved)

simplify5.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
011
Stop Event
saturated
Calls
Call 1
Inputs
#s(literal -54767/66192 binary64)
Outputs
#s(literal -54767/66192 binary64)

localize10.0ms (0.2%)

Results
7.0ms256×0valid
Compiler

Compiled 3 to 3 computations (0% saved)

Precisions
Click to see histograms. Total time spent on operations: 4.0ms
...in/eval/compile.rkt:71:19: 4.0ms (103.4% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

eval0.0ms (0%)

Compiler

Compiled 0 to 0 computations (0% saved)

prune1.0ms (0%)

Pruning

1 alts after pruning (0 fresh and 1 done)

PrunedKeptTotal
New000
Fresh000
Picked011
Done000
Total011
Accuracy
100.0%
Counts
1 → 1
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
#s(literal -54767/66192 binary64)
Compiler

Compiled 46 to 33 computations (28.3% saved)

simplify99.0ms (1.6%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
011
Stop Event
saturated
Calls
Call 1
Inputs
#s(literal -54767/66192 binary64)
Outputs
#s(literal -54767/66192 binary64)

soundness10.0ms (0.2%)

Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0532
Stop Event
done
saturated
Compiler

Compiled 45 to 32 computations (28.9% saved)

preprocess73.0ms (1.2%)

Compiler

Compiled 90 to 64 computations (28.9% saved)

end0.0ms (0%)

Profiling

Loading profile data...