Data.Array.Repa.Algorithms.ColorRamp:rampColorHotToCold from repa-algorithms-3.4.0.1, C

Time bar (total: 5.4s)

analyze74.0ms (1.4%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
50%49.9%49.9%0.1%0%0%0%3
50%49.9%49.9%0.1%0%0%0%4
50%49.9%49.9%0.1%0%0%0%5
75%74.9%25%0.1%0%0%0%6
75%74.9%25%0.1%0%0%0%7
75%74.9%25%0.1%0%0%0%8
87.5%87.4%12.5%0.1%0%0%0%9
87.5%87.4%12.5%0.1%0%0%0%10
87.5%87.4%12.5%0.1%0%0%0%11
93.8%93.6%6.2%0.1%0%0%0%12
Compiler

Compiled 17 to 13 computations (23.5% saved)

sample5.1s (94.4%)

Results
1.6s8256×0valid-rival
828.0ms8253×0valid-sollya
15.0ms0exit-sollya
Bogosity

preprocess151.0ms (2.8%)

Algorithm
egg-herbie
Rules
699×div-sub
374×fma-define
258×associate-*r/
246×sub-neg
243×associate--r+
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
057591
1144491
2439459
31309451
43926388
Stop Event
node limit
Calls
Call 1
Inputs
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) z)) y))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) z)) y))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 (neg.f64 x) (*.f64 y #s(literal 1/4 binary64))) z)) y))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 (neg.f64 y) #s(literal 1/4 binary64))) z)) (neg.f64 y)))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) (neg.f64 z))) y))
(neg.f64 (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 (neg.f64 x) (*.f64 y #s(literal 1/4 binary64))) z)) y)))
(neg.f64 (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 (neg.f64 y) #s(literal 1/4 binary64))) z)) (neg.f64 y))))
(neg.f64 (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) (neg.f64 z))) y)))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 y (*.f64 x #s(literal 1/4 binary64))) z)) x))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 z (*.f64 y #s(literal 1/4 binary64))) x)) y))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 z #s(literal 1/4 binary64))) y)) z))
Outputs
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) z)) y))
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 (+.f64 x (-.f64 (*.f64 y #s(literal 1/4 binary64)) z)) y)))
(fma.f64 #s(literal 4 binary64) (/.f64 (-.f64 (fma.f64 y #s(literal 1/4 binary64) x) z) y) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (fma.f64 z #s(literal -4 binary64) (fma.f64 #s(literal 4 binary64) x y)) y))
(+.f64 (*.f64 (/.f64 #s(literal 4 binary64) y) (-.f64 x z)) #s(literal 2 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) z)) y))
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 (+.f64 x (-.f64 (*.f64 y #s(literal 1/4 binary64)) z)) y)))
(fma.f64 #s(literal 4 binary64) (/.f64 (-.f64 (fma.f64 y #s(literal 1/4 binary64) x) z) y) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (fma.f64 z #s(literal -4 binary64) (fma.f64 #s(literal 4 binary64) x y)) y))
(+.f64 (*.f64 (/.f64 #s(literal 4 binary64) y) (-.f64 x z)) #s(literal 2 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 (neg.f64 x) (*.f64 y #s(literal 1/4 binary64))) z)) y))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (+.f64 (neg.f64 x) (-.f64 (*.f64 y #s(literal 1/4 binary64)) z))) y))
(fma.f64 #s(literal 4 binary64) (/.f64 (-.f64 (-.f64 (*.f64 y #s(literal 1/4 binary64)) x) z) y) #s(literal 1 binary64))
(fma.f64 #s(literal 4 binary64) (/.f64 (-.f64 (-.f64 (*.f64 y #s(literal 1/4 binary64)) z) x) y) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (fma.f64 z #s(literal -4 binary64) (fma.f64 x #s(literal -4 binary64) y)) y))
(+.f64 (/.f64 (*.f64 #s(literal -4 binary64) (+.f64 x z)) y) #s(literal 2 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 (neg.f64 y) #s(literal 1/4 binary64))) z)) (neg.f64 y)))
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 (-.f64 (+.f64 x (*.f64 #s(literal 1/4 binary64) (neg.f64 y))) z) (neg.f64 y))))
(-.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 (+.f64 x (-.f64 (*.f64 y #s(literal -1/4 binary64)) z)) y)))
(fma.f64 (-.f64 x (fma.f64 y #s(literal 1/4 binary64) z)) (/.f64 #s(literal -4 binary64) y) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (fma.f64 #s(literal 4 binary64) z (fma.f64 x #s(literal -4 binary64) y)) y))
(-.f64 #s(literal 2 binary64) (*.f64 (/.f64 #s(literal 4 binary64) y) (-.f64 x z)))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) (neg.f64 z))) y))
(fma.f64 #s(literal 4 binary64) (/.f64 (+.f64 x (fma.f64 y #s(literal 1/4 binary64) z)) y) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (fma.f64 #s(literal 4 binary64) x (fma.f64 #s(literal 4 binary64) z y)) y))
(+.f64 (*.f64 (/.f64 #s(literal 4 binary64) y) (+.f64 x z)) #s(literal 2 binary64))
(neg.f64 (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 (neg.f64 x) (*.f64 y #s(literal 1/4 binary64))) z)) y)))
(+.f64 #s(literal -1 binary64) (neg.f64 (/.f64 (*.f64 #s(literal 4 binary64) (+.f64 (neg.f64 x) (-.f64 (*.f64 y #s(literal 1/4 binary64)) z))) y)))
(-.f64 #s(literal -1 binary64) (*.f64 (-.f64 (-.f64 (*.f64 y #s(literal 1/4 binary64)) x) z) (/.f64 #s(literal 4 binary64) y)))
(fma.f64 #s(literal -4 binary64) (/.f64 (-.f64 (-.f64 (*.f64 y #s(literal 1/4 binary64)) z) x) y) #s(literal -1 binary64))
(-.f64 #s(literal -1 binary64) (/.f64 (fma.f64 z #s(literal -4 binary64) (fma.f64 x #s(literal -4 binary64) y)) y))
(-.f64 #s(literal -2 binary64) (/.f64 (*.f64 #s(literal -4 binary64) (+.f64 x z)) y))
(neg.f64 (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 (neg.f64 y) #s(literal 1/4 binary64))) z)) (neg.f64 y))))
(neg.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 (-.f64 (+.f64 x (*.f64 #s(literal 1/4 binary64) (neg.f64 y))) z) (neg.f64 y)))))
(+.f64 #s(literal -1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 (+.f64 x (-.f64 (*.f64 y #s(literal -1/4 binary64)) z)) y)))
(fma.f64 #s(literal 4 binary64) (/.f64 (-.f64 x (fma.f64 y #s(literal 1/4 binary64) z)) y) #s(literal -1 binary64))
(-.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal 4 binary64) z (fma.f64 x #s(literal -4 binary64) y)) y))
(+.f64 (*.f64 (/.f64 #s(literal 4 binary64) y) (-.f64 x z)) #s(literal -2 binary64))
(neg.f64 (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) (neg.f64 z))) y)))
(+.f64 #s(literal -1 binary64) (neg.f64 (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) (neg.f64 z))) y)))
(-.f64 #s(literal -1 binary64) (*.f64 (+.f64 x (fma.f64 y #s(literal 1/4 binary64) z)) (/.f64 #s(literal 4 binary64) y)))
(fma.f64 #s(literal -4 binary64) (/.f64 (+.f64 x (fma.f64 y #s(literal 1/4 binary64) z)) y) #s(literal -1 binary64))
(-.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal 4 binary64) x (fma.f64 #s(literal 4 binary64) z y)) y))
(-.f64 #s(literal -2 binary64) (*.f64 (/.f64 #s(literal 4 binary64) y) (+.f64 x z)))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 y (*.f64 x #s(literal 1/4 binary64))) z)) x))
(fma.f64 #s(literal 4 binary64) (/.f64 (-.f64 (fma.f64 x #s(literal 1/4 binary64) y) z) x) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (fma.f64 z #s(literal -4 binary64) (fma.f64 #s(literal 4 binary64) y x)) x))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 z (*.f64 y #s(literal 1/4 binary64))) x)) y))
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 (-.f64 (+.f64 x (*.f64 #s(literal 1/4 binary64) (neg.f64 y))) z) (neg.f64 y))))
(-.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 (+.f64 x (-.f64 (*.f64 y #s(literal -1/4 binary64)) z)) y)))
(fma.f64 (-.f64 x (fma.f64 y #s(literal 1/4 binary64) z)) (/.f64 #s(literal -4 binary64) y) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (fma.f64 #s(literal 4 binary64) z (fma.f64 x #s(literal -4 binary64) y)) y))
(-.f64 #s(literal 2 binary64) (*.f64 (/.f64 #s(literal 4 binary64) y) (-.f64 x z)))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 z #s(literal 1/4 binary64))) y)) z))
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (+.f64 x (-.f64 (*.f64 #s(literal 1/4 binary64) z) y))) z))
(fma.f64 #s(literal 4 binary64) (/.f64 (-.f64 (fma.f64 #s(literal 1/4 binary64) z x) y) z) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (/.f64 (fma.f64 y #s(literal -4 binary64) (fma.f64 #s(literal 4 binary64) x z)) z))
Compiler

Compiled 16 to 12 computations (25% saved)

eval0.0ms (0%)

Compiler

Compiled 3 to 3 computations (0% saved)

prune3.0ms (0%)

Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) z)) y))
Compiler

Compiled 32 to 24 computations (25% saved)

simplify5.0ms (0.1%)

Algorithm
egg-herbie
Rules
+-commutative
1-exp
*-commutative
sub-neg
neg-sub0
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01849
13049
23449
33649
43749
Stop Event
saturated
Calls
Call 1
Inputs
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) z)) y))
Outputs
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 4 binary64) (-.f64 (+.f64 x (*.f64 y #s(literal 1/4 binary64))) z)) y))

soundness1.0ms (0%)

Stop Event
fuel
Compiler

Compiled 16 to 12 computations (25% saved)

preprocess64.0ms (1.2%)

Compiler

Compiled 64 to 48 computations (25% saved)

end0.0ms (0%)

Profiling

Loading profile data...