2010-05-18 17:58:33 +02:00
|
|
|
/*
|
2010-09-09 14:16:39 +02:00
|
|
|
* Copyright (c) 2010 The WebM project authors. All Rights Reserved.
|
2010-05-18 17:58:33 +02:00
|
|
|
*
|
2010-06-18 18:39:21 +02:00
|
|
|
* Use of this source code is governed by a BSD-style license
|
2010-06-04 22:19:40 +02:00
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
2010-06-18 18:39:21 +02:00
|
|
|
* in the file PATENTS. All contributing project authors may
|
2010-06-04 22:19:40 +02:00
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
2010-05-18 17:58:33 +02:00
|
|
|
*/
|
|
|
|
|
2012-11-30 01:36:10 +01:00
|
|
|
#ifndef VP9_ENCODER_VP9_QUANTIZE_H_
|
|
|
|
#define VP9_ENCODER_VP9_QUANTIZE_H_
|
2010-05-18 17:58:33 +02:00
|
|
|
|
2012-11-28 19:41:40 +01:00
|
|
|
#include "vp9/encoder/vp9_block.h"
|
2010-05-18 17:58:33 +02:00
|
|
|
|
|
|
|
#define prototype_quantize_block(sym) \
|
2013-02-27 19:00:24 +01:00
|
|
|
void (sym)(MACROBLOCK *mb, int b_idx)
|
2010-05-18 17:58:33 +02:00
|
|
|
|
2011-05-09 09:09:41 +02:00
|
|
|
#define prototype_quantize_block_pair(sym) \
|
2013-02-27 19:00:24 +01:00
|
|
|
void (sym)(MACROBLOCK *mb, int b_idx1, int b_idx2)
|
2011-05-09 09:09:41 +02:00
|
|
|
|
|
|
|
#define prototype_quantize_mb(sym) \
|
2012-07-14 00:21:29 +02:00
|
|
|
void (sym)(MACROBLOCK *x)
|
2011-04-11 11:04:17 +02:00
|
|
|
|
2010-06-14 20:07:56 +02:00
|
|
|
#if ARCH_X86 || ARCH_X86_64
|
2012-11-27 22:59:17 +01:00
|
|
|
#include "x86/vp9_quantize_x86.h"
|
2010-06-14 20:07:56 +02:00
|
|
|
#endif
|
|
|
|
|
2013-03-06 00:18:06 +01:00
|
|
|
void vp9_ht_quantize_b_4x4(MACROBLOCK *mb, int b_ix, TX_TYPE type);
|
2013-04-04 21:03:27 +02:00
|
|
|
void vp9_regular_quantize_b_4x4(MACROBLOCK *mb, int b_idx, int y_blocks);
|
|
|
|
void vp9_regular_quantize_b_4x4_pair(MACROBLOCK *mb, int b_idx1, int b_idx2,
|
|
|
|
int y_blocks);
|
|
|
|
void vp9_regular_quantize_b_8x8(MACROBLOCK *mb, int b_idx, TX_TYPE tx_type,
|
|
|
|
int y_blocks);
|
|
|
|
void vp9_regular_quantize_b_16x16(MACROBLOCK *mb, int b_idx, TX_TYPE tx_type,
|
|
|
|
int y_blocks);
|
|
|
|
void vp9_regular_quantize_b_32x32(MACROBLOCK *mb, int b_idx,
|
|
|
|
int y_blocks);
|
2013-03-06 00:18:06 +01:00
|
|
|
|
2013-04-10 06:28:27 +02:00
|
|
|
void vp9_quantize_sby_32x32(MACROBLOCK *x, BLOCK_SIZE_TYPE bsize);
|
|
|
|
void vp9_quantize_sby_16x16(MACROBLOCK *x, BLOCK_SIZE_TYPE bsize);
|
|
|
|
void vp9_quantize_sby_8x8(MACROBLOCK *x, BLOCK_SIZE_TYPE bsize);
|
|
|
|
void vp9_quantize_sby_4x4(MACROBLOCK *x, BLOCK_SIZE_TYPE bsize);
|
|
|
|
void vp9_quantize_sbuv_32x32(MACROBLOCK *x, BLOCK_SIZE_TYPE bsize);
|
|
|
|
void vp9_quantize_sbuv_16x16(MACROBLOCK *x, BLOCK_SIZE_TYPE bsize);
|
|
|
|
void vp9_quantize_sbuv_8x8(MACROBLOCK *x, BLOCK_SIZE_TYPE bsize);
|
|
|
|
void vp9_quantize_sbuv_4x4(MACROBLOCK *x, BLOCK_SIZE_TYPE bsize);
|
32x32 transform for superblocks.
This adds Debargha's DCT/DWT hybrid and a regular 32x32 DCT, and adds
code all over the place to wrap that in the bitstream/encoder/decoder/RD.
Some implementation notes (these probably need careful review):
- token range is extended by 1 bit, since the value range out of this
transform is [-16384,16383].
- the coefficients coming out of the FDCT are manually scaled back by
1 bit, or else they won't fit in int16_t (they are 17 bits). Because
of this, the RD error scoring does not right-shift the MSE score by
two (unlike for 4x4/8x8/16x16).
- to compensate for this loss in precision, the quantizer is halved
also. This is currently a little hacky.
- FDCT and IDCT is double-only right now. Needs a fixed-point impl.
- There are no default probabilities for the 32x32 transform yet; I'm
simply using the 16x16 luma ones. A future commit will add newly
generated probabilities for all transforms.
- No ADST version. I don't think we'll add one for this level; if an
ADST is desired, transform-size selection can scale back to 16x16
or lower, and use an ADST at that level.
Additional notes specific to Debargha's DWT/DCT hybrid:
- coefficient scale is different for the top/left 16x16 (DCT-over-DWT)
block than for the rest (DWT pixel differences) of the block. Therefore,
RD error scoring isn't easily scalable between coefficient and pixel
domain. Thus, unfortunately, we need to compute the RD distortion in
the pixel domain until we figure out how to scale these appropriately.
Change-Id: I00386f20f35d7fabb19aba94c8162f8aee64ef2b
2012-12-07 23:45:05 +01:00
|
|
|
|
2012-10-31 01:53:32 +01:00
|
|
|
struct VP9_COMP;
|
2012-10-30 22:25:33 +01:00
|
|
|
|
2012-10-31 01:53:32 +01:00
|
|
|
extern void vp9_set_quantizer(struct VP9_COMP *cpi, int Q);
|
2012-10-30 22:25:33 +01:00
|
|
|
|
2012-10-31 01:53:32 +01:00
|
|
|
extern void vp9_frame_init_quantizer(struct VP9_COMP *cpi);
|
2012-10-30 22:25:33 +01:00
|
|
|
|
2012-10-31 01:53:32 +01:00
|
|
|
extern void vp9_update_zbin_extra(struct VP9_COMP *cpi, MACROBLOCK *x);
|
2012-10-30 22:25:33 +01:00
|
|
|
|
2012-10-31 01:53:32 +01:00
|
|
|
extern void vp9_mb_init_quantizer(struct VP9_COMP *cpi, MACROBLOCK *x);
|
2012-10-30 22:25:33 +01:00
|
|
|
|
2012-10-31 01:53:32 +01:00
|
|
|
extern void vp9_init_quantizer(struct VP9_COMP *cpi);
|
2011-05-19 17:04:03 +02:00
|
|
|
|
2012-12-19 00:31:19 +01:00
|
|
|
#endif // VP9_ENCODER_VP9_QUANTIZE_H_
|