2016-01-09 15:51:20 +00:00
|
|
|
#/usr/bin/env python
|
|
|
|
# -*- coding:Utf-8 -*-
|
|
|
|
|
2016-01-12 08:14:44 +00:00
|
|
|
from random import randint, uniform, gauss, choice
|
2016-01-09 15:51:20 +00:00
|
|
|
|
|
|
|
|
2016-02-13 04:04:08 +00:00
|
|
|
def random_generator(length,
|
|
|
|
distrib=gauss, rd_args=(0, 1),
|
|
|
|
nbr_format=lambda x: round(x, 2),
|
|
|
|
v_min=None, v_max=None,
|
|
|
|
exact_mean=None):
|
2016-01-09 15:51:20 +00:00
|
|
|
""" Generate a random list of value
|
|
|
|
|
|
|
|
:param length: length of the dataset
|
2016-01-12 08:14:44 +00:00
|
|
|
:param distrib: Distribution of the data set. It can be a function or string from ["randint", "uniform", "gauss", "choice"]
|
2016-01-09 15:51:20 +00:00
|
|
|
:param rd_args: arguments to pass to distrib
|
|
|
|
:param nbr_format: function which format value
|
|
|
|
:param v_min: minimum accepted value
|
|
|
|
:param v_max: maximum accepted value
|
|
|
|
:param exact_mean: if set, the last generated number will be create in order that the computed mean is exacly equal to "exact_mean"
|
|
|
|
|
|
|
|
>>> random_generator(10)
|
|
|
|
>>> random_generator(10, distrib = uniform, rd_args = (5, 10))
|
|
|
|
>>> random_generator(10, distrib = "uniform", rd_args = (5, 10))
|
|
|
|
>>> random_generator(10, v_min = 0)
|
|
|
|
>>> random_generator(10, exact_mean = 0)
|
|
|
|
>>> random_generator(10, distrib = gauss, rd_args = (50,20), nbr_format = int)
|
|
|
|
|
|
|
|
"""
|
|
|
|
# if exact_mean is set, we create automaticaly only length-1 value
|
2016-02-13 04:04:08 +00:00
|
|
|
if exact_mean is not None:
|
2016-01-09 15:51:20 +00:00
|
|
|
length = length - 1
|
|
|
|
|
|
|
|
# build function to test created values
|
2016-02-13 04:04:08 +00:00
|
|
|
if v_min is None:
|
2016-01-09 15:51:20 +00:00
|
|
|
v1 = lambda x: True
|
|
|
|
else:
|
|
|
|
v1 = lambda x: x >= v_min
|
2016-02-13 04:04:08 +00:00
|
|
|
if v_max is None:
|
2016-01-09 15:51:20 +00:00
|
|
|
v2 = lambda x: True
|
|
|
|
else:
|
|
|
|
v2 = lambda x: x <= v_max
|
2016-02-13 04:04:08 +00:00
|
|
|
validate = lambda x: v1(x) and v2(x)
|
2016-01-09 15:51:20 +00:00
|
|
|
|
|
|
|
# get distrib function
|
2016-02-13 04:04:08 +00:00
|
|
|
distribs = {
|
|
|
|
"gauss": gauss,
|
|
|
|
"uniform": uniform,
|
|
|
|
"randint": randint,
|
|
|
|
"choice": choice}
|
2016-01-09 15:51:20 +00:00
|
|
|
try:
|
|
|
|
distrib(*rd_args)
|
|
|
|
except TypeError:
|
|
|
|
distrib = distribs[distrib]
|
|
|
|
|
|
|
|
# building values
|
|
|
|
data = []
|
|
|
|
for _ in range(length):
|
|
|
|
valid = False
|
|
|
|
while not valid:
|
|
|
|
v = nbr_format(distrib(*rd_args))
|
|
|
|
valid = validate(v)
|
|
|
|
data.append(v)
|
|
|
|
|
|
|
|
# Build last value
|
2016-02-13 04:04:08 +00:00
|
|
|
if exact_mean is not None:
|
|
|
|
last_v = nbr_format((length + 1) * exact_mean - sum(data))
|
2016-01-09 15:51:20 +00:00
|
|
|
if not validate(last_v):
|
2016-02-13 04:04:08 +00:00
|
|
|
raise ValueError(
|
|
|
|
"Can't build the last value. Conflict between v_min/v_max and exact_mean")
|
2016-01-09 15:51:20 +00:00
|
|
|
data.append(last_v)
|
|
|
|
|
|
|
|
return data
|
|
|
|
|
|
|
|
# -----------------------------
|
|
|
|
# Reglages pour 'vim'
|
|
|
|
# vim:set autoindent expandtab tabstop=4 shiftwidth=4:
|
2016-02-13 03:29:26 +00:00
|
|
|
# cursor: 16 del
|