2013-09-19 07:35:34 +00:00
|
|
|
#ifndef CABAC_H_
|
|
|
|
#define CABAC_H_
|
2012-06-04 10:47:12 +00:00
|
|
|
/**
|
2013-09-18 14:29:30 +00:00
|
|
|
* \file
|
|
|
|
* \brief The Content Adaptive Binary Arithmetic Coder (CABAC).
|
|
|
|
*
|
|
|
|
* \author Marko Viitanen ( fador@iki.fi ),
|
|
|
|
* Tampere University of Technology,
|
|
|
|
* Department of Pervasive Computing.
|
|
|
|
* \author Ari Koivula ( ari@koivu.la ),
|
|
|
|
* Tampere University of Technology,
|
|
|
|
* Department of Pervasive Computing.
|
2012-06-04 10:47:12 +00:00
|
|
|
*/
|
|
|
|
|
2013-09-18 09:16:03 +00:00
|
|
|
#include "global.h"
|
|
|
|
|
|
|
|
#include "bitstream.h"
|
2013-09-19 09:47:39 +00:00
|
|
|
#include "context.h"
|
2013-09-18 09:16:03 +00:00
|
|
|
|
|
|
|
|
2013-09-19 09:28:57 +00:00
|
|
|
// Types
|
2012-06-04 10:47:12 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
2013-09-19 08:05:42 +00:00
|
|
|
cabac_ctx *ctx;
|
|
|
|
uint32_t low;
|
|
|
|
uint32_t range;
|
|
|
|
uint32_t buffered_byte;
|
2013-09-18 11:06:45 +00:00
|
|
|
int32_t num_buffered_bytes;
|
|
|
|
int32_t bits_left;
|
2013-09-19 08:05:42 +00:00
|
|
|
bitstream *stream;
|
2012-06-04 10:47:12 +00:00
|
|
|
} cabac_data;
|
|
|
|
|
|
|
|
|
2013-09-19 09:28:57 +00:00
|
|
|
// Globals
|
2013-09-19 09:37:27 +00:00
|
|
|
extern const uint8_t g_auc_next_state_mps[128];
|
|
|
|
extern const uint8_t g_auc_next_state_lps[128];
|
2013-09-19 09:28:57 +00:00
|
|
|
extern const uint8_t g_auc_lpst_table[64][4];
|
|
|
|
extern const uint8_t g_auc_renorm_table[32];
|
|
|
|
extern cabac_data cabac;
|
2012-06-04 10:47:12 +00:00
|
|
|
|
2012-06-13 15:08:15 +00:00
|
|
|
|
2013-09-19 09:28:57 +00:00
|
|
|
// Functions
|
|
|
|
void cabac_start(cabac_data *data);
|
|
|
|
void cabac_encode_bin(cabac_data *data, uint32_t bin_value);
|
|
|
|
void cabac_encode_bin_ep(cabac_data *data, uint32_t bin_value);
|
|
|
|
void cabac_encode_bins_ep(cabac_data *data, uint32_t bin_values, int num_bins);
|
|
|
|
void cabac_encode_bin_trm(cabac_data *data, uint8_t bin_value);
|
|
|
|
void cabac_write(cabac_data *data);
|
|
|
|
void cabac_finish(cabac_data *data);
|
|
|
|
void cabac_flush(cabac_data *data);
|
|
|
|
void cabac_write_coeff_remain(cabac_data *cabac, uint32_t symbol,
|
|
|
|
uint32_t r_param);
|
|
|
|
void cabac_write_ep_ex_golomb(cabac_data *data, uint32_t symbol,
|
|
|
|
uint32_t count);
|
|
|
|
void cabac_write_unary_max_symbol(cabac_data *data, cabac_ctx *ctx,
|
|
|
|
uint32_t symbol, int32_t offset,
|
|
|
|
uint32_t max_symbol);
|
2013-10-31 22:52:06 +00:00
|
|
|
void cabac_write_unary_max_symbol_ep(cabac_data *data, unsigned symbol, unsigned max_symbol);
|
2013-09-19 09:28:57 +00:00
|
|
|
|
2013-09-19 09:37:27 +00:00
|
|
|
|
2013-09-19 09:28:57 +00:00
|
|
|
// Macros
|
2013-09-19 09:37:27 +00:00
|
|
|
#define CTX_STATE(ctx) (ctx->uc_state >> 1)
|
|
|
|
#define CTX_MPS(ctx) (ctx->uc_state & 1)
|
|
|
|
#define CTX_UPDATE_LPS(ctx) { (ctx)->uc_state = g_auc_next_state_lps[ (ctx)->uc_state ]; }
|
|
|
|
#define CTX_UPDATE_MPS(ctx) { (ctx)->uc_state = g_auc_next_state_mps[ (ctx)->uc_state ]; }
|
2013-09-19 09:28:57 +00:00
|
|
|
#ifdef VERBOSE
|
|
|
|
#define CABAC_BIN(data, value, name) { \
|
|
|
|
uint32_t prev_state = (data)->ctx->uc_state; \
|
|
|
|
cabac_encode_bin(data, value); \
|
|
|
|
printf("%s = %d prev_state=%d state=%d\n", \
|
|
|
|
name, value, prev_state, (data)->ctx->uc_state); }
|
|
|
|
|
|
|
|
#define CABAC_BINS_EP(data, value, bins, name) { \
|
|
|
|
uint32_t prev_state = (data)->ctx->uc_state; \
|
|
|
|
cabac_encode_bins_ep(data, value, bins); \
|
|
|
|
printf("%s = %d prev_state=%d state=%d\n", \
|
|
|
|
name, value, prev_state, (data)->ctx->uc_state); }
|
|
|
|
|
|
|
|
#define CABAC_BIN_EP(data, value, name) { \
|
|
|
|
uint32_t prev_state = (data)->ctx->uc_state; \
|
|
|
|
cabac_encode_bin_ep(data, value); \
|
|
|
|
printf("%s = %d prev_state=%d state=%d\n", \
|
|
|
|
name, value, prev_state, (data)->ctx->uc_state); }
|
2012-06-07 14:38:28 +00:00
|
|
|
#else
|
2013-09-19 09:28:57 +00:00
|
|
|
#define CABAC_BIN(data, value, name) \
|
|
|
|
cabac_encode_bin(data, value);
|
|
|
|
#define CABAC_BINS_EP(data, value, bins, name) \
|
|
|
|
cabac_encode_bins_ep(data, value, bins);
|
|
|
|
#define CABAC_BIN_EP(data, value, name) \
|
|
|
|
cabac_encode_bin_ep(data, value);
|
2012-06-07 14:38:28 +00:00
|
|
|
#endif
|
|
|
|
|
2012-06-04 10:47:12 +00:00
|
|
|
#endif
|