2015-07-21 08:49:04 +00:00
|
|
|
#ifndef SEARCH_INTER_H_
|
|
|
|
#define SEARCH_INTER_H_
|
|
|
|
/*****************************************************************************
|
|
|
|
* 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 as published by the
|
|
|
|
* Free Software Foundation; either version 2.1 of the License, or (at your
|
|
|
|
* option) any later version.
|
|
|
|
*
|
|
|
|
* 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/>.
|
|
|
|
****************************************************************************/
|
|
|
|
|
2015-12-17 11:42:57 +00:00
|
|
|
/**
|
|
|
|
* \ingroup Compression
|
|
|
|
* \file
|
|
|
|
* Inter prediction parameter search.
|
|
|
|
*/
|
2015-07-21 08:49:04 +00:00
|
|
|
|
2016-04-01 14:14:23 +00:00
|
|
|
#include "cu.h"
|
|
|
|
#include "encoderstate.h"
|
2016-03-30 09:41:37 +00:00
|
|
|
#include "global.h" // IWYU pragma: keep
|
2016-06-20 03:30:41 +00:00
|
|
|
#include "inter.h"
|
2016-08-09 13:16:33 +00:00
|
|
|
#include "kvazaar.h"
|
2015-07-21 08:49:04 +00:00
|
|
|
|
2016-07-12 14:36:28 +00:00
|
|
|
#define FILTER_SIZE 8
|
|
|
|
#define HALF_FILTER (FILTER_SIZE>>1)
|
|
|
|
|
|
|
|
// Maximum extra width a block needs to filter
|
|
|
|
// a fractional pixel with positive fractional mv.x and mv.y
|
|
|
|
#define KVZ_EXT_PADDING (FILTER_SIZE - 1)
|
|
|
|
|
|
|
|
// Maximum block width for extended block
|
|
|
|
#define KVZ_EXT_BLOCK_W (LCU_WIDTH + KVZ_EXT_PADDING)
|
|
|
|
|
|
|
|
typedef kvz_pixel frac_search_block[(LCU_WIDTH + 1) * (LCU_WIDTH + 1)];
|
|
|
|
|
|
|
|
enum hpel_position {
|
|
|
|
HPEL_POS_HOR = 0,
|
|
|
|
HPEL_POS_VER = 1,
|
|
|
|
HPEL_POS_DIA = 2
|
|
|
|
};
|
|
|
|
|
2016-06-20 03:30:41 +00:00
|
|
|
typedef int kvz_mvd_cost_func(encoder_state_t * const state,
|
|
|
|
int x, int y,
|
|
|
|
int mv_shift,
|
|
|
|
int16_t mv_cand[2][2],
|
|
|
|
inter_merge_cand_t merge_cand[MRG_MAX_NUM_CANDS],
|
|
|
|
int16_t num_cand,
|
|
|
|
int32_t ref_idx,
|
|
|
|
uint32_t *bitcost);
|
2015-07-21 09:02:54 +00:00
|
|
|
|
2016-03-21 09:50:41 +00:00
|
|
|
void kvz_search_cu_inter(encoder_state_t * const state,
|
|
|
|
int x, int y, int depth,
|
|
|
|
lcu_t *lcu,
|
|
|
|
double *inter_cost,
|
|
|
|
uint32_t *inter_bitcost);
|
2015-07-21 09:02:54 +00:00
|
|
|
|
2016-03-21 09:50:41 +00:00
|
|
|
void kvz_search_cu_smp(encoder_state_t * const state,
|
|
|
|
int x, int y,
|
|
|
|
int depth,
|
|
|
|
part_mode_t part_mode,
|
|
|
|
lcu_t *lcu,
|
|
|
|
double *inter_cost,
|
|
|
|
uint32_t *inter_bitcost);
|
2015-11-03 08:32:37 +00:00
|
|
|
|
2017-05-17 11:31:01 +00:00
|
|
|
|
|
|
|
unsigned kvz_inter_satd_cost(const encoder_state_t* state,
|
|
|
|
const lcu_t *lcu,
|
|
|
|
int x,
|
|
|
|
int y);
|
|
|
|
|
2015-07-21 08:49:04 +00:00
|
|
|
#endif // SEARCH_INTER_H_
|