2015-07-21 08:49:04 +00:00
|
|
|
#ifndef SEARCH_INTER_H_
|
|
|
|
#define SEARCH_INTER_H_
|
|
|
|
/*****************************************************************************
|
2021-11-23 06:46:06 +00:00
|
|
|
* This file is part of uvg266 VVC encoder.
|
2021-10-07 08:32:59 +00:00
|
|
|
*
|
|
|
|
* Copyright (c) 2021, Tampere University, ITU/ISO/IEC, project contributors
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without modification,
|
|
|
|
* are permitted provided that the following conditions are met:
|
|
|
|
*
|
|
|
|
* * Redistributions of source code must retain the above copyright notice, this
|
|
|
|
* list of conditions and the following disclaimer.
|
|
|
|
*
|
|
|
|
* * Redistributions in binary form must reproduce the above copyright notice, this
|
|
|
|
* list of conditions and the following disclaimer in the documentation and/or
|
|
|
|
* other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* * Neither the name of the Tampere University or ITU/ISO/IEC nor the names of its
|
|
|
|
* contributors may be used to endorse or promote products derived from
|
|
|
|
* this software without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR
|
|
|
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
* INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
|
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION HOWEVER CAUSED AND ON
|
|
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
* INCLUDING NEGLIGENCE OR OTHERWISE ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
****************************************************************************/
|
2015-07-21 08:49:04 +00:00
|
|
|
|
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"
|
2022-04-28 11:26:05 +00:00
|
|
|
#include "uvg266.h"
|
2015-07-21 08:49:04 +00:00
|
|
|
|
2022-04-28 11:18:09 +00:00
|
|
|
#define UVG_LUMA_FILTER_TAPS 8
|
|
|
|
#define UVG_LUMA_FILTER_OFFSET 3
|
|
|
|
#define UVG_CHROMA_FILTER_TAPS 4
|
|
|
|
#define UVG_CHROMA_FILTER_OFFSET 1
|
2018-11-04 19:04:17 +00:00
|
|
|
|
|
|
|
// Maximum extra width a block needs to filter
|
|
|
|
// a fractional pixel with positive fractional mv.x and mv.y
|
2022-04-28 11:18:09 +00:00
|
|
|
#define UVG_EXT_PADDING_LUMA (UVG_LUMA_FILTER_TAPS - 1)
|
|
|
|
#define UVG_EXT_PADDING_CHROMA (UVG_CHROMA_FILTER_TAPS - 1)
|
2018-11-04 19:04:17 +00:00
|
|
|
|
|
|
|
// Maximum block width for extended block
|
2022-04-28 11:18:09 +00:00
|
|
|
#define UVG_EXT_BLOCK_W_LUMA (LCU_WIDTH + UVG_EXT_PADDING_LUMA)
|
|
|
|
#define UVG_EXT_BLOCK_W_CHROMA (LCU_WIDTH_C + UVG_EXT_PADDING_CHROMA)
|
2016-07-12 14:36:28 +00:00
|
|
|
|
|
|
|
enum hpel_position {
|
|
|
|
HPEL_POS_HOR = 0,
|
|
|
|
HPEL_POS_VER = 1,
|
|
|
|
HPEL_POS_DIA = 2
|
|
|
|
};
|
|
|
|
|
2022-05-30 09:11:48 +00:00
|
|
|
typedef double uvg_mvd_cost_func(const encoder_state_t *state,
|
2017-08-03 11:11:36 +00:00
|
|
|
int x, int y,
|
|
|
|
int mv_shift,
|
2021-11-22 08:38:18 +00:00
|
|
|
mv_t mv_cand[2][2],
|
2017-08-03 11:11:36 +00:00
|
|
|
inter_merge_cand_t merge_cand[MRG_MAX_NUM_CANDS],
|
|
|
|
int16_t num_cand,
|
|
|
|
int32_t ref_idx,
|
2021-12-13 08:43:19 +00:00
|
|
|
double *bitcost);
|
2015-07-21 09:02:54 +00:00
|
|
|
|
2022-09-06 10:45:08 +00:00
|
|
|
void uvg_search_cu_inter(
|
|
|
|
encoder_state_t * const state,
|
|
|
|
const cu_loc_t* const cu_loc,
|
|
|
|
lcu_t *lcu,
|
|
|
|
double *inter_cost,
|
|
|
|
double* inter_bitcost);
|
2015-07-21 09:02:54 +00:00
|
|
|
|
2017-05-17 11:31:01 +00:00
|
|
|
|
|
|
|
|
2022-05-30 09:11:48 +00:00
|
|
|
unsigned uvg_inter_satd_cost(const encoder_state_t* state,
|
2017-05-17 11:31:01 +00:00
|
|
|
const lcu_t *lcu,
|
|
|
|
int x,
|
|
|
|
int y);
|
2022-09-06 10:45:08 +00:00
|
|
|
void uvg_cu_cost_inter_rd2(
|
|
|
|
encoder_state_t* const state,
|
2022-01-28 10:26:12 +00:00
|
|
|
cu_info_t* cur_cu,
|
2022-01-28 07:08:25 +00:00
|
|
|
lcu_t* lcu,
|
|
|
|
double* inter_cost,
|
2022-09-06 10:45:08 +00:00
|
|
|
double* inter_bitcost,
|
|
|
|
const cu_loc_t* const cu_loc);
|
2017-05-17 11:31:01 +00:00
|
|
|
|
2022-05-30 09:11:48 +00:00
|
|
|
int uvg_get_skip_context(int x, int y, lcu_t* const lcu, cu_array_t* const cu_a, int* predmode_ctx);
|
2017-05-17 11:31:01 +00:00
|
|
|
|
2015-07-21 08:49:04 +00:00
|
|
|
#endif // SEARCH_INTER_H_
|