数学软件作业圆周率的计算.doc

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数学软件作业圆周率的计算

2007数学应用软件设计内容 ——怎样计算圆周率π的值 实验报告 姓名:。。 学号:;;;; 实验目的: 利用所学的数学应用软件,解决下列问题: 1. 用反正切函数的幂级数展开式结合有关公式求π,若要精确到以40位、50位数字,试比较简单公式和Machin公式所用的项数; 2. 用数值积分计算π,分别用梯形法和Simpson法精确到10位数字,用Simpson法精确到15位数字; 3. 用Monte Carlo 法计算π,除了加大随机数,在随机数一定时可重复算若干次后求平均值,看能否求得5位精确数字? 4. 设计方案用计算机模拟Buffon实验; 5.利用学习过的知识(或查阅资料),提出其他计算π的方法。 实验的基本理论与方法: 1.利用反正切函数的幂级数表达式: 利用积分公式两边积分得: 在上式中令x=1得: 用Mathematica计算 In[1] k=1000; S1=N[4*Sum[(-1)^(n-1)/(2n-1),{n,1,k}],18] [Out2] 3.14059265383979293 In[3] k=10000; [Out4] 3.14149265359004324 In[5] k=15000; [Out6] 3.14152598692320065 In[7] k=20000 [Out8] 3.14154265358982449 由上述计算可以知道,用反正切函数的幂级数展开来计算π的值,运算速度比较慢,结果精度也不高,因此此方法一般不选取。 下面对精确到相同精度时简单公式和Machin公式所用的项数进行比较: 简单公式: Machin公式: 再用Mathematica计算: 当精确到40位时: 对于简单公式: Clear[k,n,S] In[9] k =62; s2 = N[4*Sum[(-1)^(n - 1)*(1/2)^(2n - 1)/(2n - 1) + (-1)^(n - 1)*(1/3)^(2n - 1)/(2n - 1), {n, 1, k}], 40] [Out10] 3.141592653589793238462643383279502884197 对于Machin公式: In[11] k = 28; s3 = N[4*Sum[ 4*(-1)^(n - 1)*(1/5)^(2n - 1)/(2n - 1) - (-1)^(n - 1)*(1/239)^(2n - 1)/(2n - 1), {n, 1, k}], 40] [Out12] 3.141592653589793238462643383279502884197 当精确到50位时: 对于简单公式: In[13] k = 78; s2 = N[4*Sum[(-1)^(n - 1)*(1/2)^(2n - 1)/(2n - 1) + (-1)^(n - 1)*(1/3)^(2n - 1)/(2n - 1), {n, 1, k}], 40] [Out14] 3.1415926535897932384626433832795028841971693993750 对于Machin公式: In[15] k = 35; s3 = N[4*Sum[ 4*(-1)^(n - 1)*(1/5)^(2n - 1)/(2n - 1) - (-1)^(n - 1)*(1/239)^(2n - 1)/(2n - 1), {n, 1, k}], 50] [Out16] 3.1415926535897932384626433832795028841971693993751 由上述比较可以看出:在精确到相同精度时,用Machin公式计算的结果比较准确,并且所需的项数也比较少,当精确到40位时简单公式和Machin公式分别需要62和28位,而当精确到50位时,分别为78和35位。所以用Machin公式计算圆周率速度较快,结果也较精确,并且程序也较简单,是一种比较好的方法。 用数值积分计算π: 将[0,1]区间n等分,取xk=k/n, yk= 1/ (1+xk2) 用Mathematica计算: 梯形法(精确到10位): In[17] y[x_]:=4/(1+x^2); n=20000; S4=N[

文档评论(0)

pangzilva + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档