-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcoins.py
More file actions
47 lines (31 loc) · 988 Bytes
/
coins.py
File metadata and controls
47 lines (31 loc) · 988 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import random
import matplotlib.pyplot as plt
import numpy as np
import collections
results = []
distribution = {}
for i in range(1000):
heads = 0
flips = 0
while heads < 10:
if(random.random() < 0.25):
heads += 1
else:
heads = 0
flips += 1
results.append(flips)
average = 0
for result in results:
average += result
average = average / len(results)
print("got 10 heads in " + str(flips) + " flips \t avg:" + str(average))
if int(flips/100000) in distribution:
distribution[int(flips/100000)] += 1
else:
distribution[int(flips/100000)] = 1
fig, ax = plt.subplots(figsize=(5, 2.7), layout='constrained')
ordered_distribution = collections.OrderedDict(sorted(distribution.items()))
for key in ordered_distribution.keys():
print(str(key) + ": " + str(ordered_distribution[key]))
ax.plot(ordered_distribution.keys(),ordered_distribution.values())
plt.show()