// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

// RunningAverage defined in this file is used to generate statistics for
// bandwidth, latency and other performance metrics for remoting. Usually
// this data comes in as a stream and fluctuates a lot. They are processed by
// this class to generate a more stable value by taking average within a
// window of data points.

// All classes defined are thread-safe.

#ifndef REMOTING_BASE_RUNNING_AVERAGE_H_
#define REMOTING_BASE_RUNNING_AVERAGE_H_

#include <deque>

#include "base/basictypes.h"
#include "base/synchronization/lock.h"
#include "base/time.h"

namespace remoting {

class RunningAverage {
 public:
  // Construct a running average counter for a specific window size. The
  // |windows_size| most recent values are kept and the average is reported.
  RunningAverage(int window_size);

  virtual ~RunningAverage();

  // Record the provided data point.
  void Record(int64 value);

  // Return the average of data points in the last window.
  double Average();

 private:
  // Size of the window. This is of type size_t to avoid casting when comparing
  // with the size of |data_points_|.
  size_t window_size_;

  // Protects |data_points_| and |sum_|.
  base::Lock lock_;

  // Keep the values of all the data points.
  std::deque<int64> data_points_;

  // Sum of values in |data_points_|.
  int64 sum_;

  DISALLOW_COPY_AND_ASSIGN(RunningAverage);
};

}  // namespace remoting

#endif  // REMOTING_BASE_RUNNING_AVERAGE_H_