User Manual, Developers Guide and API Documentation

WeightedAverage.hpp

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. 5, 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 #ifndef WNS_WEIGHTEDAVERAGE_HPP
00029 #define WNS_WEIGHTEDAVERAGE_HPP
00030 
00031 #include <WNS/Average.hpp>
00032 #include <WNS/Assure.hpp>
00033 
00034 namespace wns {
00039     template <typename C>
00040     class WeightedAverage
00041         : public Average<C>
00042     {
00043     public:
00047         WeightedAverage()
00048             : Average<C>(),
00049               totalWeight(0.0)
00050         {};
00051 
00055         virtual ~WeightedAverage()
00056         {};
00057 
00061         virtual void reset()
00062         {
00063             totalWeight = 0.0;
00064             Average<C>::reset();
00065         };
00066 
00070         virtual void put(const C& c)
00071         {
00072             put(c, 1);
00073         };
00074 
00078         virtual void put(const C& c, double w)
00079         {
00080             assure(w>=0, "Only values greater or equal to zero allowed");
00081             totalWeight += w;
00082             if(totalWeight > 0) {
00083                 this->mean *= (1-w/totalWeight);
00084                 this->mean += convertForAveraging(c)*w/totalWeight;
00085             }
00086         };
00087 
00088     private:
00092         double totalWeight;
00093     };
00094 }
00095 
00096 #endif // WNS_WEIGHTEDAVERAGE_HPP
00097 
00098 

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