the-honk/python/calculators/Binomial Distribution.py

22 lines
570 B
Python
Raw Permalink Normal View History

2021-06-23 19:02:32 +00:00
import operator as op
from functools import reduce
2021-08-26 01:42:17 +00:00
from _helpers import intInput, floatInput
2021-06-23 19:02:32 +00:00
def nCr(n, r):
r = min(r, n-r)
num = reduce(op.mul, range(n, n - r, -1), 1)
den = reduce(op.mul, range(1, r + 1), 1)
return num / den
def binomial(x, n, p):
q = 1 - p
2021-08-26 01:42:17 +00:00
return nCr(n, x) * (p ** x) * (q ** (n-x))
2021-06-23 19:02:32 +00:00
2021-08-26 01:42:17 +00:00
n = intInput('How many trials would you like to execute?')
x = intInput('How many times must the outcome happen in these trials?')
p = floatInput('What is the probability of success as a float?')
res = binomial(x, n, p)
print()
print(res)