Python 以指定的概率選取元素


Python 以指定的概率選取元素

Problem

You want to pick an item at random from a list, just about as random.choice does, but you need to pick the various items with different probabilities given in another list, rather than picking any item with equal probability as random.choice does.

Solution

Module random in the standard Python library offers a wealth of possibilities for generating and using pseudo-random numbers, but it does not offer this specific functionality, so we must code it as a function of our own:

import random 

def random_pick(some_list, probabilities): 
    x = random.uniform(0,1) 
    cumulative_probability = 0.0 
    for item, item_probability in zip(some_list, probabilities): 
         cumulative_probability += item_probability 
         if x < cumulative_probability:
               break 
    return item 

 

random.uniform(0,1)->生成0.0到1.0之間的偽隨機數,之后循環元素及其概率,計算累積概率.

如:random_pick([1,2,3,4],[0.1,0.2,0.3,0.4])

當x處於0.0到0.1之間,則輸出1

當x處於0.1到0.3之間,則輸出2

……

 

Example

#以指定的概率獲取元素 以一個列表為基准概率,從一個列表中隨機獲取元素 

import random 

def random_pick(some_list, probabilities): 
x = random.uniform(0,1) 
cumulative_probability = 0.0 
for item, item_probability in zip(some_list, probabilities): 
cumulative_probability += item_probability 
if x < cumulative_probability:break 
return item 

some_list = [1,2,3,4] 
probabilities = [0.2,0.1,0.6,0.1] 

print random_pick(some_list,probabilities) 

 

【注意】要求 some_list 的長度和 probabilities 的長度一致,以及所有元素的概率相加為1.0

 

【References】

[1] Randomly Picking Items with Given Probabilities

[2] Python 以指定概率獲取元素


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM