User Manual, Developers Guide and API Documentation

StopWatch.cpp

Go to the documentation of this file.
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 

Generated on Sat May 26 03:31:53 2012 for openWNS by  doxygen 1.5.5