math.cube on complex, imaginary part

Time bar (total: 1.7s)

analyze0.0ms (0%)

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 22 to 12 computations (45.5% saved)

Precisions
Click to see histograms. Total time spent on operations: 0.0ms
Operation ival-sub, time spent: 0.0ms, 0.0% of total-time
Operation ival-add, time spent: 0.0ms, 0.0% of total-time
Operation ival-mult, time spent: 0.0ms, 0.0% of total-time
Operation const, time spent: 0.0ms, 0.0% of total-time

sample1.5s (89.2%)

Results
923.0ms4587×256valid
502.0ms3668×256infinite
0.0ms256valid
Precisions
Click to see histograms. Total time spent on operations: 708.0ms
Operation ival-mult, time spent: 552.0ms, 78.0% of total-time
Operation ival-add, time spent: 95.0ms, 13.0% of total-time
Operation ival-sub, time spent: 53.0ms, 7.0% of total-time
Operation const, time spent: 9.0ms, 1.0% of total-time
Bogosity

preprocess185.0ms (10.8%)

Algorithm
egg-herbie
Rules
1828×unsub-neg
1212×fma-define
838×sub-neg
784×distribute-lft-out
766×distribute-lft-in
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
042563
1136491
2368483
31517309
44607301
56832301
67668301
Stop Event
node limit
Calls
Call 1
Inputs
(+.f64 (*.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) x.im) (*.f64 (+.f64 (*.f64 x.re x.im) (*.f64 x.im x.re)) x.re))
(+.f64 (*.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) x.im) (*.f64 (+.f64 (*.f64 x.re x.im) (*.f64 x.im x.re)) x.re))
(+.f64 (*.f64 (-.f64 (*.f64 (neg.f64 x.re) (neg.f64 x.re)) (*.f64 x.im x.im)) x.im) (*.f64 (+.f64 (*.f64 (neg.f64 x.re) x.im) (*.f64 x.im (neg.f64 x.re))) (neg.f64 x.re)))
(+.f64 (*.f64 (-.f64 (*.f64 x.re x.re) (*.f64 (neg.f64 x.im) (neg.f64 x.im))) (neg.f64 x.im)) (*.f64 (+.f64 (*.f64 x.re (neg.f64 x.im)) (*.f64 (neg.f64 x.im) x.re)) x.re))
(neg.f64 (+.f64 (*.f64 (-.f64 (*.f64 (neg.f64 x.re) (neg.f64 x.re)) (*.f64 x.im x.im)) x.im) (*.f64 (+.f64 (*.f64 (neg.f64 x.re) x.im) (*.f64 x.im (neg.f64 x.re))) (neg.f64 x.re))))
(neg.f64 (+.f64 (*.f64 (-.f64 (*.f64 x.re x.re) (*.f64 (neg.f64 x.im) (neg.f64 x.im))) (neg.f64 x.im)) (*.f64 (+.f64 (*.f64 x.re (neg.f64 x.im)) (*.f64 (neg.f64 x.im) x.re)) x.re)))
(+.f64 (*.f64 (-.f64 (*.f64 x.im x.im) (*.f64 x.re x.re)) x.re) (*.f64 (+.f64 (*.f64 x.im x.re) (*.f64 x.re x.im)) x.im))
Outputs
(+.f64 (*.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) x.im) (*.f64 (+.f64 (*.f64 x.re x.im) (*.f64 x.im x.re)) x.re))
(fma.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) x.im (*.f64 x.re (fma.f64 x.re x.im (*.f64 x.re x.im))))
(fma.f64 x.re (*.f64 #s(literal 2 binary64) (*.f64 x.re x.im)) (*.f64 x.im (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im))))
(fma.f64 x.re (*.f64 x.re (*.f64 x.im #s(literal 2 binary64))) (*.f64 x.im (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im))))
(-.f64 (*.f64 (*.f64 x.re (*.f64 x.re x.im)) #s(literal 3 binary64)) (pow.f64 x.im #s(literal 3 binary64)))
(-.f64 (*.f64 x.re (*.f64 x.im (*.f64 x.re #s(literal 3 binary64)))) (pow.f64 x.im #s(literal 3 binary64)))
(+.f64 (*.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) x.im) (*.f64 (+.f64 (*.f64 x.re x.im) (*.f64 x.im x.re)) x.re))
(fma.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) x.im (*.f64 x.re (fma.f64 x.re x.im (*.f64 x.re x.im))))
(fma.f64 x.re (*.f64 #s(literal 2 binary64) (*.f64 x.re x.im)) (*.f64 x.im (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im))))
(fma.f64 x.re (*.f64 x.re (*.f64 x.im #s(literal 2 binary64))) (*.f64 x.im (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im))))
(-.f64 (*.f64 (*.f64 x.re (*.f64 x.re x.im)) #s(literal 3 binary64)) (pow.f64 x.im #s(literal 3 binary64)))
(-.f64 (*.f64 x.re (*.f64 x.im (*.f64 x.re #s(literal 3 binary64)))) (pow.f64 x.im #s(literal 3 binary64)))
(+.f64 (*.f64 (-.f64 (*.f64 (neg.f64 x.re) (neg.f64 x.re)) (*.f64 x.im x.im)) x.im) (*.f64 (+.f64 (*.f64 (neg.f64 x.re) x.im) (*.f64 x.im (neg.f64 x.re))) (neg.f64 x.re)))
(fma.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) x.im (*.f64 x.re (fma.f64 x.re x.im (*.f64 x.re x.im))))
(fma.f64 x.re (*.f64 #s(literal 2 binary64) (*.f64 x.re x.im)) (*.f64 x.im (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im))))
(fma.f64 x.re (*.f64 x.re (*.f64 x.im #s(literal 2 binary64))) (*.f64 x.im (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im))))
(-.f64 (*.f64 (*.f64 x.re (*.f64 x.re x.im)) #s(literal 3 binary64)) (pow.f64 x.im #s(literal 3 binary64)))
(-.f64 (*.f64 x.re (*.f64 x.im (*.f64 x.re #s(literal 3 binary64)))) (pow.f64 x.im #s(literal 3 binary64)))
(+.f64 (*.f64 (-.f64 (*.f64 x.re x.re) (*.f64 (neg.f64 x.im) (neg.f64 x.im))) (neg.f64 x.im)) (*.f64 (+.f64 (*.f64 x.re (neg.f64 x.im)) (*.f64 (neg.f64 x.im) x.re)) x.re))
(fma.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) (neg.f64 x.im) (*.f64 x.re (fma.f64 x.re (neg.f64 x.im) (*.f64 x.re (neg.f64 x.im)))))
(fma.f64 x.re (*.f64 #s(literal 2 binary64) (*.f64 x.re (neg.f64 x.im))) (*.f64 x.im (-.f64 (*.f64 x.im x.im) (*.f64 x.re x.re))))
(fma.f64 x.im (-.f64 (*.f64 x.im x.im) (*.f64 x.re x.re)) (*.f64 (*.f64 x.re x.re) (*.f64 x.im #s(literal -2 binary64))))
(+.f64 (pow.f64 x.im #s(literal 3 binary64)) (*.f64 (*.f64 x.re (*.f64 x.re (neg.f64 x.im))) #s(literal 3 binary64)))
(-.f64 (pow.f64 x.im #s(literal 3 binary64)) (*.f64 x.re (*.f64 x.im (*.f64 x.re #s(literal 3 binary64)))))
(neg.f64 (+.f64 (*.f64 (-.f64 (*.f64 (neg.f64 x.re) (neg.f64 x.re)) (*.f64 x.im x.im)) x.im) (*.f64 (+.f64 (*.f64 (neg.f64 x.re) x.im) (*.f64 x.im (neg.f64 x.re))) (neg.f64 x.re))))
(fma.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) (neg.f64 x.im) (*.f64 x.re (fma.f64 x.re (neg.f64 x.im) (*.f64 x.re (neg.f64 x.im)))))
(fma.f64 x.re (*.f64 #s(literal 2 binary64) (*.f64 x.re (neg.f64 x.im))) (*.f64 x.im (-.f64 (*.f64 x.im x.im) (*.f64 x.re x.re))))
(fma.f64 x.im (-.f64 (*.f64 x.im x.im) (*.f64 x.re x.re)) (*.f64 (*.f64 x.re x.re) (*.f64 x.im #s(literal -2 binary64))))
(+.f64 (pow.f64 x.im #s(literal 3 binary64)) (*.f64 (*.f64 x.re (*.f64 x.re (neg.f64 x.im))) #s(literal 3 binary64)))
(-.f64 (pow.f64 x.im #s(literal 3 binary64)) (*.f64 x.re (*.f64 x.im (*.f64 x.re #s(literal 3 binary64)))))
(neg.f64 (+.f64 (*.f64 (-.f64 (*.f64 x.re x.re) (*.f64 (neg.f64 x.im) (neg.f64 x.im))) (neg.f64 x.im)) (*.f64 (+.f64 (*.f64 x.re (neg.f64 x.im)) (*.f64 (neg.f64 x.im) x.re)) x.re)))
(fma.f64 (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im)) x.im (*.f64 x.re (fma.f64 x.re x.im (*.f64 x.re x.im))))
(fma.f64 x.re (*.f64 #s(literal 2 binary64) (*.f64 x.re x.im)) (*.f64 x.im (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im))))
(fma.f64 x.re (*.f64 x.re (*.f64 x.im #s(literal 2 binary64))) (*.f64 x.im (-.f64 (*.f64 x.re x.re) (*.f64 x.im x.im))))
(-.f64 (*.f64 (*.f64 x.re (*.f64 x.re x.im)) #s(literal 3 binary64)) (pow.f64 x.im #s(literal 3 binary64)))
(-.f64 (*.f64 x.re (*.f64 x.im (*.f64 x.re #s(literal 3 binary64)))) (pow.f64 x.im #s(literal 3 binary64)))
(+.f64 (*.f64 (-.f64 (*.f64 x.im x.im) (*.f64 x.re x.re)) x.re) (*.f64 (+.f64 (*.f64 x.im x.re) (*.f64 x.re x.im)) x.im))
(fma.f64 (-.f64 (*.f64 x.im x.im) (*.f64 x.re x.re)) x.re (*.f64 x.im (fma.f64 x.re x.im (*.f64 x.re x.im))))
(fma.f64 x.re (-.f64 (*.f64 x.im x.im) (*.f64 x.re x.re)) (*.f64 x.im (*.f64 #s(literal 2 binary64) (*.f64 x.re x.im))))
(fma.f64 x.re (-.f64 (*.f64 x.im x.im) (*.f64 x.re x.re)) (*.f64 (*.f64 x.im x.im) (*.f64 #s(literal 2 binary64) x.re)))
(-.f64 (*.f64 (*.f64 x.re (*.f64 x.im x.im)) #s(literal 3 binary64)) (pow.f64 x.re #s(literal 3 binary64)))
(-.f64 (*.f64 x.re (*.f64 x.im (*.f64 x.im #s(literal 3 binary64)))) (pow.f64 x.re #s(literal 3 binary64)))
Symmetry

(abs x.re)

(negabs x.im)

Compiler

Compiled 76 to 12 computations (84.2% saved)

Precisions
Click to see histograms. Total time spent on operations: 16.0ms
Operation ival-mult, time spent: 12.0ms, 75.0% of total-time
Operation ival-add, time spent: 3.0ms, 19.0% of total-time
Operation ival-sub, time spent: 2.0ms, 13.0% of total-time
Operation const, time spent: 0.0ms, 0.0% of total-time

end0.0ms (0%)

Profiling

Loading profile data...