Source code for expyriment.design.randomize
"""The expyriment randomize module.
This module contains various functions for randomizing data
"""
__author__ = 'Florian Krause <florian@expyriment.org>,\
Oliver Lindemann <oliver@expyriment.org>'
__version__ = '0.6.3+'
__revision__ = '0a47722d7fb0'
__date__ = 'Fri Jul 26 11:31:53 2013 +0200'
from copy import copy as _copy
import random as _random
_random.seed()
[docs]def rand_int_sequence(first_elem, last_elem):
"""Return a randomised sequence of integers in given range.
Parameters
----------
first_elem : int
first element of the range
last_elem : int
last element of the range
Results
-------
rnd_seq : list
randomised sequence of integers in given range
"""
list_ = range(first_elem, last_elem + 1)
_random.shuffle(list_)
return list_
[docs]def rand_int(a, b):
"""Return random integer in given range.
Parameters
----------
a : int
first element of range
b : int
last element of range
Results
-------
rnd : int
"""
return _random.randint(a, b)
[docs]def rand_element(list_):
"""Return a random element from a list
Parameter
---------
list_ : list
Results
-------
elem : a random element from the list
"""
return list_[_random.randint(0, len(list_) - 1)]
[docs]def coin_flip():
"""Return randomly True or False.
Returns
-------
rnd : bool
"""
if _random.randint(1, 2) == 1:
return True
else:
return False
[docs]def shuffle_list(list_):
"""Shuffle any list of objects.
Parameters
----------
list_ : int
list to shuffle
"""
_random.shuffle(list_)
[docs]def make_multiplied_shuffled_list(list_, xtimes):
"""Return the multiplied and shuffled (sectionwise) list.
The function manifolds the list 'xtimes' and shuffles each
and concatenates to the return new lists.
Parameters
----------
list_ : list
list to be shuffled
xtimes : int
how often the list will be multiplied
"""
newlist = []
tmp = _copy(list_)
for _i in range(0, xtimes):
_random.shuffle(tmp)
newlist.extend(tmp)
return newlist