|  | /* | 
|  | *  Copyright 2019 The WebRTC Project Authors. All rights reserved. | 
|  | * | 
|  | *  Use of this source code is governed by a BSD-style license | 
|  | *  that can be found in the LICENSE file in the root of the source | 
|  | *  tree. An additional intellectual property rights grant can be found | 
|  | *  in the file PATENTS.  All contributing project authors may | 
|  | *  be found in the AUTHORS file in the root of the source tree. | 
|  | */ | 
|  |  | 
|  | #ifndef RTC_BASE_NUMERICS_EVENT_BASED_EXPONENTIAL_MOVING_AVERAGE_H_ | 
|  | #define RTC_BASE_NUMERICS_EVENT_BASED_EXPONENTIAL_MOVING_AVERAGE_H_ | 
|  |  | 
|  | #include <cmath> | 
|  | #include <cstdint> | 
|  | #include <limits> | 
|  | #include "absl/types/optional.h" | 
|  |  | 
|  | namespace rtc { | 
|  |  | 
|  | /** | 
|  | * This class implements exponential moving average for time series | 
|  | * estimating both value, variance and variance of estimator based on | 
|  | * https://en.wikipedia.org/w/index.php?title=Moving_average§ion=9#Application_to_measuring_computer_performance | 
|  | * with the additions from nisse@ added to | 
|  | * https://en.wikipedia.org/wiki/Talk:Moving_average. | 
|  | * | 
|  | * A sample gets exponentially less weight so that it's 50% | 
|  | * after |half_time| time units. | 
|  | */ | 
|  | class EventBasedExponentialMovingAverage { | 
|  | public: | 
|  | // |half_time| specifies how much weight will be given to old samples, | 
|  | // see example above. | 
|  | explicit EventBasedExponentialMovingAverage(int half_time); | 
|  |  | 
|  | void AddSample(int64_t now, int value); | 
|  |  | 
|  | double GetAverage() const { return value_; } | 
|  | double GetVariance() const { return sample_variance_; } | 
|  |  | 
|  | // Compute 95% confidence interval assuming that | 
|  | // - variance of samples are normal distributed. | 
|  | // - variance of estimator is normal distributed. | 
|  | // | 
|  | // The returned values specifies the distance from the average, | 
|  | // i.e if X = GetAverage(), m = GetConfidenceInterval() | 
|  | // then a there is 95% likelihood that the observed variables is inside | 
|  | // [ X +/- m ]. | 
|  | double GetConfidenceInterval() const; | 
|  |  | 
|  | // Reset | 
|  | void Reset(); | 
|  |  | 
|  | // Update the half_time. | 
|  | // NOTE: resets estimate too. | 
|  | void SetHalfTime(int half_time); | 
|  |  | 
|  | private: | 
|  | double tau_; | 
|  | double value_ = std::nan("uninit"); | 
|  | double sample_variance_ = std::numeric_limits<double>::infinity(); | 
|  | // This is the ratio between variance of the estimate and variance of samples. | 
|  | double estimator_variance_ = 1; | 
|  | absl::optional<int64_t> last_observation_timestamp_; | 
|  | }; | 
|  |  | 
|  | }  // namespace rtc | 
|  |  | 
|  | #endif  // RTC_BASE_NUMERICS_EVENT_BASED_EXPONENTIAL_MOVING_AVERAGE_H_ |