| /* | 
 |  *  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 "test/gtest.h" | 
 |  | 
 | namespace webrtc { | 
 | namespace video_coding { | 
 |  | 
 | class TestHistogram : public ::testing::Test { | 
 |  protected: | 
 |   TestHistogram() : histogram_(5, 10) {} | 
 |   Histogram histogram_; | 
 | }; | 
 |  | 
 | TEST_F(TestHistogram, NumValues) { | 
 |   EXPECT_EQ(0ul, histogram_.NumValues()); | 
 |   histogram_.Add(0); | 
 |   EXPECT_EQ(1ul, histogram_.NumValues()); | 
 | } | 
 |  | 
 | TEST_F(TestHistogram, InverseCdf) { | 
 |   histogram_.Add(0); | 
 |   histogram_.Add(1); | 
 |   histogram_.Add(2); | 
 |   histogram_.Add(3); | 
 |   histogram_.Add(4); | 
 |   EXPECT_EQ(5ul, histogram_.NumValues()); | 
 |   EXPECT_EQ(1ul, histogram_.InverseCdf(0.2f)); | 
 |   EXPECT_EQ(2ul, histogram_.InverseCdf(0.2000001f)); | 
 |   EXPECT_EQ(4ul, histogram_.InverseCdf(0.8f)); | 
 |  | 
 |   histogram_.Add(0); | 
 |   EXPECT_EQ(6ul, histogram_.NumValues()); | 
 |   EXPECT_EQ(1ul, histogram_.InverseCdf(0.2f)); | 
 |   EXPECT_EQ(1ul, histogram_.InverseCdf(0.2000001f)); | 
 | } | 
 |  | 
 | TEST_F(TestHistogram, ReplaceOldValues) { | 
 |   histogram_.Add(0); | 
 |   histogram_.Add(0); | 
 |   histogram_.Add(0); | 
 |   histogram_.Add(0); | 
 |   histogram_.Add(0); | 
 |   histogram_.Add(1); | 
 |   histogram_.Add(1); | 
 |   histogram_.Add(1); | 
 |   histogram_.Add(1); | 
 |   histogram_.Add(1); | 
 |   EXPECT_EQ(10ul, histogram_.NumValues()); | 
 |   EXPECT_EQ(1ul, histogram_.InverseCdf(0.5f)); | 
 |   EXPECT_EQ(2ul, histogram_.InverseCdf(0.5000001f)); | 
 |  | 
 |   histogram_.Add(4); | 
 |   histogram_.Add(4); | 
 |   histogram_.Add(4); | 
 |   histogram_.Add(4); | 
 |   EXPECT_EQ(10ul, histogram_.NumValues()); | 
 |   EXPECT_EQ(1ul, histogram_.InverseCdf(0.1f)); | 
 |   EXPECT_EQ(2ul, histogram_.InverseCdf(0.5f)); | 
 |  | 
 |   histogram_.Add(20); | 
 |   EXPECT_EQ(10ul, histogram_.NumValues()); | 
 |   EXPECT_EQ(2ul, histogram_.InverseCdf(0.5f)); | 
 |   EXPECT_EQ(5ul, histogram_.InverseCdf(0.5000001f)); | 
 | } | 
 |  | 
 | }  // namespace video_coding | 
 | }  // namespace webrtc |