📄 allred.c
字号:
for (i=0; i<count; i++) { *(in + i) = 1; *(sol + i) = 0; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED_SHORT, MPI_LXOR, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED_SHORT and op MPI_LXOR\n", rank ); free( in ); free( out ); free( sol );}void e9(void){ unsigned *in, *out, *sol; int i, fnderr=0; in = (unsigned *)malloc( count * sizeof(unsigned) ); out = (unsigned *)malloc( count * sizeof(unsigned) ); sol = (unsigned *)malloc( count * sizeof(unsigned) ); for (i=0; i<count; i++) { *(in + i) = 1; *(sol + i) = 0; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED, MPI_LXOR, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED and op MPI_LXOR\n", rank ); free( in ); free( out ); free( sol );}void f9(void){ unsigned long *in, *out, *sol; int i, fnderr=0; in = (unsigned long *)malloc( count * sizeof(unsigned long) ); out = (unsigned long *)malloc( count * sizeof(unsigned long) ); sol = (unsigned long *)malloc( count * sizeof(unsigned long) ); for (i=0; i<count; i++) { *(in + i) = 1; *(sol + i) = 0; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED_LONG, MPI_LXOR, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED_LONG and op MPI_LXOR\n", rank ); free( in ); free( out ); free( sol );}void a10(void){ int *in, *out, *sol; int i, fnderr=0; in = (int *)malloc( count * sizeof(int) ); out = (int *)malloc( count * sizeof(int) ); sol = (int *)malloc( count * sizeof(int) ); for (i=0; i<count; i++) { *(in + i) = (rank & 0x1); *(sol + i) = 0; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_INT, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_INT and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void b10(void){ long *in, *out, *sol; int i, fnderr=0; in = (long *)malloc( count * sizeof(long) ); out = (long *)malloc( count * sizeof(long) ); sol = (long *)malloc( count * sizeof(long) ); for (i=0; i<count; i++) { *(in + i) = (rank & 0x1); *(sol + i) = 0; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_LONG, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_LONG and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void c10(void){ short *in, *out, *sol; int i, fnderr=0; in = (short *)malloc( count * sizeof(short) ); out = (short *)malloc( count * sizeof(short) ); sol = (short *)malloc( count * sizeof(short) ); for (i=0; i<count; i++) { *(in + i) = (rank & 0x1); *(sol + i) = 0; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_SHORT, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_SHORT and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void d10(void){ unsigned short *in, *out, *sol; int i, fnderr=0; in = (unsigned short *)malloc( count * sizeof(unsigned short) ); out = (unsigned short *)malloc( count * sizeof(unsigned short) ); sol = (unsigned short *)malloc( count * sizeof(unsigned short) ); for (i=0; i<count; i++) { *(in + i) = (rank & 0x1); *(sol + i) = 0; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED_SHORT, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED_SHORT and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void e10(void){ unsigned *in, *out, *sol; int i, fnderr=0; in = (unsigned *)malloc( count * sizeof(unsigned) ); out = (unsigned *)malloc( count * sizeof(unsigned) ); sol = (unsigned *)malloc( count * sizeof(unsigned) ); for (i=0; i<count; i++) { *(in + i) = (rank & 0x1); *(sol + i) = 0; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void f10(void){ unsigned long *in, *out, *sol; int i, fnderr=0; in = (unsigned long *)malloc( count * sizeof(unsigned long) ); out = (unsigned long *)malloc( count * sizeof(unsigned long) ); sol = (unsigned long *)malloc( count * sizeof(unsigned long) ); for (i=0; i<count; i++) { *(in + i) = (rank & 0x1); *(sol + i) = 0; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED_LONG, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED_LONG and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void a11(void){ int *in, *out, *sol; int i, fnderr=0; in = (int *)malloc( count * sizeof(int) ); out = (int *)malloc( count * sizeof(int) ); sol = (int *)malloc( count * sizeof(int) ); for (i=0; i<count; i++) { *(in + i) = 1; *(sol + i) = 1; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_INT, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_INT and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void b11(void){ long *in, *out, *sol; int i, fnderr=0; in = (long *)malloc( count * sizeof(long) ); out = (long *)malloc( count * sizeof(long) ); sol = (long *)malloc( count * sizeof(long) ); for (i=0; i<count; i++) { *(in + i) = 1; *(sol + i) = 1; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_LONG, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_LONG and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void c11(void){ short *in, *out, *sol; int i, fnderr=0; in = (short *)malloc( count * sizeof(short) ); out = (short *)malloc( count * sizeof(short) ); sol = (short *)malloc( count * sizeof(short) ); for (i=0; i<count; i++) { *(in + i) = 1; *(sol + i) = 1; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_SHORT, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_SHORT and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void d11(void){ unsigned short *in, *out, *sol; int i, fnderr=0; in = (unsigned short *)malloc( count * sizeof(unsigned short) ); out = (unsigned short *)malloc( count * sizeof(unsigned short) ); sol = (unsigned short *)malloc( count * sizeof(unsigned short) ); for (i=0; i<count; i++) { *(in + i) = 1; *(sol + i) = 1; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED_SHORT, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED_SHORT and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void e11(void){ unsigned *in, *out, *sol; int i, fnderr=0; in = (unsigned *)malloc( count * sizeof(unsigned) ); out = (unsigned *)malloc( count * sizeof(unsigned) ); sol = (unsigned *)malloc( count * sizeof(unsigned) ); for (i=0; i<count; i++) { *(in + i) = 1; *(sol + i) = 1; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void f11(void){ unsigned long *in, *out, *sol; int i, fnderr=0; in = (unsigned long *)malloc( count * sizeof(unsigned long) ); out = (unsigned long *)malloc( count * sizeof(unsigned long) ); sol = (unsigned long *)malloc( count * sizeof(unsigned long) ); for (i=0; i<count; i++) { *(in + i) = 1; *(sol + i) = 1; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED_LONG, MPI_LAND, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED_LONG and op MPI_LAND\n", rank ); free( in ); free( out ); free( sol );}void a12(void){ int *in, *out, *sol; int i, fnderr=0; in = (int *)malloc( count * sizeof(int) ); out = (int *)malloc( count * sizeof(int) ); sol = (int *)malloc( count * sizeof(int) ); for (i=0; i<count; i++) { *(in + i) = rank & 0x3; *(sol + i) = (size < 3) ? size - 1 : 0x3; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_INT, MPI_BOR, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_INT and op MPI_BOR\n", rank ); free( in ); free( out ); free( sol );}void b12(void){ long *in, *out, *sol; int i, fnderr=0; in = (long *)malloc( count * sizeof(long) ); out = (long *)malloc( count * sizeof(long) ); sol = (long *)malloc( count * sizeof(long) ); for (i=0; i<count; i++) { *(in + i) = rank & 0x3; *(sol + i) = (size < 3) ? size - 1 : 0x3; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_LONG, MPI_BOR, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_LONG and op MPI_BOR\n", rank ); free( in ); free( out ); free( sol );}void c12(void){ short *in, *out, *sol; int i, fnderr=0; in = (short *)malloc( count * sizeof(short) ); out = (short *)malloc( count * sizeof(short) ); sol = (short *)malloc( count * sizeof(short) ); for (i=0; i<count; i++) { *(in + i) = rank & 0x3; *(sol + i) = (size < 3) ? size - 1 : 0x3; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_SHORT, MPI_BOR, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_SHORT and op MPI_BOR\n", rank ); free( in ); free( out ); free( sol );}void d12(void){ unsigned short *in, *out, *sol; int i, fnderr=0; in = (unsigned short *)malloc( count * sizeof(unsigned short) ); out = (unsigned short *)malloc( count * sizeof(unsigned short) ); sol = (unsigned short *)malloc( count * sizeof(unsigned short) ); for (i=0; i<count; i++) { *(in + i) = rank & 0x3; *(sol + i) = (size < 3) ? size - 1 : 0x3; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED_SHORT, MPI_BOR, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED_SHORT and op MPI_BOR\n", rank ); free( in ); free( out ); free( sol );}void e12(void){ unsigned *in, *out, *sol; int i, fnderr=0; in = (unsigned *)malloc( count * sizeof(unsigned) ); out = (unsigned *)malloc( count * sizeof(unsigned) ); sol = (unsigned *)malloc( count * sizeof(unsigned) ); for (i=0; i<count; i++) { *(in + i) = rank & 0x3; *(sol + i) = (size < 3) ? size - 1 : 0x3; *(out + i) = 0; } MPI_Allreduce( in, out, count, MPI_UNSIGNED, MPI_BOR, comm ); for (i=0; i<count; i++) { if (*(out + i) != *(sol + i)) {errcnt++; fnderr++;}} if (fnderr) fprintf( stderr, "(%d) Error for type MPI_UNSIGNED and op MPI_BOR\n", rank ); free( in ); free( out ); free( sol );}void f12(void){ unsigned long *in, *out, *sol; int i, fnderr=0; in = (unsigned long *)malloc( count * sizeof(unsigned long) ); out = (unsigned long *)malloc( count * sizeof(unsigned long) ); sol = (unsigned long *)malloc( count * sizeof(unsigned long) ); for (i=0; i<count; i++) { *(in + i) = rank & 0x3; *(sol + i) = (size < 3) ? size - 1 : 0x3; *(out + i) = 0; }
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -