In unbiased coin flip H or T occurs 50% of times.
But I want to simulate coin which gives H with probability ‘p’ and T with probability ‘(1-p)’.
something like this:
JavaScript
x
8
1
def flip(p):
2
'''this function return H with probability p'''
3
# do something
4
return result
5
6
>> [flip(0.8) for i in xrange(10)]
7
[H,H,T,H,H,H,T,H,H,H]
8
Advertisement
Answer
random.random()
returns a uniformly distributed pseudo-random floating point number in the range [0, 1). This number is less than a given number p
in the range [0,1) with probability p
. Thus:
JavaScript
1
3
1
def flip(p):
2
return 'H' if random.random() < p else 'T'
3
Some experiments:
JavaScript
1
10
10
1
>>> N = 100
2
>>> flips = [flip(0.2) for i in xrange(N)]
3
>>> float(flips.count('H'))/N
4
0.17999999999999999 # Approximately 20% of the coins are heads
5
6
>>> N = 10000
7
>>> flips = [flip(0.2) for i in xrange(N)]
8
>>> float(flips.count('H'))/N
9
0.20549999999999999 # Better approximation
10