blob: ed20073e25f17ac6ba52bacd1e6d4acb9347e51e [file] [log] [blame]
// Copyright 2014 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 CC_BASE_ROLLING_TIME_DELTA_HISTORY_H_
#define CC_BASE_ROLLING_TIME_DELTA_HISTORY_H_
#include <stddef.h>
#include <set>
#include "base/containers/circular_deque.h"
#include "base/macros.h"
#include "base/time/time.h"
#include "cc/base/base_export.h"
namespace cc {
// Stores a limited number of samples. When the maximum size is reached, each
// insertion results in the deletion of the oldest remaining sample.
class CC_BASE_EXPORT RollingTimeDeltaHistory {
public:
explicit RollingTimeDeltaHistory(size_t max_size);
~RollingTimeDeltaHistory();
void InsertSample(base::TimeDelta time);
void Clear();
// Returns the smallest sample that is greater than or equal to the specified
// percent of samples. If there aren't any samples, returns base::TimeDelta().
base::TimeDelta Percentile(double percent) const;
private:
typedef std::multiset<base::TimeDelta> TimeDeltaMultiset;
TimeDeltaMultiset sample_set_;
base::circular_deque<TimeDeltaMultiset::iterator> chronological_sample_deque_;
size_t max_size_;
DISALLOW_COPY_AND_ASSIGN(RollingTimeDeltaHistory);
};
} // namespace cc
#endif // CC_BASE_ROLLING_TIME_DELTA_HISTORY_H_