2013-09-19 07:35:34 +00:00
|
|
|
#ifndef CONTEXT_H_
|
|
|
|
#define CONTEXT_H_
|
2014-01-24 10:37:15 +00:00
|
|
|
/*****************************************************************************
|
|
|
|
* This file is part of Kvazaar HEVC encoder.
|
2014-03-06 16:14:01 +00:00
|
|
|
*
|
2015-02-23 11:18:48 +00:00
|
|
|
* Copyright (C) 2013-2015 Tampere University of Technology and others (see
|
2014-01-24 10:37:15 +00:00
|
|
|
* COPYING file).
|
|
|
|
*
|
2015-02-23 11:18:48 +00:00
|
|
|
* Kvazaar is free software: you can redistribute it and/or modify it under
|
|
|
|
* the terms of the GNU Lesser General Public License as published by the
|
|
|
|
* Free Software Foundation; either version 2.1 of the License, or (at your
|
|
|
|
* option) any later version.
|
2014-01-24 10:37:15 +00:00
|
|
|
*
|
2015-02-23 11:18:48 +00:00
|
|
|
* Kvazaar is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
|
|
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
|
|
|
|
* more details.
|
2014-01-24 10:37:15 +00:00
|
|
|
*
|
2015-02-23 11:18:48 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with Kvazaar. If not, see <http://www.gnu.org/licenses/>.
|
2014-01-24 10:37:15 +00:00
|
|
|
****************************************************************************/
|
|
|
|
|
2015-12-17 11:42:57 +00:00
|
|
|
/**
|
|
|
|
* \ingroup CABAC
|
2013-09-18 14:29:30 +00:00
|
|
|
* \file
|
2015-12-17 11:42:57 +00:00
|
|
|
* Context derivation for CABAC.
|
2012-08-15 10:22:31 +00:00
|
|
|
*/
|
|
|
|
|
2014-04-04 08:50:07 +00:00
|
|
|
#include "cabac.h"
|
2016-04-01 14:14:23 +00:00
|
|
|
#include "encoderstate.h"
|
|
|
|
#include "global.h" // IWYU pragma: keep
|
2013-09-19 09:47:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Functions
|
2019-08-19 11:33:55 +00:00
|
|
|
void kvz_ctx_init(cabac_ctx_t* ctx, int32_t qp, int32_t init_value, uint8_t rate);
|
2015-08-26 08:50:27 +00:00
|
|
|
void kvz_init_contexts(encoder_state_t *state, int8_t QP, int8_t slice);
|
2014-05-08 08:12:57 +00:00
|
|
|
|
2015-08-26 08:50:27 +00:00
|
|
|
void kvz_context_copy(encoder_state_t * target_state, const encoder_state_t * source_state);
|
|
|
|
int32_t kvz_context_calc_pattern_sig_ctx( const uint32_t *sig_coeff_group_flag, uint32_t pos_x, uint32_t pos_y, int32_t width);
|
2012-08-15 10:22:31 +00:00
|
|
|
|
2015-08-26 08:50:27 +00:00
|
|
|
uint32_t kvz_context_get_sig_coeff_group( uint32_t *sig_coeff_group_flag,uint32_t pos_x, uint32_t pos_y,int32_t width);
|
2012-08-15 10:22:31 +00:00
|
|
|
|
|
|
|
|
2015-08-26 08:50:27 +00:00
|
|
|
int32_t kvz_context_get_sig_ctx_inc(int32_t pattern_sig_ctx,uint32_t scan_idx,int32_t pos_x,
|
2014-04-04 08:32:56 +00:00
|
|
|
int32_t pos_y,int32_t block_type, int8_t texture_type);
|
2012-08-15 10:22:31 +00:00
|
|
|
|
2018-08-30 08:09:42 +00:00
|
|
|
uint32_t kvz_context_get_sig_ctx_idx_abs(const coeff_t* coeff, int32_t pos_x, int32_t pos_y,
|
2018-08-30 11:24:03 +00:00
|
|
|
uint32_t height, uint32_t width, int8_t type,
|
|
|
|
int32_t* temp_diag, int32_t* temp_sum);
|
|
|
|
|
2019-05-13 12:30:43 +00:00
|
|
|
uint32_t kvz_abs_sum(const coeff_t* coeff, int32_t pos_x, int32_t pos_y,
|
|
|
|
uint32_t height, uint32_t width, uint32_t baselevel);
|
|
|
|
|
2018-08-30 11:24:03 +00:00
|
|
|
uint32_t kvz_go_rice_par_abs(const coeff_t* coeff, int32_t pos_x, int32_t pos_y,
|
2019-05-13 12:30:43 +00:00
|
|
|
uint32_t height, uint32_t width, uint32_t baselevel);
|
2018-08-30 08:09:42 +00:00
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
#define CNU 35
|
2019-03-27 10:38:19 +00:00
|
|
|
#define DWS 8
|
2013-04-19 07:56:40 +00:00
|
|
|
|
2012-08-15 10:22:31 +00:00
|
|
|
#endif
|