Go to the documentation of this file.
   25 #define OPUS_RC_BITS 32 
   27 #define OPUS_RC_CEIL ((1 << OPUS_RC_SYM) - 1) 
   28 #define OPUS_RC_TOP (1u << 31) 
   29 #define OPUS_RC_BOT (OPUS_RC_TOP >> OPUS_RC_SYM) 
   30 #define OPUS_RC_SHIFT (OPUS_RC_BITS - OPUS_RC_SYM - 1) 
   41     for (; rc->
ext > 0; rc->
ext--)
 
   67                                                 uint32_t low, uint32_t high,
 
   70     rc->
value -= scale * (total - high);
 
   71     rc->
range  = low ? scale * (high - low)
 
   72                       : rc->
range - scale * (total - high);
 
   78                                                 uint32_t p_tot, 
const int ptwo)
 
   80     uint32_t rscaled, cnd = !!
b;
 
   84         rscaled = rc->
range/p_tot;
 
   86     rc->
range  = (!cnd)*(rc->
range - rscaled*(p_tot - p)) + cnd*rscaled*(p - 
b);
 
   92     unsigned int k, scale, total, symbol, low, high;
 
   96     scale   = rc->
range / total;
 
   97     symbol = rc->
value / scale + 1;
 
   98     symbol = total - 
FFMIN(symbol, total);
 
  100     for (k = 0; cdf[k] <= symbol; k++);
 
  102     low  = k ? cdf[k-1] : 0;
 
  119     if (rc->
value >= scale) {
 
  184     uint32_t 
bits, k, scale, total;
 
  189     scale  = rc->
range / total;
 
  190     k      = rc->
value / scale + 1;
 
  191     k      = total - 
FFMIN(k, total);
 
  214     uint32_t k, scale, symbol, total = (k0+1)*3 + k0;
 
  215     scale  = rc->
range / total;
 
  216     symbol = rc->
value / scale + 1;
 
  217     symbol = total - 
FFMIN(symbol, total);
 
  219     k = (symbol < (k0+1)*3) ? symbol/3 : symbol - (k0+1)*2;
 
  222                        (k <= k0) ? 3*(k+1) : (k-0-k0) + 3*(k0+1), total);
 
  228     const uint32_t 
a = 
val <= k0, 
b = 2*
a + 1;
 
  236     uint32_t k, scale, symbol, total, low, center;
 
  238     total = ((qn>>1) + 1) * ((qn>>1) + 1);
 
  239     scale   = rc->
range / total;
 
  240     center = rc->
value / scale + 1;
 
  241     center = total - 
FFMIN(center, total);
 
  243     if (center < total >> 1) {
 
  244         k      = (
ff_sqrt(8 * center + 1) - 1) >> 1;
 
  245         low    = k * (k + 1) >> 1;
 
  248         k      = (2*(qn + 1) - 
ff_sqrt(8*(total - center - 1) + 1)) >> 1;
 
  249         low    = total - ((qn + 1 - k) * (qn + 2 - k) >> 1);
 
  260     uint32_t symbol, low, total;
 
  262     total = ((qn>>1) + 1) * ((qn>>1) + 1);
 
  265         low    = k * (k + 1) >> 1;
 
  268         low    = total - ((qn + 1 - k) * (qn + 2 - k) >> 1);
 
  279     uint32_t scale, low = 0, center;
 
  281     scale  = rc->
range >> 15;
 
  282     center = rc->
value / scale + 1;
 
  283     center = (1 << 15) - 
FFMIN(center, 1 << 15);
 
  285     if (center >= symbol) {
 
  288         symbol = 1 + ((32768 - 32 - symbol) * (16384-decay) >> 15);
 
  290         while (symbol > 1 && center >= low + 2 * symbol) {
 
  294             symbol  = (((symbol - 2) * decay) >> 15) + 1;
 
  303         if (center < low + symbol)
 
  316     uint32_t low = symbol;
 
  322     symbol = ((32768 - 32 - symbol)*(16384 - decay)) >> 15;
 
  323     for (; 
i < 
val && symbol; 
i++) {
 
  324         low   += (symbol << 1) + 2;
 
  325         symbol = (symbol*decay) >> 14;
 
  328         low += (++symbol)*
pos;
 
  332         symbol = 
FFMIN(1, 32768 - low);
 
  380     if (rc->
rem >= 0 || rc->
ext > 0)
 
  384     memcpy(dst, rc->
buf, rng_bytes);
 
  395         lap = &dst[rng_bytes] - rb_dst;
 
  396         for (
i = 0; 
i < lap; 
i++)
 
  397             rb_dst[
i] |= rb_src[
i];
 
  398         memcpy(&rb_dst[lap], &rb_src[lap], 
FFMAX(rc->
rb.
bytes - lap, 0));
 
  
void ff_opus_rc_enc_cdf(OpusRangeCoder *rc, int val, const uint16_t *cdf)
static double cb(void *priv, double x, double y)
uint32_t ff_opus_rc_get_raw(OpusRangeCoder *rc, uint32_t count)
CELT: read 1-25 raw bits at the end of the frame, backwards byte-wise.
void ff_opus_rc_enc_uint(OpusRangeCoder *rc, uint32_t val, uint32_t size)
CELT: write a uniformly distributed integer.
static av_cold int end(AVCodecContext *avctx)
static av_always_inline void opus_rc_enc_carryout(OpusRangeCoder *rc, int cbuf)
static unsigned int get_bits(GetBitContext *s, int n)
Read 1-25 bits.
static double val(void *priv, double ch)
static av_always_inline void opus_rc_dec_update(OpusRangeCoder *rc, uint32_t scale, uint32_t low, uint32_t high, uint32_t total)
static int init_get_bits8(GetBitContext *s, const uint8_t *buffer, int byte_size)
Initialize GetBitContext.
static const uint16_t mask[17]
uint32_t ff_opus_rc_dec_uint(OpusRangeCoder *rc, uint32_t size)
CELT: read a uniform distribution.
#define av_assert0(cond)
assert() equivalent, that is always enabled.
void ff_opus_rc_enc_uint_tri(OpusRangeCoder *rc, uint32_t k, int qn)
#define FFABS(a)
Absolute value, Note, INT_MIN / INT64_MIN result in undefined behavior as they are not representable ...
static av_always_inline void opus_rc_enc_normalize(OpusRangeCoder *rc)
uint32_t ff_opus_rc_dec_uint_tri(OpusRangeCoder *rc, int qn)
void ff_opus_rc_enc_init(OpusRangeCoder *rc)
#define OPUS_MAX_PACKET_SIZE
int ff_opus_rc_dec_init(OpusRangeCoder *rc, const uint8_t *data, int size)
The reader does not expect b to be semantically here and if the code is changed by maybe adding a a division or other the signedness will almost certainly be mistaken To avoid this confusion a new type was SUINT is the C unsigned type but it holds a signed int to use the same example SUINT a
uint32_t ff_opus_rc_dec_cdf(OpusRangeCoder *rc, const uint16_t *cdf)
void ff_opus_rc_enc_uint_step(OpusRangeCoder *rc, uint32_t val, int k0)
int ff_opus_rc_dec_laplace(OpusRangeCoder *rc, uint32_t symbol, int decay)
#define i(width, name, range_min, range_max)
void ff_opus_rc_enc_laplace(OpusRangeCoder *rc, int *value, uint32_t symbol, int decay)
void ff_opus_rc_put_raw(OpusRangeCoder *rc, uint32_t val, uint32_t count)
CELT: write 0 - 31 bits to the rawbits buffer.
void ff_opus_rc_dec_raw_init(OpusRangeCoder *rc, const uint8_t *rightend, uint32_t bytes)
it s the only field you need to keep assuming you have a context There is some magic you don t need to care about around this just let it vf default value
uint32_t ff_opus_rc_dec_uint_step(OpusRangeCoder *rc, int k0)
void ff_opus_rc_enc_log(OpusRangeCoder *rc, int val, uint32_t bits)
static av_always_inline void opus_rc_dec_normalize(OpusRangeCoder *rc)
static float distance(float x, float y, int band)
uint32_t ff_opus_rc_dec_log(OpusRangeCoder *rc, uint32_t bits)
static av_always_inline void opus_rc_enc_update(OpusRangeCoder *rc, uint32_t b, uint32_t p, uint32_t p_tot, const int ptwo)
void ff_opus_rc_enc_end(OpusRangeCoder *rc, uint8_t *dst, int size)
uint8_t buf[OPUS_MAX_PACKET_SIZE+12]