码迷,mamicode.com
首页 > 其他好文 > 详细

MPI计算π

时间:2020-07-25 23:38:51      阅读:124      评论:0      收藏:0      [点我收藏+]

标签:com   argc   argv   world   idt   alt   rac   mic   ali   

MPI计算\(\pi\)
  • 利用公式

\[\int_0^1 \frac{4}{1+x^2}dx = \pi \]

技术图片
技术图片
#include<stdio.h>
#include<mpi.h>
#include<stdlib.h>
#include<time.h>
int main(int argc, char** argv)
{
	int rank, size;
	int n = 100;
	double sum,width,local,mypi,pi;
	MPI_Init(&argc, &argv);
	MPI_Comm_rank(MPI_COMM_WORLD, &rank);
	MPI_Comm_size(MPI_COMM_WORLD, &size);
	MPI_Bcast(&n, 1, MPI_INT, 0, MPI_COMM_WORLD);
	sum = 0.0;
	width = 1.0 / n;
	/*
	* 把0~1分成n份,把计算任务分成size份。
	*/
	for (int i = rank; i < n; i += size)
	{
		local = width * ((double)i + 0.5);
		sum += 4.0 / (1.0 + local * local);
	}
	mypi = width * sum;
	MPI_Reduce(&mypi, &pi, 1, MPI_DOUBLE, MPI_SUM, 0, MPI_COMM_WORLD);
	if (rank == 0)
	{
		printf("pi is %.20f\n", pi);
		fflush(stdout);
	}
	MPI_Finalize();
	return 0;
}

MPI计算π

标签:com   argc   argv   world   idt   alt   rac   mic   ali   

原文地址:https://www.cnblogs.com/zhangyazhou/p/13376309.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!