| /* | 
 |  *  Copyright (c) 2016 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. | 
 |  */ | 
 |  | 
 | #include "modules/video_coding/histogram.h" | 
 |  | 
 | #include <algorithm> | 
 |  | 
 | #include "rtc_base/numerics/sequence_number_util.h" | 
 |  | 
 | namespace webrtc { | 
 | namespace video_coding { | 
 | Histogram::Histogram(size_t num_buckets, size_t max_num_values) { | 
 |   RTC_DCHECK_GT(num_buckets, 0); | 
 |   RTC_DCHECK_GT(max_num_values, 0); | 
 |   buckets_.resize(num_buckets); | 
 |   values_.reserve(max_num_values); | 
 |   index_ = 0; | 
 | } | 
 |  | 
 | void Histogram::Add(size_t value) { | 
 |   value = std::min<size_t>(value, buckets_.size() - 1); | 
 |   if (index_ < values_.size()) { | 
 |     --buckets_[values_[index_]]; | 
 |     RTC_DCHECK_LT(values_[index_], buckets_.size()); | 
 |     values_[index_] = value; | 
 |   } else { | 
 |     values_.emplace_back(value); | 
 |   } | 
 |  | 
 |   ++buckets_[value]; | 
 |   index_ = (index_ + 1) % values_.capacity(); | 
 | } | 
 |  | 
 | size_t Histogram::InverseCdf(float probability) const { | 
 |   RTC_DCHECK_GE(probability, 0.f); | 
 |   RTC_DCHECK_LE(probability, 1.f); | 
 |   RTC_DCHECK_GT(values_.size(), 0ul); | 
 |  | 
 |   size_t bucket = 0; | 
 |   float accumulated_probability = 0; | 
 |   while (accumulated_probability < probability && bucket < buckets_.size()) { | 
 |     accumulated_probability += | 
 |         static_cast<float>(buckets_[bucket]) / values_.size(); | 
 |     ++bucket; | 
 |   } | 
 |   return bucket; | 
 | } | 
 |  | 
 | size_t Histogram::NumValues() const { | 
 |   return values_.size(); | 
 | } | 
 |  | 
 | }  // namespace video_coding | 
 | }  // namespace webrtc |