cae03a7ef5
The vbp thresholds are set seperately for boosted/non-boosted superblocks according to their segment_id. This way we don't have to force the boosted blocks to split to 32x32. Speed 6 RTC set borg test result showed some quality gains. Overall PSNR: +0.199%; Avg PSNR: +0.245%; SSIM: +0.802%. No speed change was observed. Change-Id: I37c6643a3e2da59c4b7dc10ebe05abc8abf4026a
50 lines
1.4 KiB
C
50 lines
1.4 KiB
C
/*
|
|
* Copyright (c) 2010 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.
|
|
*/
|
|
|
|
|
|
#ifndef VP9_ENCODER_VP9_ENCODEFRAME_H_
|
|
#define VP9_ENCODER_VP9_ENCODEFRAME_H_
|
|
|
|
#include "vpx/vpx_integer.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
struct macroblock;
|
|
struct yv12_buffer_config;
|
|
struct VP9_COMP;
|
|
struct ThreadData;
|
|
|
|
// Constants used in SOURCE_VAR_BASED_PARTITION
|
|
#define VAR_HIST_MAX_BG_VAR 1000
|
|
#define VAR_HIST_FACTOR 10
|
|
#define VAR_HIST_BINS (VAR_HIST_MAX_BG_VAR / VAR_HIST_FACTOR + 1)
|
|
#define VAR_HIST_LARGE_CUT_OFF 75
|
|
#define VAR_HIST_SMALL_CUT_OFF 45
|
|
|
|
void vp9_setup_src_planes(struct macroblock *x,
|
|
const struct yv12_buffer_config *src,
|
|
int mi_row, int mi_col);
|
|
|
|
void vp9_encode_frame(struct VP9_COMP *cpi);
|
|
|
|
void vp9_init_tile_data(struct VP9_COMP *cpi);
|
|
void vp9_encode_tile(struct VP9_COMP *cpi, struct ThreadData *td,
|
|
int tile_row, int tile_col);
|
|
|
|
void vp9_set_vbp_thresholds(struct VP9_COMP *cpi, int64_t thresholds[], int q);
|
|
|
|
#ifdef __cplusplus
|
|
} // extern "C"
|
|
#endif
|
|
|
|
#endif // VP9_ENCODER_VP9_ENCODEFRAME_H_
|