- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
圆周率计算并行程序设计
圆周率计算并行程序设计实验一、实验小组xxxxxxxxx二、实验原理有。故可令,通过计算得到值。进而,可在计算机上计算其近似值。四、实验目的1.在算法实现的过程中熟悉MPI的API,提高并行编程的熟练度。2.熟悉编程环境的使用,学习和掌握调试程序的方法。3.从实验结果分析比较不同输入规模下使用不同数量的结点数的实际运行时间。五、实验内容实验主要包括两部分内容:1、每一个结点按照公式计算一定数量的值。2、将每个结点的结果通过通讯传送给同一个结点汇总计算最终结果。1、计算:代码如下:/*Function resultofEachPoint is used to calculate the f((i-0.5)/N) of each iinput: i and N(numofIteration)output: result*/doubleresultofEachPoint (inti, intnumofIteration){double result;result = ((double)i - 0.5) / numofIteration;result = 4 / (1 + result * result);return result;}2、通信使用MPI_Send和MPI_Recv函数。六、实验结果规模PE个数10410710910.000443006716520.001877098039440.002688011214480.0251460035847160.0201820.0684166.456754表.不同输入规模下不同PE的时间消耗(单位s)图.不同PE个数在不同输入规模下的时间消耗图七、实验分析对于输入规模较小的情况(N=10000),增加PE数所带来的结果是并行程序中的通信代价所占比重增大,故程序的执行时间反而随着运行结点数的增加而增加。对于输入规模大的情况(另外两种),通信和串行部分在程序中所占比重较小,所以程序的执行速度随着PE数的增加有明显的减小趋势。但,由于通信部分在程序中所占比重增大等因素,导致程序的并行加速比随PE数的增加而降低。八、实验心得体会完成这次的实验后,对于并行程序的一些基本设计有了直观的认识。能够比较顺利地使用MPI基本的API,完成整个程序的编写。通过分析比较不同输入规模下使用不同数量的结点数的实际运行时间,对于串行、通信部分较少的程序在增加PE时加速比等并行程序的评估因素的变化有所认识。
文档评论(0)