【Python-3.5】Pygal模拟骰子点数,分析结果可视化
程序员文章站
2024-03-08 19:38:52
...
使用Pygal模拟同时投掷两个骰子的点数和,本例中使用普通6面的骰子。
本例中涉及两个模块,die.py和dice_visual.py。其中die模块中定义roll方法,用于随机产生骰子的点数。运行dice_visual.py会在同目录下产生一个svg文件,在浏览器中打开就可看到条形图的分析结果。
代码如下:
die.py
from random import randint
class Die():
"""表示一个骰子的类"""
def __init__(self,num_sides=6):
# 骰子默认为6面
self.num_sides = num_sides
def roll(self):
"""返回1和骰子面数之间的一个随机数"""
return randint(1,self.num_sides)
import pygal
from die import Die
#创建一个骰子实例,6面的
die_1 = Die()
die_2 = Die()
#投掷骰子,记录结果
results = []
for roll_num in range(1000):
result = die_1.roll() + die_2.roll()
results.append(result)
#分析结果
frequencies = []
max_values = die_1.num_sides + die_2.num_sides
for value in range(2,max_values+1):
frequency = results.count(value)
frequencies.append(frequency)
#对结果进行可视化
hist = pygal.Bar()
hist.title = ("Results of rolling two D6 dice 1000 times.")
hist.x_labels = ['2','3','4','5','6','7','8','9','10','11','12']
hist.x_title = "Result"
hist.y_title = "frequency of Result"
hist.add('D6+D6',frequencies)
# 输出svg格式的文件
hist.render_to_file('die_visual.svg')
下一篇: Apriori算法--关联分析算法(一)