System.Random.MWC.Distributions:truncatedExp from mwc-random-0.13.3.2

Time bar (total: 2.0min)

analyze923.0ms (0.8%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.8%0.2%0%0%0%0
0%0%99.8%0.2%0%0%0%1
0%0%99.8%0.2%0%0%0%2
0%0%99.8%0.2%0%0%0%3
0%0%99.8%0.2%0%0%0%4
0%0%99.8%0.2%0%0%0%5
0%0%99.8%0.2%0%0%0%6
0%0%99.8%0.2%0%0%0%7
3.1%3.1%96.7%0.2%0%0%0%8
4.7%4.7%95.1%0.2%0%0%0%9
4.7%4.7%95.1%0.2%0%0%0%10
16.4%16.4%83.4%0.2%0%0%0%11
18.8%17.5%76%0.2%0%6.2%0%12
Compiler

Compiled 18 to 13 computations (27.8% saved)

sample2.0min (98.9%)

Results
4.1s4396×1valid-rival
2.2s4386×1valid-sollya
1.1s3736×0valid-rival
674.0ms3733×0valid-sollya
394.0ms1704×0invalid-rival
1.7s1678×0invalid-sollya
4.0s1659×5exit-rival
8.1s1622×5exit-sollya
468.0ms683×1invalid-rival
1.8s659×1invalid-sollya
247.0ms124×2valid-rival
240.0ms124×2valid-sollya
359.0ms37×5invalid-sollya
170.0ms34×1exit-sollya
145.0ms29×0exit-sollya
Bogosity

preprocess349.0ms (0.3%)

Algorithm
egg-herbie
Rules
1592×fma-neg
430×sub-neg
347×fma-define
315×times-frac
309×distribute-lft-neg-in
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
076912
1161832
2423736
31139734
43217648
55929648
66632648
76888648
87095648
97228648
107300648
Stop Event
node limit
Calls
Call 1
Inputs
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t))
(-.f64 (neg.f64 x) (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) (neg.f64 y)) (*.f64 (neg.f64 y) (exp.f64 z)))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 (neg.f64 z))))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) (neg.f64 t)))
(neg.f64 (-.f64 (neg.f64 x) (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t)))
(neg.f64 (-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) (neg.f64 y)) (*.f64 (neg.f64 y) (exp.f64 z)))) t)))
(neg.f64 (-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 (neg.f64 z))))) t)))
(neg.f64 (-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) (neg.f64 t))))
(-.f64 y (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x (exp.f64 z)))) t))
(-.f64 z (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 x)))) t))
(-.f64 t (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) x))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) z) (*.f64 z (exp.f64 y)))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) t) (*.f64 t (exp.f64 z)))) y))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 t)))) z))
Outputs
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t))
(-.f64 x (/.f64 (log.f64 (fma.f64 y (exp.f64 z) (-.f64 #s(literal 1 binary64) y))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 z)))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 (exp.f64 z) #s(literal -1 binary64)))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (expm1.f64 z))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t))
(-.f64 x (/.f64 (log.f64 (fma.f64 y (exp.f64 z) (-.f64 #s(literal 1 binary64) y))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 z)))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 (exp.f64 z) #s(literal -1 binary64)))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (expm1.f64 z))) t))
(-.f64 (neg.f64 x) (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t))
(-.f64 (neg.f64 x) (/.f64 (log.f64 (fma.f64 y (exp.f64 z) (-.f64 #s(literal 1 binary64) y))) t))
(-.f64 (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 z)))) (neg.f64 t)) x)
(-.f64 (/.f64 (log1p.f64 (*.f64 y (+.f64 (exp.f64 z) #s(literal -1 binary64)))) (neg.f64 t)) x)
(-.f64 (/.f64 (log1p.f64 (*.f64 y (expm1.f64 z))) (neg.f64 t)) x)
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) (neg.f64 y)) (*.f64 (neg.f64 y) (exp.f64 z)))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) (neg.f64 y)) (*.f64 (exp.f64 z) (neg.f64 y)))) t))
(-.f64 x (/.f64 (log.f64 (fma.f64 (exp.f64 z) (neg.f64 y) (+.f64 #s(literal 1 binary64) y))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (-.f64 #s(literal 1 binary64) (exp.f64 z)))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (neg.f64 (expm1.f64 z)))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 (neg.f64 z))))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (/.f64 y (exp.f64 z)))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 (neg.f64 z))))) t))
(-.f64 x (/.f64 (log1p.f64 (-.f64 (/.f64 y (exp.f64 z)) y)) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (expm1.f64 (neg.f64 z)))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) (neg.f64 t)))
(+.f64 x (/.f64 (log.f64 (fma.f64 y (exp.f64 z) (-.f64 #s(literal 1 binary64) y))) t))
(+.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 z)))) t))
(+.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 (exp.f64 z) #s(literal -1 binary64)))) t))
(+.f64 x (/.f64 (log1p.f64 (*.f64 y (expm1.f64 z))) t))
(neg.f64 (-.f64 (neg.f64 x) (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t)))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) (neg.f64 t)))
(+.f64 x (/.f64 (log.f64 (fma.f64 y (exp.f64 z) (-.f64 #s(literal 1 binary64) y))) t))
(+.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 z)))) t))
(+.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 (exp.f64 z) #s(literal -1 binary64)))) t))
(+.f64 x (/.f64 (log1p.f64 (*.f64 y (expm1.f64 z))) t))
(neg.f64 (-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) (neg.f64 y)) (*.f64 (neg.f64 y) (exp.f64 z)))) t)))
(neg.f64 (-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) (neg.f64 y)) (*.f64 (exp.f64 z) (neg.f64 y)))) t)))
(+.f64 (neg.f64 x) (/.f64 (log.f64 (fma.f64 (exp.f64 z) (neg.f64 y) (+.f64 #s(literal 1 binary64) y))) t))
(-.f64 (/.f64 (log1p.f64 (*.f64 y (-.f64 #s(literal 1 binary64) (exp.f64 z)))) t) x)
(-.f64 (/.f64 (log1p.f64 (*.f64 y (neg.f64 (expm1.f64 z)))) t) x)
(neg.f64 (-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 (neg.f64 z))))) t)))
(+.f64 (neg.f64 x) (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (/.f64 y (exp.f64 z)))) t))
(-.f64 (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 (neg.f64 z))))) t) x)
(-.f64 (/.f64 (log1p.f64 (-.f64 (/.f64 y (exp.f64 z)) y)) t) x)
(-.f64 (/.f64 (log1p.f64 (*.f64 y (expm1.f64 (neg.f64 z)))) t) x)
(neg.f64 (-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) (neg.f64 t))))
(-.f64 (neg.f64 x) (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t))
(-.f64 (neg.f64 x) (/.f64 (log.f64 (fma.f64 y (exp.f64 z) (-.f64 #s(literal 1 binary64) y))) t))
(-.f64 (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 z)))) (neg.f64 t)) x)
(-.f64 (/.f64 (log1p.f64 (*.f64 y (+.f64 (exp.f64 z) #s(literal -1 binary64)))) (neg.f64 t)) x)
(-.f64 (/.f64 (log1p.f64 (*.f64 y (expm1.f64 z))) (neg.f64 t)) x)
(-.f64 y (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) x) (*.f64 x (exp.f64 z)))) t))
(-.f64 y (/.f64 (log.f64 (fma.f64 x (exp.f64 z) (-.f64 #s(literal 1 binary64) x))) t))
(-.f64 y (/.f64 (log1p.f64 (*.f64 x (+.f64 #s(literal -1 binary64) (exp.f64 z)))) t))
(-.f64 y (/.f64 (log1p.f64 (*.f64 x (+.f64 (exp.f64 z) #s(literal -1 binary64)))) t))
(-.f64 y (/.f64 (log1p.f64 (*.f64 x (expm1.f64 z))) t))
(-.f64 z (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 x)))) t))
(-.f64 z (/.f64 (log.f64 (fma.f64 y (exp.f64 x) (-.f64 #s(literal 1 binary64) y))) t))
(-.f64 z (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 x)))) t))
(-.f64 z (/.f64 (log1p.f64 (*.f64 y (+.f64 (exp.f64 x) #s(literal -1 binary64)))) t))
(-.f64 z (/.f64 (log1p.f64 (*.f64 y (expm1.f64 x))) t))
(-.f64 t (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) x))
(-.f64 t (/.f64 (log.f64 (fma.f64 y (exp.f64 z) (-.f64 #s(literal 1 binary64) y))) x))
(-.f64 t (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 z)))) x))
(-.f64 t (/.f64 (log1p.f64 (*.f64 y (+.f64 (exp.f64 z) #s(literal -1 binary64)))) x))
(-.f64 t (/.f64 (log1p.f64 (*.f64 y (expm1.f64 z))) x))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) z) (*.f64 z (exp.f64 y)))) t))
(-.f64 x (/.f64 (log.f64 (fma.f64 z (exp.f64 y) (-.f64 #s(literal 1 binary64) z))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 z (+.f64 #s(literal -1 binary64) (exp.f64 y)))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 z (+.f64 (exp.f64 y) #s(literal -1 binary64)))) t))
(-.f64 x (/.f64 (log1p.f64 (*.f64 z (expm1.f64 y))) t))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) t) (*.f64 t (exp.f64 z)))) y))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) t) (*.f64 (exp.f64 z) t))) y))
(-.f64 x (/.f64 (log.f64 (fma.f64 (exp.f64 z) t (-.f64 #s(literal 1 binary64) t))) y))
(-.f64 x (/.f64 (log1p.f64 (*.f64 t (+.f64 #s(literal -1 binary64) (exp.f64 z)))) y))
(-.f64 x (/.f64 (log1p.f64 (*.f64 t (+.f64 (exp.f64 z) #s(literal -1 binary64)))) y))
(-.f64 x (/.f64 (log1p.f64 (*.f64 t (expm1.f64 z))) y))
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 t)))) z))
(-.f64 x (/.f64 (log.f64 (fma.f64 y (exp.f64 t) (-.f64 #s(literal 1 binary64) y))) z))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (exp.f64 t)))) z))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (+.f64 (exp.f64 t) #s(literal -1 binary64)))) z))
(-.f64 x (/.f64 (log1p.f64 (*.f64 y (expm1.f64 t))) z))
Compiler

Compiled 17 to 12 computations (29.4% saved)

eval0.0ms (0%)

Compiler

Compiled 4 to 4 computations (0% saved)

prune21.0ms (0%)

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

Compiled 34 to 24 computations (29.4% saved)

simplify5.0ms (0%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
02054
13154
24254
35054
45654
55854
Stop Event
saturated
Calls
Call 1
Inputs
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t))
Outputs
(-.f64 x (/.f64 (log.f64 (+.f64 (-.f64 #s(literal 1 binary64) y) (*.f64 y (exp.f64 z)))) t))

soundness1.0ms (0%)

Stop Event
fuel
Compiler

Compiled 17 to 12 computations (29.4% saved)

preprocess80.0ms (0.1%)

Compiler

Compiled 158 to 98 computations (38% saved)

end0.0ms (0%)

Profiling

Loading profile data...