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

📄 functions_inln.h

📁 MPI stands for the Message Passing Interface. Written by the MPI Forum (a large committee comprising
💻 H
字号:
// -*- c++ -*-// // Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana//                         University Research and Technology//                         Corporation.  All rights reserved.// Copyright (c) 2004-2005 The University of Tennessee and The University//                         of Tennessee Research Foundation.  All rights//                         reserved.// Copyright (c) 2004-2005 High Performance Computing Center Stuttgart, //                         University of Stuttgart.  All rights reserved.// Copyright (c) 2004-2005 The Regents of the University of California.//                         All rights reserved.// $COPYRIGHT$// // Additional copyrights may follow// // $HEADER$//#include <string.h>//// Point-to-Point Communication//inline void MPI::Attach_buffer(void* buffer, int size){  (void)MPI_Buffer_attach(buffer, size);}inline int MPI::Detach_buffer(void*& buffer){  int size;  (void)MPI_Buffer_detach(&buffer, &size);  return size;}//// Process Topologies//inline voidMPI::Compute_dims(int nnodes, int ndims, int dims[]){  (void)MPI_Dims_create(nnodes, ndims, dims);}//// Environmental Inquiry//inline void MPI::Get_processor_name(char* name, int& resultlen){  (void)MPI_Get_processor_name(name, &resultlen);}inline voidMPI::Get_error_string(int errorcode, char* string, int& resultlen){  (void)MPI_Error_string(errorcode, string, &resultlen);}inline int MPI::Get_error_class(int errorcode) {  int errorclass;  (void)MPI_Error_class(errorcode, &errorclass);  return errorclass;}inline double MPI::Wtime(){  return (MPI_Wtime());}inline double MPI::Wtick(){  return (MPI_Wtick());}inline voidMPI::Real_init(){    MPI::InitializeIntercepts();}inline voidMPI::Init(int& argc, char**& argv){  (void)MPI_Init(&argc, &argv);  Real_init();}inline voidMPI::Init(){  (void)MPI_Init(0, 0);  Real_init();}inline voidMPI::Finalize(){  FinalizeIntercepts();  (void)MPI_Finalize();}inline boolMPI::Is_initialized(){  int t;  (void)MPI_Initialized(&t);  return OPAL_INT_TO_BOOL(t);}inline boolMPI::Is_finalized(){  int t;  (void)MPI_Finalized(&t);  return OPAL_INT_TO_BOOL(t);}//// External Interfaces//inline intMPI::Init_thread(int required){  int provided;  (void) MPI_Init_thread(0, NULL, required, &provided);  Real_init();  return provided;}inline intMPI::Init_thread(int& argc, char**& argv, int required){  int provided;  (void) MPI_Init_thread(&argc, &argv, required, &provided);  Real_init();  return provided;}inline boolMPI::Is_thread_main(){  int flag;  (void) MPI_Is_thread_main(&flag);  return OPAL_INT_TO_BOOL(flag == 1);}inline intMPI::Query_thread(){  int provided;  (void) MPI_Query_thread(&provided);  return provided;}//// Miscellany//inline void*MPI::Alloc_mem(MPI::Aint size, const MPI::Info& info) {  void* baseptr;  (void) MPI_Alloc_mem(size, info, &baseptr);  return baseptr;}inline voidMPI::Free_mem(void* base){  (void) MPI_Free_mem(base);}//// Process Creation//inline voidMPI::Close_port(const char* port_name) {  (void) MPI_Close_port(const_cast<char *>(port_name));}inline voidMPI::Lookup_name(const char * service_name, 			const MPI::Info& info,			char* port_name){  (void) MPI_Lookup_name(const_cast<char *>(service_name), info, port_name);}inline voidMPI::Open_port(const MPI::Info& info, char* port_name){  (void) MPI_Open_port(info, port_name);}inline voidMPI::Publish_name(const char* service_name, 			 const MPI::Info& info,			 const char* port_name){  (void) MPI_Publish_name(const_cast<char *>(service_name), info,                          const_cast<char *>(port_name));}inline voidMPI::Unpublish_name(const char* service_name, 			   const MPI::Info& info,			   const char* port_name){  (void)MPI_Unpublish_name(const_cast<char *>(service_name), info,                           const_cast<char *>(port_name));}//// Profiling//inline voidMPI::Pcontrol(const int level, ...){  va_list ap;  va_start(ap, level);   (void)MPI_Pcontrol(level, ap);  va_end(ap);}inline voidMPI::Get_version(int& version, int& subversion){  (void)MPI_Get_version(&version, &subversion);}inline MPI::AintMPI::Get_address(void* location){  MPI::Aint ret;  MPI_Get_address(location, &ret);  return ret;}

⌨️ 快捷键说明

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