并行 MPI 版本

问题描述

我必须编写我的点积的并行 MPI 版本(代码如下):

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <sys/time.h>

#define SIZE 10000000

volatile float a[SIZE];
volatile float b[SIZE];

int main(int argc,char **argv)
{
  long int       i;
  double         sum;
  struct timeval time1,time2;

  srand(time(0));
  
  for (i = 0; i < SIZE; i++)
  {
    a[i] = rand();
    b[i] = rand();
  }
    
  gettimeofday(&time1,0);
  
  sum = 0.0;
  
  for (i = 0; i < SIZE; i++)
  {
    sum = sum + a[i]*b[i];
  }

  gettimeofday(&time2,0);
MPI_Scatter(a,1,MPI_INT,&b,MPI_COMM_WORLD);

  printf("Elapsed time (us) = %d\n",(time2.tv_sec-time1.tv_sec)*1000000 + time2.tv_usec - time1.tv_usec);

  return 0;
}                

我的问题是,我需要在程序中添加哪些代码,哪些 MPI 原语是有用的?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...