⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 infoorderx.cxx

📁 mpi并行计算的c++代码 可用vc或gcc编译通过 可以用来搭建并行计算试验环境
💻 CXX
字号:
/* -*- Mode: C++; c-basic-offset:4 ; -*- *//* * *  (C) 2003 by Argonne National Laboratory. *      See COPYRIGHT in top-level directory. */#include "mpi.h"#include "mpitestconf.h"#ifdef HAVE_IOSTREAM// Not all C++ compilers have iostream instead of iostream.h#include <iostream>#ifdef HAVE_NAMESPACE_STD// Those that do often need the std namespace; otherwise, a bare "cout"// is likely to fail to compileusing namespace std;#endif#else#include <iostream.h>#endif#include "mpitestcxx.h"#ifdef HAVE_STRING_H#include <string.h>#endif#define NKEYS 3int main( int argc, char *argv[] ){    int errs = 0;    MPI::Info info;    const char *keys1[NKEYS] = { "file", "soft", "host" };    const char *values1[NKEYS] = { "runfile.txt", "2:1000:4,3:1000:7", 				   "myhost.myorg.org" };    char *value;    int i, flag;    MTest_Init();    value = new char [MPI::MAX_INFO_VAL];    /* 1,2,3 */    info = MPI::Info::Create();    /* Use only named keys incase the info implementation only supports       the predefined keys (e.g., IBM) */    for (i=0; i<NKEYS; i++) {	info.Set( keys1[i], values1[i] );    }    /* Check that all values are present */    for (i=0; i<NKEYS; i++) {	flag = info.Get( keys1[i], MPI::MAX_INFO_VAL, value  );	if (!flag) {	    errs++;	    cout << "No value for key " << keys1[i] << "\n";	}	if (strcmp( value, values1[i] )) {	    errs++;	    cout << "Incorrect value for key " << keys1[i] << "\n";	}    }    info.Free();    /* 3,2,1 */    info = MPI::Info::Create();    /* Use only named keys incase the info implementation only supports       the predefined keys (e.g., IBM) */    for (i=NKEYS-1; i>=0; i--) {	info.Set( keys1[i], values1[i] );    }    /* Check that all values are present */    for (i=0; i<NKEYS; i++) {	flag = info.Get( keys1[i], MPI::MAX_INFO_VAL, value );	if (!flag) {	    errs++;	    cout << "No value for key " << keys1[i] << "\n";	}	if (strcmp( value, values1[i] )) {	    errs++;	    cout << "Incorrect value for key " << keys1[i] << "\n";	}    }    info.Free();    /* 1,3,2 */    info = MPI::Info::Create();    /* Use only named keys incase the info implementation only supports       the predefined keys (e.g., IBM) */    info.Set( keys1[0], values1[0] );    info.Set( keys1[2], values1[2] );    info.Set( keys1[1], values1[1] );    /* Check that all values are present */    for (i=0; i<NKEYS; i++) {	flag = info.Get( keys1[i], MPI::MAX_INFO_VAL, value );	if (!flag) {	    errs++;	    cout << "No value for key " << keys1[i] << "\n";	}	if (strcmp( value, values1[i] )) {	    errs++;	    cout << "Incorrect value for key " << keys1[i] << "\n";	}    }    info.Free( );    /* 2,1,3 */    info = MPI::Info::Create();    /* Use only named keys incase the info implementation only supports       the predefined keys (e.g., IBM) */    info.Set( keys1[1], values1[1] );    info.Set( keys1[0], values1[0] );    info.Set( keys1[2], values1[2] );    /* Check that all values are present */    for (i=0; i<NKEYS; i++) {	flag = info.Get( keys1[i], MPI::MAX_INFO_VAL, value );	if (!flag) {	    errs++;	    cout << "No value for key " << keys1[i] << "\n";	}	if (strcmp( value, values1[i] )) {	    errs++;	    cout << "Incorrect value for key " << keys1[i] << "\n";	}    }    info.Free( );    /* 2,3,1 */    info = MPI::Info::Create();    /* Use only named keys incase the info implementation only supports       the predefined keys (e.g., IBM) */    info.Set( keys1[1], values1[1] );    info.Set( keys1[2], values1[2] );    info.Set( keys1[0], values1[0] );    /* Check that all values are present */    for (i=0; i<NKEYS; i++) {	flag = info.Get( keys1[i], MPI::MAX_INFO_VAL, value );	if (!flag) {	    errs++;	    cout << "No value for key " << keys1[i] << "\n";	}	if (strcmp( value, values1[i] )) {	    errs++;	    cout << "Incorrect value for key " << keys1[i] << "\n";	}    }    info.Free();        /* 3,1,2 */    info = MPI::Info::Create();    /* Use only named keys incase the info implementation only supports       the predefined keys (e.g., IBM) */    info.Set( keys1[2], values1[2] );    info.Set( keys1[0], values1[0] );    info.Set( keys1[1], values1[1] );    /* Check that all values are present */    for (i=0; i<NKEYS; i++) {	flag = info.Get( keys1[i], MPI::MAX_INFO_VAL, value );	if (!flag) {	    errs++;	    cout << "No value for key " << keys1[i] << "\n";	}	if (strcmp( value, values1[i] )) {	    errs++;	    cout << "Incorrect value for key " << keys1[i] << "\n";	}    }    info.Free();    delete [] value;        MTest_Finalize( errs );    MPI::Finalize();    return 0;  }

⌨️ 快捷键说明

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