mirror of
https://github.com/status-im/research.git
synced 2025-01-12 08:04:12 +00:00
28 lines
584 B
Python
28 lines
584 B
Python
import math
|
|
BLKTIME = 17
|
|
X = 0.28
|
|
|
|
faclog = [1]
|
|
for i in range(5000):
|
|
faclog.append(faclog[-1] * len(faclog))
|
|
|
|
def fac(x):
|
|
return faclog[x]
|
|
|
|
def poisson(expected, actual):
|
|
if expected == 0:
|
|
return 1 if actual == 0 else 0
|
|
return 2.718281828 ** (-expected + actual * math.log(expected) - math.log(fac(actual)))
|
|
|
|
def p_we_win(k, x):
|
|
return 1 - (x / (1.0 - x)) ** k
|
|
|
|
def p_we_win_after(s):
|
|
p = 0
|
|
for i in range(4000):
|
|
p += poisson(s * 1.0 / BLKTIME, i) * p_we_win(i, X)
|
|
return p
|
|
|
|
for i in range(0, 7200, 12):
|
|
print i, p_we_win_after(i)
|