LCOV - code coverage report
Current view: top level - media/webrtc/trunk/webrtc/modules/congestion_controller - median_slope_estimator.h (source / functions) Hit Total Coverage
Test: output.info Lines: 0 7 0.0 %
Date: 2017-07-14 16:53:18 Functions: 0 4 0.0 %
Legend: Lines: hit not hit

          Line data    Source code
       1             : /*
       2             :  *  Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
       3             :  *
       4             :  *  Use of this source code is governed by a BSD-style license
       5             :  *  that can be found in the LICENSE file in the root of the source
       6             :  *  tree. An additional intellectual property rights grant can be found
       7             :  *  in the file PATENTS.  All contributing project authors may
       8             :  *  be found in the AUTHORS file in the root of the source tree.
       9             :  */
      10             : #ifndef WEBRTC_MODULES_CONGESTION_CONTROLLER_MEDIAN_SLOPE_ESTIMATOR_H_
      11             : #define WEBRTC_MODULES_CONGESTION_CONTROLLER_MEDIAN_SLOPE_ESTIMATOR_H_
      12             : 
      13             : #include <stddef.h>
      14             : #include <stdint.h>
      15             : 
      16             : #include <list>
      17             : #include <vector>
      18             : 
      19             : #include "webrtc/base/constructormagic.h"
      20             : #include "webrtc/base/numerics/percentile_filter.h"
      21             : 
      22             : namespace webrtc {
      23             : 
      24             : class MedianSlopeEstimator {
      25             :  public:
      26             :   // |window_size| is the number of points required to compute a trend line.
      27             :   // |threshold_gain| is used to scale the trendline slope for comparison to
      28             :   // the old threshold. Once the old estimator has been removed (or the
      29             :   // thresholds been merged into the estimators), we can just set the
      30             :   // threshold instead of setting a gain.
      31             :   MedianSlopeEstimator(size_t window_size, double threshold_gain);
      32             :   ~MedianSlopeEstimator();
      33             : 
      34             :   // Update the estimator with a new sample. The deltas should represent deltas
      35             :   // between timestamp groups as defined by the InterArrival class.
      36             :   void Update(double recv_delta_ms,
      37             :               double send_delta_ms,
      38             :               int64_t arrival_time_ms);
      39             : 
      40             :   // Returns the estimated trend k multiplied by some gain.
      41             :   // 0 < k < 1   ->  the delay increases, queues are filling up
      42             :   //   k == 0    ->  the delay does not change
      43             :   //   k <  0    ->  the delay decreases, queues are being emptied
      44           0 :   double trendline_slope() const { return trendline_ * threshold_gain_; }
      45             : 
      46             :   // Returns the number of deltas which the current estimator state is based on.
      47           0 :   unsigned int num_of_deltas() const { return num_of_deltas_; }
      48             : 
      49             :  private:
      50           0 :   struct DelayInfo {
      51           0 :     DelayInfo(int64_t time, double delay, size_t slope_count)
      52           0 :         : time(time), delay(delay) {
      53           0 :       slopes.reserve(slope_count);
      54           0 :     }
      55             :     int64_t time;
      56             :     double delay;
      57             :     std::vector<double> slopes;
      58             :   };
      59             :   // Parameters.
      60             :   const size_t window_size_;
      61             :   const double threshold_gain_;
      62             :   // Used by the existing threshold.
      63             :   unsigned int num_of_deltas_;
      64             :   // Theil-Sen robust line fitting
      65             :   double accumulated_delay_;
      66             :   std::list<DelayInfo> delay_hist_;
      67             :   PercentileFilter<double> median_filter_;
      68             :   double trendline_;
      69             : 
      70             :   RTC_DISALLOW_COPY_AND_ASSIGN(MedianSlopeEstimator);
      71             : };
      72             : }  // namespace webrtc
      73             : 
      74             : #endif  // WEBRTC_MODULES_CONGESTION_CONTROLLER_MEDIAN_SLOPE_ESTIMATOR_H_

Generated by: LCOV version 1.13