我真的想用C ++代码,并使用MPI。
在我的代码,我想从文件中读取。 我只是想在主处理器读取数据,后来,我将它分散到其他人。 我们的目标是读从文件的图形,然后分散邻接矩阵行方式。
问题是,当我想打开该文件。 如果我生成一个矩阵,将很好地撒(我使用的代码从这里 ,改变它的基础上我的需要),以便我测试了好几次我不有任何问题散射。 问题是,当我想打开,并从文件中读取,而奇怪的是,即使打开该文件给我的错误,我不是很熟悉,MPI和版本以及它与C ++的兼容性。 我认为这是值得与C ++或我怎么编译。
这里是我的代码:
#include <iostream>
#include <climits>
#include <fstream>
#include <vector>
#include <set>
#include <stdio.h>
#include <stdlib.h>
#include <algorithm>
#include <list>
#include <queue>
#include <sstream>
#include <mpi.h>
#include <string>
#define BLOCK_LOW(id,p,n) ((id)*(n)/(p))
#define BLOCK_HIGH(id,p,n) ((id+1)*(n)/(p) - 1)
#define BLOCK_SIZE(id,p,n) ((id+1)*(n)/(p) - (id)*(n)/(p))
#define BLOCK_OWNER(index,p,n) (((p)*((index)+1)-1)/(n))
using namespace std;
void matrix_print(double **M, size_t m, size_t n,int my_rank);
int main(int argc, char* argv[])
{
int comm_size, my_rank, root = 0, nVertex = 6, rows, i, j, *sendcounts, *displs,nEdges;
double **adjArray, **adjPart, *stripdata;
double *Adata;
MPI_Status status;
MPI_Init(&argc, &argv);
MPI_Comm_size(MPI_COMM_WORLD,&comm_size);
MPI_Comm_rank(MPI_COMM_WORLD,&my_rank);
if (my_rank == 0){
ifstream myfile;
myfile.open("path/intsance.gr");
if(!myfile)
{
cout << "Error: file could not be opened" << endl;
exit (EXIT_FAILURE);
}
/*
static const int max_line = 65536;
string s;
myfile.ignore(max_line, '\n');
myfile>>s; // Nodes;
myfile>>nVertex;
myfile>>s; // Edges;
myfile>>nEdges;
cout<<"-----File is read..."<<endl;
cout<<"------------------------------------------------------------------------------------------"<<endl;
*/
}
// MPI_Barrier(MPI_COMM_WORLD);
nVertex=6;
if (my_rank == 0){
Adata = (double *)malloc(sizeof(double)*nVertex*nVertex);
adjArray = (double **)malloc(sizeof(double*)*nVertex);
for(int i = 0; i < nVertex; i++)
adjArray[i] = &(Adata[i*nVertex]);
int k=0;
for (int i=0; i<nVertex; i++) {
for (int j=0; j<nVertex; j++) {
adjArray[i][j]=k;
k++;
}
}
cout<<"---Adjacancy Matrix:"<<endl;
for (int i=0; i<nVertex; i++) {
for (int j=0; j<nVertex; j++) {
if(adjArray[i][j]==INT_MAX)
{
cout<< " - ";
}else
{
cout<< adjArray[i][j]<<" ";
}
}
cout<<endl;
}
cout<<"----------------------------------------------------"<<endl;
}
// Array containing the numbers of rows for each process
sendcounts = (int *)malloc(nVertex * sizeof(int));
// Array containing the displacement for each data chunk
displs = (int *)malloc(nVertex * sizeof(int));
// For each process ...
for (j = 0; j < comm_size; j++) {
// Sets each number of rows
sendcounts[j] = BLOCK_SIZE(j, comm_size, nVertex)*nVertex;
// Sets each displacement
displs[j] = BLOCK_LOW(j, comm_size, nVertex)*nVertex;
}
// Each process gets the number of rows that he is going to get
rows = sendcounts[my_rank]/nVertex;
// Creates the empty matrixes for the parts of M
// adjPart = (double**)matrix_create(rows, nVertex, sizeof(double));
stripdata = (double *)malloc(sizeof(double)*rows*nVertex);
adjPart = (double **)malloc(sizeof(double*)*rows);
for(int i= 0; i< rows; i++) {
adjPart[i] = &(stripdata[i*nVertex]);
}
// Scatters the matrix parts through all the processes
MPI_Scatterv(&adjArray[0][0], sendcounts, displs, MPI_DOUBLE, &adjPart[0][0], sendcounts[my_rank], MPI_DOUBLE, root, MPI_COMM_WORLD);
// This is where I get the Segmentation Fault
matrix_print(adjPart, rows, nVertex,my_rank);
MPI_Finalize();
return 0;
}
void matrix_print(double **M, size_t m, size_t n,int my_rank) {
size_t i,j;
cout<<"Rank: "<<my_rank<<endl;
for(i=0; i<m; ++i) {
printf("\n ");
for(j=0; j<n; ++j)
printf("%f ",M[i][j]);
}
cout<<endl;
}
这里是我编译并运行它:
mpic++ file.cpp -o outPut
mpirun -np 4 ./outPut
而我得到以下的结果,我不`吨明白的地方是问题:
---Adjacancy Matrix:
0 1 2 3 4 5
6 7 8 9 10 11
12 13 14 15 16 17
18 19 20 21 22 23
24 25 26 27 28 29
30 31 32 33 34 35
----------------------------------------------------
[S-MacBook-Pro:25734] *** Process received signal ***
[S-MacBook-Pro:25734] Signal: Segmentation fault: 11 (11)
[S-MacBook-Pro:25734] Signal code: Address not mapped (1)
[S-MacBook-Pro:25734] Failing at address: 0x0
[S-MacBook-Pro:25734] [ 0] 0 libsystem_platform.dylib 0x00007fff7221ff5a _sigtramp + 26
[S-MacBook-Pro:25734] [ 1] 0 ??? 0x000000010a630b5a 0x0 + 4469230426
[S-MacBook-Pro:25734] [ 2] 0 libdyld.dylib 0x00007fff71f9e115 start + 1
[S-MacBook-Pro:25734] *** End of error message ***
Rank: 0
0.000000 1.000000 2.000000 3.000000 4.000000 5.000000
[S-MacBook-Pro:25732] *** Process received signal ***
[S-MacBook-Pro:25732] Signal: Segmentation fault: 11 (11)
[S-MacBook-Pro:25732] Signal code: Address not mapped (1)
[S-MacBook-Pro:25732] Failing at address: 0x0
[S-MacBook-Pro:25732] [ 0] 0 libsystem_platform.dylib 0x00007fff7221ff5a _sigtramp + 26
[S-MacBook-Pro:25732] [ 1] 0 ??? 0x000000010e9cfb5a 0x0 + 4540136282
[S-MacBook-Pro:25732] [ 2] 0 libdyld.dylib 0x00007fff71f9e115 start + 1
[S-MacBook-Pro:25732] *** End of error message ***
[S-MacBook-Pro:25733] *** Process received signal ***
[S-MacBook-Pro:25733] Signal: Segmentation fault: 11 (11)
[S-MacBook-Pro:25733] Signal code: Address not mapped (1)
[S-MacBook-Pro:25733] Failing at address: 0x0
[S-MacBook-Pro:25733] [ 0] 0 libsystem_platform.dylib 0x00007fff7221ff5a _sigtramp + 26
[S-MacBook-Pro:25733] [ 1] 0 ??? 0x00000001100acb5a 0x0 + 4564110170
[S-MacBook-Pro:25733] [ 2] 0 libdyld.dylib 0x00007fff71f9e115 start + 1
[S-MacBook-Pro:25733] *** End of error message ***
--------------------------------------------------------------------------
mpirun noticed that process rank 3 with PID 25734 on node S-MacBook-Pro exited on signal 11 (Segmentation fault: 11).
需要注意的是,因为我didn`t知道在哪里的问题从何而来,我不停的矩阵,因为我在我的代码生成它,现在我只想知道为什么它通过打开这个文件给我的错误。 任何帮助,将不胜感激!