quant_common.h 2.06 KB
Newer Older
Jingning Han's avatar
Jingning Han committed
1 2 3 4 5 6 7 8 9 10
/*
 *  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.
 */

11 12
#ifndef VP10_COMMON_QUANT_COMMON_H_
#define VP10_COMMON_QUANT_COMMON_H_
Jingning Han's avatar
Jingning Han committed
13 14

#include "vpx/vpx_codec.h"
15
#include "vp10/common/seg_common.h"
16
#include "vp10/common/enums.h"
Jingning Han's avatar
Jingning Han committed
17 18 19 20 21 22 23 24 25

#ifdef __cplusplus
extern "C" {
#endif

#define MINQ 0
#define MAXQ 255
#define QINDEX_RANGE (MAXQ - MINQ + 1)
#define QINDEX_BITS 8
26 27
#if CONFIG_AOM_QM
// Total number of QM sets stored
28 29
#define QM_LEVEL_BITS 4
#define NUM_QM_LEVELS (1 << QM_LEVEL_BITS)
30 31 32
/* Offset into the list of QMs. Actual number of levels used is
   (NUM_QM_LEVELS-AOM_QM_OFFSET)
   Lower value of AOM_QM_OFFSET implies more heavily weighted matrices.*/
33 34
#define DEFAULT_QM_FIRST (NUM_QM_LEVELS / 2)
#define DEFAULT_QM_LAST (NUM_QM_LEVELS - 1)
35 36 37
#endif

struct VP10Common;
Jingning Han's avatar
Jingning Han committed
38 39 40 41 42

int16_t vp10_dc_quant(int qindex, int delta, vpx_bit_depth_t bit_depth);
int16_t vp10_ac_quant(int qindex, int delta, vpx_bit_depth_t bit_depth);

int vp10_get_qindex(const struct segmentation *seg, int segment_id,
clang-format's avatar
clang-format committed
43
                    int base_qindex);
44 45 46
#if CONFIG_AOM_QM
// Reduce the large number of quantizers to a smaller number of levels for which
// different matrices may be defined
47 48 49
static inline int aom_get_qmlevel(int qindex, int first, int last) {
  int qmlevel = (qindex * (last + 1 - first) + QINDEX_RANGE / 2) / QINDEX_RANGE;
  qmlevel = VPXMIN(qmlevel + first, NUM_QM_LEVELS - 1);
50 51 52 53 54 55 56 57
  return qmlevel;
}
void aom_qm_init(struct VP10Common *cm);
qm_val_t *aom_iqmatrix(struct VP10Common *cm, int qindex, int comp,
                       int log2sizem2, int is_intra);
qm_val_t *aom_qmatrix(struct VP10Common *cm, int qindex, int comp,
                      int log2sizem2, int is_intra);
#endif
Jingning Han's avatar
Jingning Han committed
58 59 60 61 62

#ifdef __cplusplus
}  // extern "C"
#endif

63
#endif  // VP10_COMMON_QUANT_COMMON_H_