dimsbalanced.c

来自「fortran并行计算包」· C语言 代码 · 共 60 行

C
60
字号
/* This is a simple test program to see how well balanced the output from   MPI_Dims_create is.  This test can be run with a single process   and does not need mpiexec.   There is no standard result.  Instead, the output should be examined to    see if the results are acceptable.  For example, make sure that Dims_create   of 2*2*2 in three dimensions returns 2,2,2 (and not 1,1,8). */#include "mpi.h"#include <stdio.h>static int verbose = 1;int main( int argc, char *argv[] ){    int i, j, dims[3], size;    MPI_Init( &argc, &argv );        for (i=2; i<12; i++) {	for (j=0; j<2; j++) dims[j] = 0;	MPI_Dims_create( i * i, 2, dims );	if (verbose) printf( "Dims_create(%d,2) = (%d,%d)\n", 			     i*i, dims[0], dims[1]);	for (j=0; j<3; j++) dims[j] = 0;	MPI_Dims_create( i * i * i, 3, dims );	if (verbose) printf( "Dims_create(%d,3) = (%d,%d,%d)\n", 			     i*i*i, dims[0], dims[1], dims[2]);    }    size = 2*5*7*11;    for (j=0; j<3; j++) dims[j] = 0;    MPI_Dims_create( size, 2, dims );    if (verbose) printf( "Dims_create(%d,2) = (%d,%d)\n", 			 size, dims[0], dims[1]);    for (j=0; j<3; j++) dims[j] = 0;    MPI_Dims_create( size, 3, dims );    if (verbose) printf( "Dims_create(%d,3) = (%d,%d,%d)\n", 			 size, dims[0], dims[1], dims[2]);    size = 5*5*2*7*7*7;    for (j=0; j<3; j++) dims[j] = 0;    MPI_Dims_create( size, 2, dims );    if (verbose) printf( "Dims_create(%d,2) = (%d,%d)\n", 			 size, dims[0], dims[1]);    for (j=0; j<3; j++) dims[j] = 0;    MPI_Dims_create( size, 3, dims );    if (verbose) printf( "Dims_create(%d,3) = (%d,%d,%d)\n", 			 size, dims[0], dims[1], dims[2]);        size = 12;    for (j=0; j<3; j++) dims[j] = 0;    MPI_Dims_create( size, 2, dims );    if (verbose) printf( "Dims_create(%d,2) = (%d,%d)\n", 			 size, dims[0], dims[1]);    MPI_Finalize();    return 0;}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?