| /* |
| * Copyright (c) 2001-2016, Alliance for Open Media. All rights reserved |
| * |
| * 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. |
| */ |
| |
| /* clang-format off */ |
| |
| #if !defined(_pvq_encoder_H) |
| # define _pvq_encoder_H (1) |
| # include "aom_dsp/bitwriter.h" |
| # include "aom_dsp/entenc.h" |
| # include "av1/common/blockd.h" |
| # include "av1/common/pvq.h" |
| # include "av1/encoder/encint.h" |
| |
| void aom_encode_band_pvq_splits(aom_writer *w, od_pvq_codeword_ctx *adapt, |
| const int *y, int n, int k, int level); |
| |
| void aom_laplace_encode_special(aom_writer *w, int x, unsigned decay, int max); |
| |
| #if OD_SIGNAL_Q_SCALING |
| void od_encode_quantizer_scaling(daala_enc_ctx *enc, int q_scaling, int bx, |
| int by, int skip); |
| #endif |
| |
| void pvq_encode_partition(aom_writer *w, |
| int qg, |
| int theta, |
| int max_theta, |
| const od_coeff *in, |
| int n, |
| int k, |
| generic_encoder model[3], |
| od_adapt_ctx *adapt, |
| int *exg, |
| int *ext, |
| int nodesync, |
| int cdf_ctx, |
| int is_keyframe, |
| int code_skip, |
| int skip_rest, |
| int encode_flip, |
| int flip); |
| |
| PVQ_SKIP_TYPE od_pvq_encode(daala_enc_ctx *enc, od_coeff *ref, |
| const od_coeff *in, od_coeff *out, int q_dc, int q_ac, int pli, int bs, |
| const od_val16 *beta, int robust, int is_keyframe, int q_scaling, int bx, |
| int by, const int16_t *qm, const int16_t *qm_inv, int speed, |
| PVQ_INFO *pvq_info); |
| |
| #endif |