![]() |
User Manual, Developers Guide and API Documentation |
![]() |
00001 /******************************************************************************* 00002 * This file is part of openWNS (open Wireless Network Simulator) 00003 * _____________________________________________________________________________ 00004 * 00005 * Copyright (C) 2004-2007 00006 * Chair of Communication Networks (ComNets) 00007 * Kopernikusstr. 16, D-52074 Aachen, Germany 00008 * phone: ++49-241-80-27910, 00009 * fax: ++49-241-80-22242 00010 * email: info@openwns.org 00011 * www: http://www.openwns.org 00012 * _____________________________________________________________________________ 00013 * 00014 * openWNS is free software; you can redistribute it and/or modify it under the 00015 * terms of the GNU Lesser General Public License version 2 as published by the 00016 * Free Software Foundation; 00017 * 00018 * openWNS is distributed in the hope that it will be useful, but WITHOUT ANY 00019 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR 00020 * A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more 00021 * details. 00022 * 00023 * You should have received a copy of the GNU Lesser General Public License 00024 * along with this program. If not, see <http://www.gnu.org/licenses/>. 00025 * 00026 ******************************************************************************/ 00027 00028 #include <WNS/Assure.hpp> 00029 #include <WNS/StopWatch.hpp> 00030 00031 using namespace wns; 00032 00033 StopWatch::StopWatch() : 00034 begin_(), 00035 end_(), 00036 isRunning_(false) 00037 { 00038 // init to zero 00039 gettimeofday(&begin_, NULL); 00040 end_ = begin_; 00041 } 00042 00043 void 00044 StopWatch::start() 00045 { 00046 assure(isRunning_ == false, "Must first call stop()"); 00047 gettimeofday(&begin_, NULL); 00048 isRunning_ = true; 00049 } 00050 00051 double 00052 StopWatch::stop() 00053 { 00054 assure(isRunning_ == true, "Must first call start()"); 00055 gettimeofday(&end_, NULL); 00056 isRunning_ = false; 00057 return getInSeconds(); 00058 } 00059 00060 double 00061 StopWatch::getInSeconds() const 00062 { 00063 assure(isRunning_ == false, "Must first call stop()"); 00064 return (static_cast<double>(end_.tv_sec) + static_cast<double>(end_.tv_usec)/1E6) - 00065 (static_cast<double>(begin_.tv_sec) + static_cast<double>(begin_.tv_usec)/1E6); 00066 } 00067 00068 std::string 00069 StopWatch::doToString() const 00070 { 00071 std::stringstream ss; 00072 ss << getInSeconds() << " s"; 00073 return ss.str(); 00074 } 00075
1.5.5