research/mining/compute_probabilities_of_finality.py

28 lines
584 B
Python
Raw Normal View History

2015-09-14 08:13:16 -04:00
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)