skbio.tree.TreeNode.shuffle#
- TreeNode.shuffle(k=None, names=None, shuffler=None, n=1)[source]#
Randomly shuffle tip names of the tree.
- Parameters:
- kint, optional
The number of tips to shuffle. If provided, this number of tips will be randomly selected by
shuffle_f
, and only those names will be shuffled. Conflicts withnames
.- nameslist, optional
The specific tip names to shuffle. Conflicts with
k
.- shufflerint, np.random.Generator or callable, optional
Shuffling function, which must accept a list and modify in place. Default is the
shuffle
method of a NumPy random generator. If an integer is provided, a random generator will be constructed using this number as the seed.Changed in version 0.6.3: Renamed from
shuffle_f
. The old name is kept as an alias but is deprecated.Changed in version 0.6.3: Switched to NumPy’s new random generator. Can accept a random seed or random generator instance.
- nint, optional
The number of iterations to perform. Must be a positive integer. Default is 1. If None or
np.inf
, iterations will be infinite.Changed in version 0.6.3: Can accept None.
- Yields:
- TreeNode
Tree with shuffled tip names.
- Raises:
- ValueError
If
k
< 2 orn
< 1.- ValueError
If both
k
andnames
are specified.- MissingNodeError
If
names
is specified but one of the names cannot be found.
See also
Notes
This method does not create copies of the tree. Instead, tip names are shuffled in place in the original tree and the tree is yielded prior to the next round of shuffling. Tree caches will be cleared prior to shuffling.
k
andnames
cannot be specified at the same time. If neitherk
nornames
are provided, all tips will be shuffled.Examples
Shuffle the names of a 4-tip tree for 5 times:
>>> from skbio import TreeNode >>> tree = TreeNode.read(["((a,b),(c,d));"]) >>> for shuffled in tree.shuffle(shuffler=42, n=5): ... print(shuffled) ((d,c),(b,a)); ((a,b),(d,c)); ((a,c),(d,b)); ((d,b),(a,c)); ((a,c),(d,b));