// 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.

#ifndef REMOTING_BASE_RUNNING_AVERAGE_H_
#define REMOTING_BASE_RUNNING_AVERAGE_H_

#include <deque>

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

namespace remoting {

// Calculates the average of the most recent N recorded samples.
// This is typically used to smooth out random variation in point samples
// over bandwidth, frame rate, etc.
class RunningAverage {
 public:
  // Constructs a helper to average over the |window_size| most recent samples.
  explicit RunningAverage(int window_size);
  virtual ~RunningAverage();

  // Records a point sample.
  void Record(int64 value);

  // Returns the average over up to |window_size| of the most recent samples.
  double Average();

 private:
  // Stores the desired window size, as size_t to avoid casting when comparing
  // with the size of |data_points_|.
  const size_t window_size_;

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

  // Stores the |window_size| most recently recorded samples.
  std::deque<int64> data_points_;

  // Holds the sum of the samples in |data_points_|.
  int64 sum_;

  DISALLOW_COPY_AND_ASSIGN(RunningAverage);
};

}  // namespace remoting

#endif  // REMOTING_BASE_RUNNING_AVERAGE_H_