Diagrams.Solve.Polynomial:quartForm from diagrams-solve-0.1, D

Time bar (total: 2.3s)

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 21 computations (12.5% saved)

sample2.2s (94%)

Memory
-2.5MiB live, 670.8MiB allocated
Samples
477.0ms8 255×0valid-sollya
405.0ms8 255×0valid-baseline
370.0ms8 255×0valid-rival
0.0ms1valid-baseline
0.0ms1valid-rival
0.0ms1valid-sollya
Bogosity

preprocess105.0ms (4.5%)

Memory
-8.7MiB live, 22.1MiB allocated
Algorithm
egg-herbie
Rules
661×fma-define
378×fmm-def
82×distribute-lft-neg-in
79×unsub-neg
78×associate-*r*
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
041398
183342
2171330
3373330
4780330
51446330
62207330
72262330
82268330
92268330
Stop Event
saturated
Calls
Call 1
Inputs
(-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (/.f64 (*.f64 (neg.f64 x) y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (/.f64 (*.f64 x (neg.f64 y)) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 (neg.f64 z) #s(literal 8 binary64)))
(neg.f64 (-.f64 (/.f64 (*.f64 (neg.f64 x) y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64))))
(neg.f64 (-.f64 (/.f64 (*.f64 x (neg.f64 y)) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64))))
(neg.f64 (-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 (neg.f64 z) #s(literal 8 binary64))))
(-.f64 (/.f64 (*.f64 y x) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (/.f64 (*.f64 z y) #s(literal 2 binary64)) (/.f64 x #s(literal 8 binary64)))
(-.f64 (/.f64 (*.f64 x z) #s(literal 2 binary64)) (/.f64 y #s(literal 8 binary64)))
Outputs
(-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (*.f64 x (/.f64 y #s(literal 2 binary64))) (/.f64 z #s(literal 8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (/.f64 z #s(literal -8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (*.f64 z #s(literal -1/8 binary64)))
(fma.f64 x (*.f64 y #s(literal 1/2 binary64)) (*.f64 z #s(literal -1/8 binary64)))
(-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (*.f64 x (/.f64 y #s(literal 2 binary64))) (/.f64 z #s(literal 8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (/.f64 z #s(literal -8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (*.f64 z #s(literal -1/8 binary64)))
(fma.f64 x (*.f64 y #s(literal 1/2 binary64)) (*.f64 z #s(literal -1/8 binary64)))
(-.f64 (/.f64 (*.f64 (neg.f64 x) y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (*.f64 x (/.f64 (neg.f64 y) #s(literal 2 binary64))) (/.f64 z #s(literal 8 binary64)))
(neg.f64 (fma.f64 y (/.f64 x #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64))))
(fma.f64 x (*.f64 y #s(literal -1/2 binary64)) (*.f64 z #s(literal -1/8 binary64)))
(-.f64 (/.f64 (*.f64 x (neg.f64 y)) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (*.f64 x (/.f64 (neg.f64 y) #s(literal 2 binary64))) (/.f64 z #s(literal 8 binary64)))
(neg.f64 (fma.f64 y (/.f64 x #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64))))
(fma.f64 x (*.f64 y #s(literal -1/2 binary64)) (*.f64 z #s(literal -1/8 binary64)))
(-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 (neg.f64 z) #s(literal 8 binary64)))
(-.f64 (*.f64 x (/.f64 y #s(literal 2 binary64))) (/.f64 (neg.f64 z) #s(literal 8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (*.f64 z #s(literal 1/8 binary64)))
(fma.f64 y (*.f64 x #s(literal 1/2 binary64)) (*.f64 z #s(literal 1/8 binary64)))
(neg.f64 (-.f64 (/.f64 (*.f64 (neg.f64 x) y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64))))
(-.f64 (*.f64 x (/.f64 y #s(literal 2 binary64))) (/.f64 (neg.f64 z) #s(literal 8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (*.f64 z #s(literal 1/8 binary64)))
(fma.f64 y (*.f64 x #s(literal 1/2 binary64)) (*.f64 z #s(literal 1/8 binary64)))
(neg.f64 (-.f64 (/.f64 (*.f64 x (neg.f64 y)) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64))))
(-.f64 (*.f64 x (/.f64 y #s(literal 2 binary64))) (/.f64 (neg.f64 z) #s(literal 8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (*.f64 z #s(literal 1/8 binary64)))
(fma.f64 y (*.f64 x #s(literal 1/2 binary64)) (*.f64 z #s(literal 1/8 binary64)))
(neg.f64 (-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 (neg.f64 z) #s(literal 8 binary64))))
(-.f64 (*.f64 x (/.f64 (neg.f64 y) #s(literal 2 binary64))) (/.f64 z #s(literal 8 binary64)))
(neg.f64 (fma.f64 y (/.f64 x #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64))))
(fma.f64 x (*.f64 y #s(literal -1/2 binary64)) (*.f64 z #s(literal -1/8 binary64)))
(-.f64 (/.f64 (*.f64 y x) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
(-.f64 (*.f64 x (/.f64 y #s(literal 2 binary64))) (/.f64 z #s(literal 8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (/.f64 z #s(literal -8 binary64)))
(fma.f64 y (/.f64 x #s(literal 2 binary64)) (*.f64 z #s(literal -1/8 binary64)))
(fma.f64 x (*.f64 y #s(literal 1/2 binary64)) (*.f64 z #s(literal -1/8 binary64)))
(-.f64 (/.f64 (*.f64 z y) #s(literal 2 binary64)) (/.f64 x #s(literal 8 binary64)))
(-.f64 (*.f64 z (/.f64 y #s(literal 2 binary64))) (/.f64 x #s(literal 8 binary64)))
(fma.f64 z (/.f64 y #s(literal 2 binary64)) (/.f64 x #s(literal -8 binary64)))
(fma.f64 y (/.f64 z #s(literal 2 binary64)) (*.f64 x #s(literal -1/8 binary64)))
(fma.f64 y (*.f64 z #s(literal 1/2 binary64)) (*.f64 x #s(literal -1/8 binary64)))
(-.f64 (/.f64 (*.f64 x z) #s(literal 2 binary64)) (/.f64 y #s(literal 8 binary64)))
(-.f64 (*.f64 x (/.f64 z #s(literal 2 binary64))) (/.f64 y #s(literal 8 binary64)))
(fma.f64 x (/.f64 z #s(literal 2 binary64)) (/.f64 y #s(literal -8 binary64)))
(fma.f64 x (/.f64 z #s(literal 2 binary64)) (*.f64 y #s(literal -1/8 binary64)))
(fma.f64 z (*.f64 x #s(literal 1/2 binary64)) (*.f64 y #s(literal -1/8 binary64)))
Symmetry

(sort x y)

Compiler

Compiled 12 to 9 computations (25% saved)

eval0.0ms (0%)

Memory
0.3MiB live, 0.3MiB allocated
Compiler

Compiled 3 to 3 computations (0% saved)

prune1.0ms (0%)

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

Compiled 24 to 18 computations (25% saved)

simplify2.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01534
11934
22834
33434
43934
54134
Stop Event
saturated
Calls
Call 1
Inputs
(-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))
Outputs
(-.f64 (/.f64 (*.f64 x y) #s(literal 2 binary64)) (/.f64 z #s(literal 8 binary64)))

soundness0.0ms (0%)

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

Compiled 12 to 9 computations (25% saved)

preprocess17.0ms (0.7%)

Memory
8.1MiB live, 23.8MiB allocated
Remove

(sort x y)

Compiler

Compiled 96 to 72 computations (25% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...