1
0
mirror of https://github.com/bitcoin/bips.git synced 2025-01-18 21:35:13 +01:00

BIP-0119: Use the same random seed across simulation runs; fix issue where a poisson was used in place of an exponential

This commit is contained in:
Jeremy Rubin 2020-04-08 12:43:42 -07:00
parent bef6dc91c4
commit 58d1b1994c

View File

@ -24,6 +24,7 @@ def get_rate(phase):
return 1.25**(phase)*TXNS_PER_SEC return 1.25**(phase)*TXNS_PER_SEC
def normal(): def normal():
np.random.seed(0)
print("Max Txns Per Sec %f"%TXNS_PER_SEC) print("Max Txns Per Sec %f"%TXNS_PER_SEC)
backlog = 0 backlog = 0
results_unconfirmed = [0]*SAMPLES results_unconfirmed = [0]*SAMPLES
@ -43,6 +44,7 @@ def normal():
results_unconfirmed[i] = backlog/AVG_TX results_unconfirmed[i] = backlog/AVG_TX
return results_unconfirmed, np.cumsum(total_time)/(60*60*24.0) return results_unconfirmed, np.cumsum(total_time)/(60*60*24.0)
def compressed(rate_multiplier = 1): def compressed(rate_multiplier = 1):
np.random.seed(0)
print("Max Txns Per Sec %f"%TXNS_PER_SEC) print("Max Txns Per Sec %f"%TXNS_PER_SEC)
backlog = 0 backlog = 0
secondary_backlog = 0 secondary_backlog = 0
@ -54,7 +56,7 @@ def compressed(rate_multiplier = 1):
total_time = [0]*(SAMPLES) total_time = [0]*(SAMPLES)
for phase in range(PHASES): for phase in range(PHASES):
for i in range(PHASE_LENGTH*phase, PHASE_LENGTH*(1+phase)): for i in range(PHASE_LENGTH*phase, PHASE_LENGTH*(1+phase)):
block_time = np.random.poisson(AVG_INTERVAL) block_time = np.random.exponential(AVG_INTERVAL)
total_time[i] = block_time total_time[i] = block_time
txns = np.random.poisson(rate_multiplier*get_rate(phase)*block_time) txns = np.random.poisson(rate_multiplier*get_rate(phase)*block_time)
postponed = txns * COMPRESSABLE postponed = txns * COMPRESSABLE