| Index: source/libvpx/test/aq_segment_test.cc
 | 
| ===================================================================
 | 
| --- source/libvpx/test/aq_segment_test.cc	(revision 0)
 | 
| +++ source/libvpx/test/aq_segment_test.cc	(revision 0)
 | 
| @@ -0,0 +1,119 @@
 | 
| +/*
 | 
| + *  Copyright (c) 2012 The WebM 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 <climits>
 | 
| +#include <vector>
 | 
| +#include "third_party/googletest/src/include/gtest/gtest.h"
 | 
| +#include "test/codec_factory.h"
 | 
| +#include "test/encode_test_driver.h"
 | 
| +#include "test/i420_video_source.h"
 | 
| +#include "test/util.h"
 | 
| +
 | 
| +namespace {
 | 
| +
 | 
| +class AqSegmentTest : public ::libvpx_test::EncoderTest,
 | 
| +    public ::libvpx_test::CodecTestWith2Params<
 | 
| +        libvpx_test::TestMode, int> {
 | 
| + protected:
 | 
| +  AqSegmentTest() : EncoderTest(GET_PARAM(0)) {}
 | 
| +
 | 
| +  virtual void SetUp() {
 | 
| +    InitializeConfig();
 | 
| +    SetMode(GET_PARAM(1));
 | 
| +    set_cpu_used_ = GET_PARAM(2);
 | 
| +    aq_mode_ = 0;
 | 
| +  }
 | 
| +
 | 
| +  virtual void PreEncodeFrameHook(::libvpx_test::VideoSource *video,
 | 
| +                                  ::libvpx_test::Encoder *encoder) {
 | 
| +    if (video->frame() == 1) {
 | 
| +      encoder->Control(VP8E_SET_CPUUSED, set_cpu_used_);
 | 
| +      encoder->Control(VP9E_SET_AQ_MODE, aq_mode_);
 | 
| +      encoder->Control(VP8E_SET_MAX_INTRA_BITRATE_PCT, 100);
 | 
| +    }
 | 
| +  }
 | 
| +
 | 
| +  virtual void FramePktHook(const vpx_codec_cx_pkt_t *pkt) {
 | 
| +    if (pkt->data.frame.flags & VPX_FRAME_IS_KEY) {
 | 
| +    }
 | 
| +  }
 | 
| +  int set_cpu_used_;
 | 
| +  int aq_mode_;
 | 
| +};
 | 
| +
 | 
| +// Validate that this AQ segmentation mode (AQ=1, variance_ap)
 | 
| +// encodes and decodes without a mismatch.
 | 
| +TEST_P(AqSegmentTest, TestNoMisMatchAQ1) {
 | 
| +  cfg_.rc_min_quantizer = 8;
 | 
| +  cfg_.rc_max_quantizer = 56;
 | 
| +  cfg_.rc_end_usage = VPX_CBR;
 | 
| +  cfg_.g_lag_in_frames = 0;
 | 
| +  cfg_.rc_buf_initial_sz = 500;
 | 
| +  cfg_.rc_buf_optimal_sz = 500;
 | 
| +  cfg_.rc_buf_sz = 1000;
 | 
| +  cfg_.rc_target_bitrate = 300;
 | 
| +
 | 
| +  aq_mode_ = 1;
 | 
| +
 | 
| +  ::libvpx_test::I420VideoSource video("hantro_collage_w352h288.yuv", 352, 288,
 | 
| +                                        30, 1, 0, 100);
 | 
| +
 | 
| +  ASSERT_NO_FATAL_FAILURE(RunLoop(&video));
 | 
| +}
 | 
| +
 | 
| +// Validate that this AQ segmentation mode (AQ=2, complexity_aq)
 | 
| +// encodes and decodes without a mismatch.
 | 
| +TEST_P(AqSegmentTest, TestNoMisMatchAQ2) {
 | 
| +  cfg_.rc_min_quantizer = 8;
 | 
| +  cfg_.rc_max_quantizer = 56;
 | 
| +  cfg_.rc_end_usage = VPX_CBR;
 | 
| +  cfg_.g_lag_in_frames = 0;
 | 
| +  cfg_.rc_buf_initial_sz = 500;
 | 
| +  cfg_.rc_buf_optimal_sz = 500;
 | 
| +  cfg_.rc_buf_sz = 1000;
 | 
| +  cfg_.rc_target_bitrate = 300;
 | 
| +
 | 
| +  aq_mode_ = 2;
 | 
| +
 | 
| +  ::libvpx_test::I420VideoSource video("hantro_collage_w352h288.yuv", 352, 288,
 | 
| +                                        30, 1, 0, 100);
 | 
| +
 | 
| +  ASSERT_NO_FATAL_FAILURE(RunLoop(&video));
 | 
| +}
 | 
| +
 | 
| +// Validate that this AQ segmentation mode (AQ=3, cyclic_refresh_aq)
 | 
| +// encodes and decodes without a mismatch.
 | 
| +TEST_P(AqSegmentTest, TestNoMisMatchAQ3) {
 | 
| +  cfg_.rc_min_quantizer = 8;
 | 
| +  cfg_.rc_max_quantizer = 56;
 | 
| +  cfg_.rc_end_usage = VPX_CBR;
 | 
| +  cfg_.g_lag_in_frames = 0;
 | 
| +  cfg_.rc_buf_initial_sz = 500;
 | 
| +  cfg_.rc_buf_optimal_sz = 500;
 | 
| +  cfg_.rc_buf_sz = 1000;
 | 
| +  cfg_.rc_target_bitrate = 300;
 | 
| +
 | 
| +  aq_mode_ = 3;
 | 
| +
 | 
| +  ::libvpx_test::I420VideoSource video("hantro_collage_w352h288.yuv", 352, 288,
 | 
| +                                        30, 1, 0, 100);
 | 
| +
 | 
| +  ASSERT_NO_FATAL_FAILURE(RunLoop(&video));
 | 
| +}
 | 
| +
 | 
| +using std::tr1::make_tuple;
 | 
| +
 | 
| +#define VP9_FACTORY \
 | 
| +  static_cast<const libvpx_test::CodecFactory*> (&libvpx_test::kVP9)
 | 
| +
 | 
| +VP9_INSTANTIATE_TEST_CASE(AqSegmentTest,
 | 
| +                          ::testing::Values(::libvpx_test::kRealTime,
 | 
| +                                            ::libvpx_test::kOnePassGood),
 | 
| +                                            ::testing::Range(3, 9));
 | 
| +}  // namespace
 | 
| 
 |