encodemb.h 3.76 KB
Newer Older
Jingning Han's avatar
Jingning Han committed
1
/*
Yaowu Xu's avatar
Yaowu Xu committed
2
 * Copyright (c) 2016, Alliance for Open Media. All rights reserved
Jingning Han's avatar
Jingning Han committed
3
 *
Yaowu Xu's avatar
Yaowu Xu committed
4 5 6 7 8 9
 * This source code is subject to the terms of the BSD 2 Clause License and
 * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
 * was not distributed with this source code in the LICENSE file, you can
 * obtain it at www.aomedia.org/license/software. If the Alliance for Open
 * Media Patent License 1.0 was not distributed with this source code in the
 * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
Jingning Han's avatar
Jingning Han committed
10 11
 */

Yaowu Xu's avatar
Yaowu Xu committed
12 13
#ifndef AV1_ENCODER_ENCODEMB_H_
#define AV1_ENCODER_ENCODEMB_H_
Jingning Han's avatar
Jingning Han committed
14

Yaowu Xu's avatar
Yaowu Xu committed
15
#include "./aom_config.h"
16
#include "av1/common/onyxc_int.h"
17
#include "av1/encoder/block.h"
Jingning Han's avatar
Jingning Han committed
18 19 20 21 22

#ifdef __cplusplus
extern "C" {
#endif

23 24 25 26 27
struct optimize_ctx {
  ENTROPY_CONTEXT ta[MAX_MB_PLANE][2 * MAX_MIB_SIZE];
  ENTROPY_CONTEXT tl[MAX_MB_PLANE][2 * MAX_MIB_SIZE];
};

Jingning Han's avatar
Jingning Han committed
28
struct encode_b_args {
Angie Chiang's avatar
Angie Chiang committed
29
  AV1_COMMON *cm;
Jingning Han's avatar
Jingning Han committed
30 31 32
  MACROBLOCK *x;
  struct optimize_ctx *ctx;
  int8_t *skip;
33 34
  ENTROPY_CONTEXT *ta;
  ENTROPY_CONTEXT *tl;
35
  int8_t enable_optimize_b;
Jingning Han's avatar
Jingning Han committed
36
};
Angie Chiang's avatar
Angie Chiang committed
37

Yaowu Xu's avatar
Yaowu Xu committed
38 39 40 41 42 43 44
typedef enum AV1_XFORM_QUANT {
  AV1_XFORM_QUANT_FP = 0,
  AV1_XFORM_QUANT_B = 1,
  AV1_XFORM_QUANT_DC = 2,
  AV1_XFORM_QUANT_SKIP_QUANT = 3,
  AV1_XFORM_QUANT_LAST = 4
} AV1_XFORM_QUANT;
Angie Chiang's avatar
Angie Chiang committed
45

Angie Chiang's avatar
Angie Chiang committed
46
void av1_encode_sb(AV1_COMMON *cm, MACROBLOCK *x, BLOCK_SIZE bsize);
47
#if CONFIG_SUPERTX
Angie Chiang's avatar
Angie Chiang committed
48
void av1_encode_sb_supertx(AV1_COMMON *cm, MACROBLOCK *x, BLOCK_SIZE bsize);
49
#endif  // CONFIG_SUPERTX
Angie Chiang's avatar
Angie Chiang committed
50 51 52 53
void av1_encode_sby_pass1(AV1_COMMON *cm, MACROBLOCK *x, BLOCK_SIZE bsize);
void av1_xform_quant(const AV1_COMMON *cm, MACROBLOCK *x, int plane, int block,
                     int blk_row, int blk_col, BLOCK_SIZE plane_bsize,
                     TX_SIZE tx_size, AV1_XFORM_QUANT xform_quant_idx);
54
#if CONFIG_NEW_QUANT
Angie Chiang's avatar
Angie Chiang committed
55 56 57
void av1_xform_quant_nuq(const AV1_COMMON *cm, MACROBLOCK *x, int plane,
                         int block, int blk_row, int blk_col,
                         BLOCK_SIZE plane_bsize, TX_SIZE tx_size, int ctx);
Yaowu Xu's avatar
Yaowu Xu committed
58 59 60
void av1_xform_quant_dc_nuq(MACROBLOCK *x, int plane, int block, int blk_row,
                            int blk_col, BLOCK_SIZE plane_bsize,
                            TX_SIZE tx_size, int ctx);
Angie Chiang's avatar
Angie Chiang committed
61 62 63
void av1_xform_quant_fp_nuq(const AV1_COMMON *cm, MACROBLOCK *x, int plane,
                            int block, int blk_row, int blk_col,
                            BLOCK_SIZE plane_bsize, TX_SIZE tx_size, int ctx);
Yaowu Xu's avatar
Yaowu Xu committed
64 65 66
void av1_xform_quant_dc_fp_nuq(MACROBLOCK *x, int plane, int block, int blk_row,
                               int blk_col, BLOCK_SIZE plane_bsize,
                               TX_SIZE tx_size, int ctx);
67
#endif
Jingning Han's avatar
Jingning Han committed
68

Angie Chiang's avatar
Angie Chiang committed
69 70
int av1_optimize_b(const AV1_COMMON *cm, MACROBLOCK *mb, int plane, int block,
                   TX_SIZE tx_size, int ctx);
71

Yaowu Xu's avatar
Yaowu Xu committed
72
void av1_subtract_plane(MACROBLOCK *x, BLOCK_SIZE bsize, int plane);
Jingning Han's avatar
Jingning Han committed
73

Yaowu Xu's avatar
Yaowu Xu committed
74 75
void av1_encode_block_intra(int plane, int block, int blk_row, int blk_col,
                            BLOCK_SIZE plane_bsize, TX_SIZE tx_size, void *arg);
Jingning Han's avatar
Jingning Han committed
76

Angie Chiang's avatar
Angie Chiang committed
77 78
void av1_encode_intra_block_plane(AV1_COMMON *cm, MACROBLOCK *x,
                                  BLOCK_SIZE bsize, int plane,
Yaowu Xu's avatar
Yaowu Xu committed
79
                                  int enable_optimize_b);
Jingning Han's avatar
Jingning Han committed
80

81 82 83 84 85 86 87 88 89 90 91 92 93
#if CONFIG_PVQ
int av1_pvq_encode_helper(daala_enc_ctx *daala_enc, tran_low_t *const coeff,
                          tran_low_t *ref_coeff, tran_low_t *const dqcoeff,
                          uint16_t *eob, const int16_t *quant, int plane,
                          int tx_size, TX_TYPE tx_type, int *rate, int speed,
                          PVQ_INFO *pvq_info);

void av1_store_pvq_enc_info(PVQ_INFO *pvq_info, int *qg, int *theta,
                            int *max_theta, int *k, od_coeff *y, int nb_bands,
                            const int *off, int *size, int skip_rest,
                            int skip_dir, int bs);
#endif

Jingning Han's avatar
Jingning Han committed
94 95 96 97
#ifdef __cplusplus
}  // extern "C"
#endif

Yaowu Xu's avatar
Yaowu Xu committed
98
#endif  // AV1_ENCODER_ENCODEMB_H_