Graphics.Rasterific.CubicBezier:isSufficientlyFlat from Rasterific-0.6.1

Time bar (total: 1.1s)

analyze0.0ms (0%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%100%0%0%0%0%0
100%100%0%0%0%0%0%1
Compiler

Compiled 7 to 5 computations (28.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 0.0ms
ival-mult: 0.0ms (0% of total)
const: 0.0ms (0% of total)

sample974.0ms (86.5%)

Results
513.0ms6095×0valid
279.0ms2161×0infinite
Precisions
Click to see histograms. Total time spent on operations: 224.0ms
ival-mult: 211.0ms (94% of total)
const: 10.0ms (4.5% of total)
backward-pass: 3.0ms (1.3% of total)
Bogosity

preprocess42.0ms (3.7%)

Algorithm
egg-herbie
Rules
52×fma-define
22×distribute-lft-neg-in
16×fma-neg
16×associate-*r*
16×distribute-lft-in
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01388
13276
27376
316876
424376
530176
Stop Event
saturated
Calls
Call 1
Inputs
(*.f64 (*.f64 x #s(literal 16 binary64)) x)
(*.f64 (*.f64 x #s(literal 16 binary64)) x)
(*.f64 (*.f64 (neg.f64 x) #s(literal 16 binary64)) (neg.f64 x))
(neg.f64 (*.f64 (*.f64 (neg.f64 x) #s(literal 16 binary64)) (neg.f64 x)))
Outputs
(*.f64 (*.f64 x #s(literal 16 binary64)) x)
(*.f64 x (*.f64 x #s(literal 16 binary64)))
(*.f64 (*.f64 x #s(literal 16 binary64)) x)
(*.f64 x (*.f64 x #s(literal 16 binary64)))
(*.f64 (*.f64 (neg.f64 x) #s(literal 16 binary64)) (neg.f64 x))
(*.f64 x (*.f64 x #s(literal 16 binary64)))
(neg.f64 (*.f64 (*.f64 (neg.f64 x) #s(literal 16 binary64)) (neg.f64 x)))
(*.f64 x (*.f64 x #s(literal -16 binary64)))
Symmetry

(abs x)

explain59.0ms (5.3%)

FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
00-0-x
00-0-(*.f64 x #s(literal 16 binary64))
00-0-(*.f64 (*.f64 x #s(literal 16 binary64)) x)
00-0-#s(literal 16 binary64)
Results
29.0ms382×256valid
10.0ms130×256infinite
Compiler

Compiled 30 to 20 computations (33.3% saved)

Precisions
Click to see histograms. Total time spent on operations: 12.0ms
ival-mult: 11.0ms (95.3% of total)
const: 1.0ms (8.7% of total)

eval0.0ms (0%)

Compiler

Compiled 6 to 4 computations (33.3% saved)

prune1.0ms (0.1%)

Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (*.f64 x #s(literal 16 binary64)) x)
Compiler

Compiled 6 to 4 computations (33.3% saved)

localize27.0ms (2.4%)

Results
15.0ms191×256valid
5.0ms65×256infinite
Compiler

Compiled 12 to 8 computations (33.3% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-mult: 5.0ms (85.8% of total)
const: 1.0ms (17.2% of total)

eval0.0ms (0%)

Compiler

Compiled 1 to 1 computations (0% saved)

prune1.0ms (0.1%)

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%
(*.f64 (*.f64 x #s(literal 16 binary64)) x)
Compiler

Compiled 12 to 8 computations (33.3% saved)

simplify2.0ms (0.2%)

Algorithm
egg-herbie
Rules
*-commutative
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0819
11019
Stop Event
saturated
Calls
Call 1
Inputs
(*.f64 (*.f64 x #s(literal 16 binary64)) x)
Outputs
(*.f64 (*.f64 x #s(literal 16 binary64)) x)
(*.f64 x (*.f64 x #s(literal 16 binary64)))

soundness0.0ms (0%)

Stop Event
done
Compiler

Compiled 6 to 4 computations (33.3% saved)

preprocess19.0ms (1.7%)

Remove

(abs x)

Compiler

Compiled 48 to 32 computations (33.3% saved)

end0.0ms (0%)

Profiling

Loading profile data...