uvg266/tests/mv_cand_tests.c
Arttu Ylä-Outinen 1cd149fb97 Check merge/mv candidate types earlier.
Moves checks for motion vector prediction and merge candidate block
types (inter/intra) from functions kvz_inter_get_mv_cand and
kvz_inter_get_merge_cand to kvz_inter_get_spatial_merge_candidates.
2015-12-15 11:21:39 +02:00

63 lines
2.1 KiB
C

/*****************************************************************************
* This file is part of Kvazaar HEVC encoder.
*
* Copyright (C) 2013-2015 Tampere University of Technology and others (see
* COPYING file).
*
* Kvazaar is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License version 2.1 as
* published by the Free Software Foundation.
*
* Kvazaar is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Kvazaar. If not, see <http://www.gnu.org/licenses/>.
****************************************************************************/
#include <string.h>
#include "greatest/greatest.h"
#include "src/cu.h"
#include "src/inter.h"
TEST test_get_spatial_merge_cand(void)
{
lcu_t lcu;
memset(&lcu, 0, sizeof(lcu));
for (int i = 0; i < sizeof(lcu.cu) / sizeof(cu_info_t); i++) {
lcu.cu[i].coded = 1;
lcu.cu[i].type = CU_INTER;
}
lcu.cu[20].coded = 1;
lcu.cu[22].coded = 1;
lcu.cu[23].coded = 1;
lcu.cu[56].coded = 1;
lcu.cu[65].coded = 1;
cu_info_t *mv_cand[5] = { NULL };
kvz_inter_get_spatial_merge_candidates(16, 16, // x, y
16, 32, // width, height
&mv_cand[0], // b0
&mv_cand[1], // b1
&mv_cand[2], // b2
&mv_cand[3], // a0
&mv_cand[4], // a1
&lcu);
ASSERT_EQ(mv_cand[0], &lcu.cu[23]); // b0
ASSERT_EQ(mv_cand[1], &lcu.cu[22]); // b1
ASSERT_EQ(mv_cand[2], &lcu.cu[20]); // b2
ASSERT_EQ(mv_cand[3], &lcu.cu[65]); // a0
ASSERT_EQ(mv_cand[4], &lcu.cu[56]); // a1
PASS();
}
SUITE(mv_cand_tests) {
RUN_TEST(test_get_spatial_merge_cand);
}