ch9.ppt.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ch9.ppt

设计的艺术 螺旋式开发与自顶向下设计是互补的方法. 如:原型可使用自顶向下设计 好的软件设计者会使用多种设计技术. 通过实践学习软件设计. Lu Chaojun, SJTU Lu Chaojun, SJTU 模拟 Lu Chaojun, SJTU * Lu Chaojun, SJTU * * 不确定性 确定性程序: 程序多次执行时,只要输入一样,结果也一样 程序执行时只有一个控制流 不确定性程序: 程序多次执行时,即使输入一样,也会得到不同结果 程序执行时有多个控制流并行执行 Lu Chaojun, SJTU * Lu Chaojun, SJTU * * 模拟 建模:建立描述现实的模型 抽象出现实的关键特征 表示为某种数学公式或结构 常用计算机来实现 模拟:为实际问题建模,通过对模型的研究来获得实际中难以获得的信息. Lu Chaojun, SJTU * Lu Chaojun, SJTU * * 编程实例:模拟混沌现象 混沌现象:系统表现出不确定的行为,其特征是: 不可预测 对初始条件敏感 例:chaos.py def main(): x = input(Enter a number between 0 and 1: ) for i in range(10): x = 3.9 * x * (1 - x) print x main() 随机现象的建模和模拟 随机事件:例如掷硬币 数学中用统计学,概率论研究随机现象 计算机利用模拟来研究 确定的程序要表现出随机性: 结果不可预测 结果的分布符合统计规律 if 模拟抛硬币的结果是正面: print 正 else: print 反 Lu Chaojun, SJTU * 随机数 如何用确定性的程序模拟非确定性? Monte Carlo算法:利用随机数生成函数 实际上是伪随机数 只要能给出相同的输入,就得到同样结果 但很难给出相同输入! random模块提供了伪随机数生成函数: randrange(s,e):生成指定范围内的一个整数 random():生成[0,1)间的一个浮点数 Lu Chaojun, SJTU * 用随机数函数模拟掷硬币 掷硬币====randrange(1,3) 正 反 1 2 if 模拟抛硬币的结果是正面: if randrange(1,3)==1: print 正 print 正 else: else: print 反 print 反 Lu Chaojun, SJTU * 用随机数函数模拟比赛 设A,B两个球员之间比赛的胜负概率分别是p和1?p 用random()模拟比赛: if random() p: random() print A wins. else: print B wins. Lu Chaojun, SJTU * p 1 0 编程案例:乒乓球比赛模拟 问题:国际乒联将每局21分改成11分,能降低中国选手获胜概率吗? 我们采用一种与自顶向下设计不同的设计方法:原型法(详后) 从程序基本功能出发,逐步完善 Lu Chaojun, SJTU * 编程案例:技术水平的表示 比赛胜负由球员的技术水平决定 我们用两个球员对阵时得1分的概率来表示他们的技术水平 当A与B水平相当,则A拿下1分的概率是50%,B拿下1分的概率也是50% 如果A水平较高,拿下1分的概率是55%,则B拿下1分的概率就只有45% 技术水平表示法是主观确定,关键是要符合实际:还可考虑接发球,世界排名等. Lu Chaojun, SJTU * 编程案例:模拟一回合及得分 首先要能模拟一回合比赛,这是得分的基本形式 if random() 0.55: pointA = pointA + 1 else: pointB = pointB + 1 这是最终程序的核心功能 可以立即测试 测试10000回合,看看胜负概率 Lu Chaojun, SJTU * 编程案例:模拟一局比赛 比赛不是1分决胜负,而是由若干分构成一局.假设采用21分制: def oneGame(): pointA = pointB = 0 while pointA != 21 and pointB != 21: if random() 0.55: pointA = pointA + 1 else: po

文档评论(0)

cynthia_h + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档