00001 #ifndef MPI_STATS_CPP 00002 #define MPI_STATS_CPP 00003 00004 //-------------------------------------------------------------------- 00005 // 00006 // This file is part of PEACE. 00007 // 00008 // PEACE is free software: you can redistribute it and/or modify it 00009 // under the terms of the GNU General Public License as published by 00010 // the Free Software Foundation, either version 3 of the License, or 00011 // (at your option) any later version. 00012 // 00013 // PEACE is distributed in the hope that it will be useful, but 00014 // WITHOUT ANY WARRANTY; without even the implied warranty of 00015 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00016 // General Public License for more details. 00017 // 00018 // You should have received a copy of the GNU General Public License 00019 // along with PEACE. If not, see <http://www.gnu.org/licenses/>. 00020 // 00021 // Miami University makes no representations or warranties about the 00022 // suitability of the software, either express or implied, including 00023 // but not limited to the implied warranties of merchantability, 00024 // fitness for a particular purpose, or non-infringement. Miami 00025 // University shall not be liable for any damages suffered by licensee 00026 // as a result of using, result of using, modifying or distributing 00027 // this software or its derivatives. 00028 // 00029 // By using or copying this Software, Licensee agrees to abide by the 00030 // intellectual property laws, and all other applicable laws of the 00031 // U.S., and the terms of GNU General Public License (version 3). 00032 // 00033 // Authors: Dhananjai M. Rao raodm@muohio.edu 00034 // 00035 //--------------------------------------------------------------------- 00036 00037 #include "MPIStats.h" 00038 00039 // Define and initialize various static stats. counters in the 00040 // MPIStats class for use. 00041 00042 double MPIStats::idleTime = 0.0; 00043 int MPIStats::sendCount = 0; 00044 int MPIStats::recvCount = 0; 00045 int MPIStats::bcastCount = 0; 00046 int MPIStats::probeCount = 0; 00047 00048 void 00049 MPIStats::displayStats(std::ostream& os, const std::string& indent) { 00050 os << indent << "No. of calls to send : " << sendCount << "\n" 00051 << indent << "No. of calls to recv : " << recvCount << "\n" 00052 << indent << "No. of calls to bCast : " << bcastCount << "\n" 00053 << indent << "No. of calls to probe : " << probeCount << "\n" 00054 << indent << "Net amount of idle time : " << idleTime 00055 << " (sec)" << std::endl; 00056 } 00057 00058 #endif