forked from pdeitel/PythonFundamentalsLiveLessons
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRollDieDynamic.py
executable file
·59 lines (50 loc) · 2.81 KB
/
RollDieDynamic.py
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
48
49
50
51
52
53
54
55
56
57
58
59
# RollDieDynamic.py
"""Dynamically graphing frequencies of die rolls."""
from matplotlib import animation
import matplotlib.pyplot as plt
import random
import seaborn as sns
import sys
def update(frame_number, rolls, faces, frequencies):
"""Configures bar plot contents for each animation frame."""
# roll die and update frequencies
for i in range(rolls):
frequencies[random.randrange(1, 7) - 1] += 1
# reconfigure plot for updated die frequencies
plt.cla() # clear old contents contents of current Figure
axes = sns.barplot(x=faces, y=frequencies, palette='bright') # new bars
axes.set_title(f'Die Frequencies for {sum(frequencies):,} Rolls')
axes.set(xlabel='Die Value', ylabel='Frequency')
axes.set_ylim(top=max(frequencies) * 1.10) # scale y-axis by 10%
# display frequency & percentage above each patch (bar)
for bar, frequency in zip(axes.patches, frequencies):
text_x = bar.get_x() + bar.get_width() / 2.0
text_y = bar.get_height()
text = f'{frequency:,}\n{frequency / sum(frequencies):.3%}'
axes.text(text_x, text_y, text, ha='center', va='bottom')
# read command-line arguments for number of frames and rolls per frame
number_of_frames = int(sys.argv[1])
rolls_per_frame = int(sys.argv[2])
sns.set_style('whitegrid') # white backround with gray grid lines
figure = plt.figure('Rolling a Six-Sided Die') # Figure for animation
values = list(range(1, 7)) # die faces for display on x-axis
frequencies = [0] * 6 # six-element list of die frequencies
# configure and start animation that calls function update
die_animation = animation.FuncAnimation(
figure, update, repeat=False, frames=number_of_frames, interval=33,
fargs=(rolls_per_frame, values, frequencies))
plt.show() # display window
#**************************************************************************
#* (C) Copyright 1992-2018 by Deitel & Associates, Inc. and *
#* Pearson Education, Inc. All Rights Reserved. *
#* *
#* DISCLAIMER: The authors and publisher of this book have used their *
#* best efforts in preparing the book. These efforts include the *
#* development, research, and testing of the theories and programs *
#* to determine their effectiveness. The authors and publisher make *
#* no warranty of any kind, expressed or implied, with regard to these *
#* programs or to the documentation contained in these books. The authors *
#* and publisher shall not be liable in any event for incidental or *
#* consequential damages in connection with, or arising out of, the *
#* furnishing, performance, or use of these programs. *
#**************************************************************************