如何在mpi中创建一个新的数据类型并在所有范围内生效?
How to create a new datatype in mpi and take effect in all scope?
我在我的代码的main函数中定义了一个新的MPI数据类型,但是好像不能在其他函数中使用。
typedef struct {
int row;
int col;
double val;
} unit;
void sendTest() {
unit val;
val.row = val.col = val.val = 1;
MPI_Send(&val, 1, valUnit, 1, 0, MPI_COMM_WORLD);
}
void recvTest() {
unit val;
MPI_Recv(&val, 1, valUnit, 0, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE);
}
int main(int argc, char* argv[]) {
int comm_sz,my_rank;
MPI_Init(&argc, &argv);
MPI_Comm_size(MPI_COMM_WORLD, &comm_sz);
MPI_Comm_rank(MPI_COMM_WORLD, &my_rank);
int blockcount[3]={1,1,1};
MPI_Aint offsets[3] = {offsetof(unit, row), offsetof(unit, col), offsetof(unit, val)};
MPI_Datatype dataType[3] = {MPI_INT, MPI_INT, MPI_DOUBLE};
MPI_Datatype valUnit;
MPI_Type_create_struct(3, blockcount, offsets, dataType, &valUnit);
MPI_Type_commit(&valUnit);
if(my_rank == 0)
sendTest();
else
recvTest();
MPI_Finalize();
return 0;
}
编译程序时出现错误:
error: ‘valUnit’ was not declared in this scope
我想知道如何一次定义新的 mpi 数据类型并可以在所有范围内使用?
只需将 valUnit
声明为全局变量(例如,在 typedef ...
声明之后)。
注意 send()
和 recv()
是 glibc
的函数,所以你应该在你的程序中重命名这些子程序,否则你可能会遇到一些非常奇怪的副作用。
我在我的代码的main函数中定义了一个新的MPI数据类型,但是好像不能在其他函数中使用。
typedef struct {
int row;
int col;
double val;
} unit;
void sendTest() {
unit val;
val.row = val.col = val.val = 1;
MPI_Send(&val, 1, valUnit, 1, 0, MPI_COMM_WORLD);
}
void recvTest() {
unit val;
MPI_Recv(&val, 1, valUnit, 0, 0, MPI_COMM_WORLD, MPI_STATUS_IGNORE);
}
int main(int argc, char* argv[]) {
int comm_sz,my_rank;
MPI_Init(&argc, &argv);
MPI_Comm_size(MPI_COMM_WORLD, &comm_sz);
MPI_Comm_rank(MPI_COMM_WORLD, &my_rank);
int blockcount[3]={1,1,1};
MPI_Aint offsets[3] = {offsetof(unit, row), offsetof(unit, col), offsetof(unit, val)};
MPI_Datatype dataType[3] = {MPI_INT, MPI_INT, MPI_DOUBLE};
MPI_Datatype valUnit;
MPI_Type_create_struct(3, blockcount, offsets, dataType, &valUnit);
MPI_Type_commit(&valUnit);
if(my_rank == 0)
sendTest();
else
recvTest();
MPI_Finalize();
return 0;
}
编译程序时出现错误:
error: ‘valUnit’ was not declared in this scope
我想知道如何一次定义新的 mpi 数据类型并可以在所有范围内使用?
只需将 valUnit
声明为全局变量(例如,在 typedef ...
声明之后)。
注意 send()
和 recv()
是 glibc
的函数,所以你应该在你的程序中重命名这些子程序,否则你可能会遇到一些非常奇怪的副作用。