标签:骰子 die self roll ---- 入门篇 num Pygal sides
使用python可视化包Pygal来生成可缩放的矢量图形文件。对于需要在尺寸不同的屏幕上显示的图表,这狠有用,因为它们将自动缩放,以适合观看者的屏幕。如果你打算以在线方式使用图表,请考虑使用Pygal来生成它们,因为这样它们在任何设备上显示时都很美观。
1.使用Pygal模拟掷骰子对掷骰子的结果进行分析。掷6面的常规骰子时,可能出现的结果为1~6点,且出现每种结果的可能性相同。然而,如果同时掷两个骰子,某些点数出现的可能性将比其他点数大。为确定哪些点数出现的可能性最大,我们将生成一个表示掷骰子结果的数据集,并根据结果绘制出一个图形。
(1)Pygal画廊
(2)创建Die类
此类模拟掷一个骰子:
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)
(3)掷骰子
通过观察运行结果,发现无异常!
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)
#创建一个D6
die = Die()
#掷几次骰子,并将结果存储在一个列表中
results = [] # 列表解析表达式代替:results = [die.roll() for roll_num in range(1000)]
for roll_num in range(1000):
result = die.roll()
results.append(result)
print(results)
(4)分析结果
为分析掷一个六面骰子的结果,我们计算每个点数出现的次数:
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)
#创建一个D6
die = Die()
#掷几次骰子,并将结果存储在一个列表中
results = [] # 列表解析表达式代替:results = [die.roll() for roll_num in range(1000)]
for roll_num in range(1000):
result = die.roll()
results.append(result)
#分析结果
frequencies = [] # 列表解析表达式代替:frequencies = [results.count(value) for value in range(1, die.num_sides+1)]
for value in range(1,die.num_sides+1):
frequency = results.count(value) #计算在1000次掷骰子结果中各个面数出现的次数。
frequencies.append(frequency)
print(frequencies)
(5)绘制直方图
直方图是一种条形图,指出了各种结果出现的频率!
import pygal
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)
#创建一个D6
die = Die()
#掷几次骰子,并将结果存储在一个列表中
results = [] # 列表解析表达式代替:results = [die.roll() for roll_num in range(1000)]
for roll_num in range(1000):
result = die.roll()
results.append(result)
#分析结果
frequencies = [] # 列表解析表达式代替:frequencies = [results.count(value) for value in range(1, die.num_sides+1)]
for value in range(1,die.num_sides+1):
frequency = results.count(value) #计算在1000次掷骰子结果中各个面数出现的次数。
frequencies.append(frequency)
#对结果进行可视化,即绘制直方图
hist = pygal.Bar()
hist.title = "Results of rolling one D6 1000 times." # 用于标识直方图的字符串
hist.x_labels = ['1','2','3','4','5','6'] # x轴的标签
hist.x_title = "Result" # x轴标题
hist.y_title = "Frequency of Result" # y轴标题
# 使用add()将一系列值添加到图表中(向它传递要给添加的值指定的标签,还有一个包含将出现在图标中的值的列表)
hist.add('D6',frequencies)
# 将图表渲染为一个SVG文件,这种文件的拓展名必须为.svg
hist.render_to_file('一个骰子.svg')
(6)同时掷两个骰子
每次掷两个都为6面的骰子时,都将两个骰子的点数相加,并将结果存储在results中:
import pygal
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)
#创建两个骰子
die_1 = Die()
die_2 = Die()
#掷骰子多次,并将结果存储到一个列表中
results = [] # 列表解析表达式代替:results = [die_1.roll() + die_2.roll() for roll_num in range(1000)]
for roll_num in range(1000):
result = die_1.roll() + die_2.roll()
results.append(result)
#分析结果
frequencies = [] #列表解析表达式代替:frequencies = [results.count(value) for value in range(2, max_result+1)]
max_result = die_1.num_sides + die_2.num_sides #列表解析表达式里有个max_result
for value in range(2,max_result+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)
hist.render_to_file('俩骰子.svg')
此图表显示了掷两个6面骰子时得到的大致结果。如你所见:总点数为2或12的可能性最小,而总点数为7的可能性最大。原因显而易见。
(7)同时掷两个面数不同的骰子
下面创建一个6面骰子和一个10面骰子,看看同时掷这俩骰子50000次的结果如何:
import pygal
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)
#创建一个D6和一个D10
die_1 = Die()
die_2 = Die(10)
#掷骰子多次,并将结果存储在一个列表中
results = []
for roll_num in range(50000):
result = die_1.roll() + die_2.roll()
results.append(result)
#分析结果
frequencies = []
max_result = die_1.num_sides + die_2.num_sides
for value in range(2,max_result+1):
frequency = results.count(value)
frequencies.append(frequency)
#可视化结果
hist = pygal.Bar()
hist.title = "Results of rolling a D6 and a D10 50000 times."
hist.x_labels = ['2','3','4','5','6','7','8','9','10','11','12','13','14','15','16']
hist._x_title = "Result"
hist.y_title = "Frequency of Result"
hist.add('D6 + D10',frequencies)
hist.render_to_file('俩不一样的骰子.svg')
观图可知:可能性最大的点数不是一个,而是5个,这是因为导致出现最小点数和最大点数的组合都只有一种(1和1以及6和10),但面数较小的骰子限制了得到中间点数的组合数:得到总点数7,8,9,,1和11的组合数都是六种。因此,这些总点数是最常见的结果,它们出现的可能性相同!
标签:骰子,die,self,roll,----,入门篇,num,Pygal,sides
来源: https://blog.51cto.com/u_15264787/2886554
本站声明:
1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。