Commit 2d9d1a61 authored by Jérome Perrin's avatar Jérome Perrin

RNG: validate parameters to prevent an infinite loop

parent d22b2c59
...@@ -44,6 +44,10 @@ class RandomNumberGenerator(object): ...@@ -44,6 +44,10 @@ class RandomNumberGenerator(object):
elif(self.distributionType=="Exp"): #if the distribution is Exponential elif(self.distributionType=="Exp"): #if the distribution is Exponential
return G.Rnd.expovariate(1.0/(self.avg)) return G.Rnd.expovariate(1.0/(self.avg))
elif(self.distributionType=="Normal"): #if the distribution is Normal elif(self.distributionType=="Normal"): #if the distribution is Normal
if self.max < self.min:
raise ValueError("Normal distribution for %s uses wrong "
"parameters. max (%s) > min (%s)" % (
self.obj.id, self.max, self.min))
while 1: while 1:
number=G.Rnd.normalvariate(self.avg, self.stdev) number=G.Rnd.normalvariate(self.avg, self.stdev)
if number>self.max or number<self.min and max!=0: #if the number is out of bounds repeat the process #if max=0 this means that we did not have time "time" bounds if number>self.max or number<self.min and max!=0: #if the number is out of bounds repeat the process #if max=0 this means that we did not have time "time" bounds
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment