![]() |
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. 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
1.5.5