这是一个实用的并行计算源代码
源代码在线查看: function.c
/* $Id: function.c,v 1.2 2005/06/20 03:28:52 zlb Exp $ */ #include #include #include int evaluation_count = 0; /* 被积函数 */ double F(double x) { size_t i; for (i = 0; i < 5000000; i++); /* 为增加计算时间引入的空循环\label{function.c:1} */ evaluation_count++; return 4.0 / (1.0 + x * x); /* $f(x) = \dfrac4{1+x^2}$ */ } /* 积分精确值 (用于检验结果) */ double RESULT = 3.141592653589793; void gettime(double *cpu, double *wall) /* 返回当前 CPU 和墙上时间 */ { struct timeval tv; struct rusage ru; if (cpu != NULL) { getrusage(RUSAGE_SELF, &ru); *cpu = ru.ru_utime.tv_sec + (double)ru.ru_utime.tv_usec * 1e-6; } if (wall != NULL) { gettimeofday(&tv, NULL); *wall = tv.tv_sec + (double)tv.tv_usec * 1e-6; } }