EMANE  1.2.1
runningaverage.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2013-2014 - Adjacent Link LLC, Bridgewater, New Jersey
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  * * Redistributions in binary form must reproduce the above copyright
12  * notice, this list of conditions and the following disclaimer in
13  * the documentation and/or other materials provided with the
14  * distribution.
15  * * Neither the name of Adjacent Link, LLC nor the names of its
16  * contributors may be used to endorse or promote products derived
17  * from this software without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30  * POSSIBILITY OF SUCH DAMAGE.
31  */
32 
33 #include "emane/statisticnumeric.h"
34 
35 #ifndef EMANEUTILSRUNNINGAVERAGE_HEADER_
36 #define EMANEUTILSRUNNINGAVERAGE_HEADER_
37 
38 namespace EMANE
39 {
40  namespace Utils
41  {
47  template<class T>
49  {
50  public:
55  pStatistic_{},
56  value_{},
57  count_{}
58  {}
59 
68  void update(T value)
69  {
70  T newValue{value};
71 
72  if(count_)
73  {
74  newValue = ((value_ * count_) + value) / (count_ + 1);
75  }
76 
77  // if pStatistic_ is still set to value_ set it to
78  // newValue otherwise it was cleared, set it to value
79  if(pStatistic_->compareExchange(value_,newValue,value))
80  {
81  value_ = newValue;
82  ++count_;
83  }
84  else
85  {
86  value_= value;
87  count_ = 1;
88  }
89  }
90 
97  {
98  pStatistic_ = p;
99  }
100 
101  private:
102  StatisticNumeric<T> * pStatistic_;
103  T value_;
104  size_t count_;
105  };
106  }
107 }
108 
109 #endif // EMANEUTILSRUNNINGAVERAGE_HEADER_
A running average statistic wrapper.
Definition: agent.h:43
void registerStatistic(StatisticNumeric< T > *p)
Defines a numeric statistic and its operations.