Graphics.Rasterific.QuadraticFormula:discriminant from Rasterific-0.6.1

Time bar (total: 2.4s)

analyze13.0ms (0.6%)

Memory
4.1MiB live, 4.1MiB allocated
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
100%99.9%0%0.1%0%0%0%1
Compiler

Compiled 24 to 19 computations (20.8% saved)

sample2.2s (94.4%)

Memory
-6.5MiB live, 668.3MiB allocated
Samples
487.0ms8 256×0valid-sollya
406.0ms8 256×0valid-baseline
368.0ms8 256×0valid-rival
Bogosity

preprocess94.0ms (4%)

Memory
6.9MiB live, 22.1MiB allocated
Algorithm
egg-herbie
Rules
425×fma-define
216×fmm-def
96×distribute-lft-neg-in
94×associate-*r*
94×cancel-sign-sub-inv
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
038435
1116375
2284375
3713375
41184375
51623375
61715375
71723375
81723375
Stop Event
saturated
Calls
Call 1
Inputs
(-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) z))
(-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) z))
(-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (*.f64 y #s(literal 4 binary64)) z))
(-.f64 (*.f64 x x) (*.f64 (*.f64 (neg.f64 y) #s(literal 4 binary64)) z))
(-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) (neg.f64 z)))
(neg.f64 (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (*.f64 y #s(literal 4 binary64)) z)))
(neg.f64 (-.f64 (*.f64 x x) (*.f64 (*.f64 (neg.f64 y) #s(literal 4 binary64)) z)))
(neg.f64 (-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) (neg.f64 z))))
(-.f64 (*.f64 y y) (*.f64 (*.f64 x #s(literal 4 binary64)) z))
(-.f64 (*.f64 z z) (*.f64 (*.f64 y #s(literal 4 binary64)) x))
(-.f64 (*.f64 x x) (*.f64 (*.f64 z #s(literal 4 binary64)) y))
Outputs
(-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) z))
(fma.f64 x x (*.f64 (*.f64 y #s(literal 4 binary64)) (neg.f64 z)))
(fma.f64 x x (*.f64 y (*.f64 z #s(literal -4 binary64))))
(-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) z))
(fma.f64 x x (*.f64 (*.f64 y #s(literal 4 binary64)) (neg.f64 z)))
(fma.f64 x x (*.f64 y (*.f64 z #s(literal -4 binary64))))
(-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (*.f64 y #s(literal 4 binary64)) z))
(fma.f64 x x (*.f64 (*.f64 y #s(literal 4 binary64)) (neg.f64 z)))
(fma.f64 x x (*.f64 y (*.f64 z #s(literal -4 binary64))))
(-.f64 (*.f64 x x) (*.f64 (*.f64 (neg.f64 y) #s(literal 4 binary64)) z))
(-.f64 (*.f64 x x) (*.f64 z (neg.f64 (*.f64 y #s(literal 4 binary64)))))
(fma.f64 x x (*.f64 y (*.f64 #s(literal 4 binary64) z)))
(fma.f64 x x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
(-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) (neg.f64 z)))
(-.f64 (*.f64 x x) (*.f64 z (neg.f64 (*.f64 y #s(literal 4 binary64)))))
(fma.f64 x x (*.f64 y (*.f64 #s(literal 4 binary64) z)))
(fma.f64 x x (*.f64 (*.f64 y #s(literal 4 binary64)) z))
(neg.f64 (-.f64 (*.f64 (neg.f64 x) (neg.f64 x)) (*.f64 (*.f64 y #s(literal 4 binary64)) z)))
(neg.f64 (fma.f64 x x (*.f64 (*.f64 y #s(literal 4 binary64)) (neg.f64 z))))
(neg.f64 (fma.f64 x x (*.f64 y (*.f64 z #s(literal -4 binary64)))))
(-.f64 (*.f64 (*.f64 y #s(literal 4 binary64)) z) (*.f64 x x))
(neg.f64 (-.f64 (*.f64 x x) (*.f64 (*.f64 (neg.f64 y) #s(literal 4 binary64)) z)))
(neg.f64 (-.f64 (*.f64 x x) (*.f64 z (neg.f64 (*.f64 y #s(literal 4 binary64))))))
(neg.f64 (fma.f64 x x (*.f64 y (*.f64 #s(literal 4 binary64) z))))
(-.f64 (*.f64 y (*.f64 z #s(literal -4 binary64))) (*.f64 x x))
(neg.f64 (-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) (neg.f64 z))))
(neg.f64 (-.f64 (*.f64 x x) (*.f64 z (neg.f64 (*.f64 y #s(literal 4 binary64))))))
(neg.f64 (fma.f64 x x (*.f64 y (*.f64 #s(literal 4 binary64) z))))
(-.f64 (*.f64 y (*.f64 z #s(literal -4 binary64))) (*.f64 x x))
(-.f64 (*.f64 y y) (*.f64 (*.f64 x #s(literal 4 binary64)) z))
(-.f64 (*.f64 y y) (*.f64 z (*.f64 x #s(literal 4 binary64))))
(fma.f64 y y (*.f64 x (*.f64 z #s(literal -4 binary64))))
(fma.f64 x (*.f64 z #s(literal -4 binary64)) (*.f64 y y))
(-.f64 (*.f64 z z) (*.f64 (*.f64 y #s(literal 4 binary64)) x))
(-.f64 (*.f64 z z) (*.f64 y (*.f64 x #s(literal 4 binary64))))
(fma.f64 z z (*.f64 x (*.f64 y #s(literal -4 binary64))))
(fma.f64 y (*.f64 x #s(literal -4 binary64)) (*.f64 z z))
(fma.f64 x (*.f64 y #s(literal -4 binary64)) (*.f64 z z))
(-.f64 (*.f64 x x) (*.f64 (*.f64 z #s(literal 4 binary64)) y))
(fma.f64 x x (*.f64 (*.f64 y #s(literal 4 binary64)) (neg.f64 z)))
(fma.f64 x x (*.f64 y (*.f64 z #s(literal -4 binary64))))
Symmetry

(abs x)

(sort y z)

Compiler

Compiled 12 to 8 computations (33.3% saved)

eval0.0ms (0%)

Memory
0.2MiB live, 0.2MiB allocated
Compiler

Compiled 3 to 3 computations (0% saved)

prune2.0ms (0.1%)

Memory
-18.8MiB live, 0.9MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.2%
(-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) z))
Compiler

Compiled 24 to 16 computations (33.3% saved)

simplify4.0ms (0.2%)

Memory
0.5MiB live, 0.5MiB allocated
Algorithm
egg-herbie
Rules
*-commutative
sub-neg
+-commutative
neg-sub0
neg-mul-1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01437
12237
24037
35037
45837
56137
Stop Event
saturated
Calls
Call 1
Inputs
(-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) z))
Outputs
(-.f64 (*.f64 x x) (*.f64 (*.f64 y #s(literal 4 binary64)) z))

soundness0.0ms (0%)

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

Compiled 12 to 8 computations (33.3% saved)

preprocess18.0ms (0.8%)

Memory
9.9MiB live, 25.6MiB allocated
Remove

(sort y z)

(abs x)

Compiler

Compiled 144 to 96 computations (33.3% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...