1*77c1e3ccSAndroid Build Coastguard Worker /*
2*77c1e3ccSAndroid Build Coastguard Worker * Copyright (c) 2021, Alliance for Open Media. All rights reserved.
3*77c1e3ccSAndroid Build Coastguard Worker *
4*77c1e3ccSAndroid Build Coastguard Worker * This source code is subject to the terms of the BSD 2 Clause License and
5*77c1e3ccSAndroid Build Coastguard Worker * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6*77c1e3ccSAndroid Build Coastguard Worker * was not distributed with this source code in the LICENSE file, you can
7*77c1e3ccSAndroid Build Coastguard Worker * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8*77c1e3ccSAndroid Build Coastguard Worker * Media Patent License 1.0 was not distributed with this source code in the
9*77c1e3ccSAndroid Build Coastguard Worker * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
10*77c1e3ccSAndroid Build Coastguard Worker */
11*77c1e3ccSAndroid Build Coastguard Worker
12*77c1e3ccSAndroid Build Coastguard Worker #include "av1/encoder/firstpass.h"
13*77c1e3ccSAndroid Build Coastguard Worker #include "av1/encoder/ratectrl.h"
14*77c1e3ccSAndroid Build Coastguard Worker #include "av1/encoder/tpl_model.h"
15*77c1e3ccSAndroid Build Coastguard Worker #include "gtest/gtest.h"
16*77c1e3ccSAndroid Build Coastguard Worker
17*77c1e3ccSAndroid Build Coastguard Worker namespace {
18*77c1e3ccSAndroid Build Coastguard Worker
TEST(RatectrlTest,QModeGetQIndexTest)19*77c1e3ccSAndroid Build Coastguard Worker TEST(RatectrlTest, QModeGetQIndexTest) {
20*77c1e3ccSAndroid Build Coastguard Worker int base_q_index = 36;
21*77c1e3ccSAndroid Build Coastguard Worker int gf_update_type = INTNL_ARF_UPDATE;
22*77c1e3ccSAndroid Build Coastguard Worker int gf_pyramid_level = 1;
23*77c1e3ccSAndroid Build Coastguard Worker int arf_q = 100;
24*77c1e3ccSAndroid Build Coastguard Worker int q_index = av1_q_mode_get_q_index(base_q_index, gf_update_type,
25*77c1e3ccSAndroid Build Coastguard Worker gf_pyramid_level, arf_q);
26*77c1e3ccSAndroid Build Coastguard Worker EXPECT_EQ(q_index, arf_q);
27*77c1e3ccSAndroid Build Coastguard Worker
28*77c1e3ccSAndroid Build Coastguard Worker gf_update_type = INTNL_ARF_UPDATE;
29*77c1e3ccSAndroid Build Coastguard Worker gf_pyramid_level = 3;
30*77c1e3ccSAndroid Build Coastguard Worker q_index = av1_q_mode_get_q_index(base_q_index, gf_update_type,
31*77c1e3ccSAndroid Build Coastguard Worker gf_pyramid_level, arf_q);
32*77c1e3ccSAndroid Build Coastguard Worker EXPECT_LT(q_index, arf_q);
33*77c1e3ccSAndroid Build Coastguard Worker
34*77c1e3ccSAndroid Build Coastguard Worker gf_update_type = LF_UPDATE;
35*77c1e3ccSAndroid Build Coastguard Worker q_index = av1_q_mode_get_q_index(base_q_index, gf_update_type,
36*77c1e3ccSAndroid Build Coastguard Worker gf_pyramid_level, arf_q);
37*77c1e3ccSAndroid Build Coastguard Worker EXPECT_EQ(q_index, base_q_index);
38*77c1e3ccSAndroid Build Coastguard Worker }
39*77c1e3ccSAndroid Build Coastguard Worker } // namespace
40