Unverified Commit f70052bb authored by Wolle's avatar Wolle Committed by GitHub

Add files via upload

parent b57941b0
This source diff could not be displayed because it is too large. You can view the blob instead.
/* Copyright (c) 2007-2008 CSIRO
Copyright (c) 2007-2009 Xiph.Org Foundation
Copyright (c) 2008 Gregory Maxwell
Written by Jean-Marc Valin and Gregory Maxwell */
/**
@file celt.h
@brief Contains all the functions for encoding and decoding audio
*/
/*
Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions
are met:
- Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
- Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#pragma once
#include "Arduino.h"
//#include "opus_decoder.h"
#ifdef __cplusplus
extern "C" {
#endif
#define OPUS_OK 0
#define OPUS_BAD_ARG -1
#define OPUS_BUFFER_TOO_SMALL -2
#define OPUS_INTERNAL_ERROR -3
#define OPUS_INVALID_PACKET -4
#define OPUS_UNIMPLEMENTED -5
#define OPUS_INVALID_STATE -6
#define OPUS_ALLOC_FAIL -7
#define OPUS_RESET_STATE 4028
#define OPUS_GET_LOOKAHEAD_REQUEST 4027
#define OPUS_GET_SAMPLE_RATE_REQUEST 4029
#define OPUS_GET_FINAL_RANGE_REQUEST 4031
#define OPUS_GET_PITCH_REQUEST 4033
#define OPUS_SET_GAIN_REQUEST 4034
#define OPUS_GET_GAIN_REQUEST 4045 /* Should have been 4035 */
#define OPUS_SET_PHASE_INVERSION_DISABLED_REQUEST 4046
#define OPUS_GET_PHASE_INVERSION_DISABLED_REQUEST 4047
#define LEAK_BANDS 19
typedef struct {
int32_t valid;
float tonality;
float tonality_slope;
float noisiness;
float activity;
float music_prob;
float music_prob_min;
float music_prob_max;
int32_t bandwidth;
float activity_probability;
float max_pitch_ratio;
/* Store as Q6 char to save space. */
uint8_t leak_boost[LEAK_BANDS];
} AnalysisInfo;
/*OPT: ec_window must be at least 32 bits, but if you have fast arithmetic on a larger type, you can speed up the
decoder by using it here.*/
typedef uint32_t ec_window;
typedef struct ec_ctx ec_ctx;
typedef struct ec_ctx ec_enc;
typedef struct ec_ctx ec_dec;
typedef struct CELTMode CELTMode;
typedef struct CELTDecoder CELTDecoder;
struct ec_ctx {
uint8_t *buf; /*Buffered input/output.*/
uint32_t storage; /*The size of the buffer.*/
uint32_t end_offs; /*The offset at which the last byte containing raw bits was read/written.*/
ec_window end_window; /*Bits that will be read from/written at the end.*/
int32_t nend_bits; /*Number of valid bits in end_window.*/
int32_t nbits_total;
uint32_t offs; /*The offset at which the next range coder byte will be read/written.*/
uint32_t rng; /*The number of values in the current range.*/
uint32_t val;
uint32_t ext;
int32_t rem; /*A buffered input/output symbol, awaiting carry propagation.*/
int32_t error; /*Nonzero if an error occurred.*/
};
struct band_ctx{
int32_t encode;
int32_t resynth;
const CELTMode *m;
int32_t i;
int32_t intensity;
int32_t spread;
int32_t tf_change;
ec_ctx *ec;
int32_t remaining_bits;
const int32_t *bandE;
uint32_t seed;
int32_t arch;
int32_t theta_round;
int32_t disable_inv;
int32_t avoid_split_noise;
};
struct split_ctx{
int32_t inv;
int32_t imid;
int32_t iside;
int32_t delta;
int32_t itheta;
int32_t qalloc;
};
struct CELTDecoder {
const CELTMode *mode;
int32_t overlap;
int32_t channels;
int32_t stream_channels;
int32_t downsample;
int32_t start, end;
int32_t signalling;
int32_t disable_inv;
int32_t arch;
uint32_t rng;
int32_t error;
int32_t last_pitch_index;
int32_t loss_count;
int32_t skip_plc;
int32_t postfilter_period;
int32_t postfilter_period_old;
int16_t postfilter_gain;
int16_t postfilter_gain_old;
int32_t postfilter_tapset;
int32_t postfilter_tapset_old;
int32_t preemph_memD[2];
int32_t _decode_mem[1]; /* Size = channels*(DECODE_BUFFER_SIZE+mode->overlap) */
/* int16_t lpc[], Size = channels*LPC_ORDER */
/* int16_t oldEBands[], Size = 2*mode->nbEBands */
/* int16_t oldLogE[], Size = 2*mode->nbEBands */
/* int16_t oldLogE2[], Size = 2*mode->nbEBands */
/* int16_t backgroundLogE[], Size = 2*mode->nbEBands */
};
typedef struct {
int32_t r;
int32_t i;
}kiss_fft_cpx;
typedef struct {
int16_t r;
int16_t i;
}kiss_twiddle_cpx;
typedef struct arch_fft_state{
int32_t is_supported;
void *priv;
} arch_fft_state;
#define MAXFACTORS 8
typedef struct kiss_fft_state{
int32_t nfft;
int16_t scale;
int32_t scale_shift;
int32_t shift;
int16_t factors[2*MAXFACTORS];
const int16_t *bitrev;
const kiss_twiddle_cpx *twiddles;
arch_fft_state *arch_fft;
} kiss_fft_state;
typedef struct {
int32_t n;
int32_t maxshift;
const kiss_fft_state *kfft[4];
const int16_t * trig;
} mdct_lookup;
typedef struct {
int32_t size;
const int16_t *index;
const uint8_t *bits;
const uint8_t *caps;
} PulseCache;
/** Mode definition (opaque)
@brief Mode definition
*/
struct CELTMode {
int32_t Fs;
int32_t overlap;
int32_t nbEBands;
int32_t effEBands;
int16_t preemph[4];
const int16_t *eBands; /**< Definition for each "pseudo-critical band" */
int32_t maxLM;
int32_t nbShortMdcts;
int32_t shortMdctSize;
int32_t nbAllocVectors; /**< Number of lines in the matrix below */
const uint8_t *allocVectors; /**< Number of bits in each band for several rates */
const int16_t *logN;
const int16_t *window;
mdct_lookup mdct;
PulseCache cache;
};
#define min(a,b) ((a)<(b)?(a):(b))
#define max(a,b) ((a)>(b)?(a):(b))
#define S_MUL(a,b) MULT16_32_Q15(b, a)
#define C_MUL(m,a,b) do{ (m).r = SUB32_ovflw(S_MUL((a).r,(b).r) , S_MUL((a).i,(b).i)); \
(m).i = ADD32_ovflw(S_MUL((a).r,(b).i) , S_MUL((a).i,(b).r)); }while(0)
#define C_MULC(m,a,b) do{ (m).r = ADD32_ovflw(S_MUL((a).r,(b).r) , S_MUL((a).i,(b).i)); \
(m).i = SUB32_ovflw(S_MUL((a).i,(b).r) , S_MUL((a).r,(b).i)); }while(0)
#define C_MULBYSCALAR( c, s ) do{ (c).r = S_MUL( (c).r , s ) ; (c).i = S_MUL( (c).i , s ) ; }while(0)
#define DIVSCALAR(x,k) (x) = S_MUL( x, (32767-((k)>>1))/(k)+1 )
#define C_FIXDIV(c,div) do { DIVSCALAR( (c).r , div); DIVSCALAR( (c).i , div); }while (0)
#define C_ADD( res, a,b) do {(res).r=ADD32_ovflw((a).r,(b).r); (res).i=ADD32_ovflw((a).i,(b).i); }while(0)
#define C_SUB( res, a,b) do {(res).r=SUB32_ovflw((a).r,(b).r); (res).i=SUB32_ovflw((a).i,(b).i); }while(0)
#define C_ADDTO( res , a) do {(res).r = ADD32_ovflw((res).r, (a).r); (res).i = ADD32_ovflw((res).i,(a).i); }while(0)
#define COMBFILTER_MAXPERIOD 1024
#define COMBFILTER_MINPERIOD 15
#define VALIDATE_CELT_DECODER(st)
#define EPSILON 1
#define VERY_SMALL 0
#define VERY_LARGE16 ((int16_t)32767)
#define Q15_ONE ((int16_t)32767)
#define EC_WINDOW_SIZE ((int32_t)sizeof(ec_window)*CHAR_BIT)
#define EC_UINT_BITS (8)
#define BITRES 3
#define EC_MINI(_a,_b) ((_a)+(((_b)-(_a))&-((_b)<(_a))))
#define EC_CLZ0 ((int32_t)sizeof(uint32_t)*CHAR_BIT)
#define EC_CLZ(_x) (__builtin_clz(_x))
#define EC_ILOG(_x) (EC_CLZ0-EC_CLZ(_x))
/** Multiply a 16-bit signed value by a 16-bit uint32_t value. The result is a 32-bit signed value */
#define MULT16_16SU(a,b) ((int32_t)(int16_t)(a)*(int32_t)(uint16_t)(b))
/** 16x32 multiplication, followed by a 16-bit shift right. Results fits in 32 bits */
inline int32_t MULT16_32_Q16(int64_t a, int64_t b){return (int32_t) (a * b) >> 16;}
/** 16x32 multiplication, followed by a 16-bit shift right (round-to-nearest). Results fits in 32 bits */
#define MULT16_32_P16(a,b) ((int32_t)PSHR((int64_t)((int16_t)(a))*(b),16))
/** 16x32 multiplication, followed by a 15-bit shift right. Results fits in 32 bits */
#define MULT16_32_Q15(a,b) ((int32_t)((int64_t)((int16_t)(a))*(b) >> 15))
/** 32x32 multiplication, followed by a 31-bit shift right. Results fits in 32 bits */
#define MULT32_32_Q31(a,b) ((int32_t)((int64_t)(a)*(int64_t)(b) >> 31))
/** Compile-time conversion of float constant to 16-bit value */
#define QCONST16(x,bits) ((int16_t)(0.5L+(x)*(((int32_t)1)<<(bits))))
/** Compile-time conversion of float constant to 32-bit value */
#define QCONST32(x,bits) ((int32_t)(0.5L+(x)*(((int32_t)1)<<(bits))))
/** Change a 16-bit value into a 32-bit value */
#define EXTEND32(x) ((int32_t)(x))
/** Arithmetic shift-right of a 16-bit value */
#define SHR16(a,shift) ((a) >> (shift))
/** Arithmetic shift-left of a 16-bit value */
#define SHL16(a,shift) ((int16_t)((uint16_t)(a)<<(shift)))
/** Arithmetic shift-right of a 32-bit value */
#define SHR32(a,shift) ((a) >> (shift))
/** Arithmetic shift-left of a 32-bit value */
#define SHL32(a,shift) ((int32_t)((uint32_t)(a)<<(shift)))
/** 32-bit arithmetic shift right with rounding-to-nearest instead of rounding down */
static inline int32_t PSHR(int32_t a, uint32_t shift){return (a + ((int32_t)1 << (shift >> 1))) >> shift;}
/** 32-bit arithmetic shift right where the argument can be negative */
#define VSHR32(a, shift) (((shift)>0) ? SHR32(a, shift) : SHL32(a, -(shift)))
#define SATURATE(x,a) (((x)>(a) ? (a) : (x)<-(a) ? -(a) : (x)))
#define SATURATE16(x) ((int16_t)((x)>32767 ? 32767 : (x)<-32768 ? -32768 : (x)))
/** Shift by a and round-to-neareast 32-bit value. Result is a 16-bit value */
#define ROUND16(x,a) ((int16_t)(PSHR((x),(a))))
/** Shift by a and round-to-neareast 32-bit value. Result is a saturated 16-bit value */
#define SROUND16(x,a) (int16_t)(SATURATE(PSHR(x,a), 32767));
/** Divide by two */
#define HALF16(x) (SHR16(x,1))
#define HALF32(x) (SHR32(x,1))
/** Add two 16-bit values */
#define ADD16(a,b) ((int16_t)((int16_t)(a)+(int16_t)(b)))
/** Subtract two 16-bit values */
#define SUB16(a,b) ((int16_t)(a)-(int16_t)(b))
/** Add two 32-bit values */
#define ADD32(a,b) ((int32_t)(a)+(int32_t)(b))
/** Subtract two 32-bit values */
#define SUB32(a,b) ((int32_t)(a)-(int32_t)(b))
/** Add two 32-bit values, ignore any overflows */
#define ADD32_ovflw(a,b) ((int32_t)((uint32_t)(a)+(uint32_t)(b)))
/** Subtract two 32-bit values, ignore any overflows */
#define SUB32_ovflw(a,b) ((int32_t)((uint32_t)(a)-(uint32_t)(b)))
/* Avoid MSVC warning C4146: unary minus operator applied to uint32_t type */
/** Negate 32-bit value, ignore any overflows */
#define NEG32_ovflw(a) ((int32_t)(0-(uint32_t)(a)))
/** 16x16 multiplication where the result fits in 16 bits */
#define MULT16_16_16(a,b) ((((int16_t)(a))*((int16_t)(b))))
/* (int32_t)(int16_t) gives TI compiler a hint that it's 16x16->32 multiply */
/** 16x16 multiplication where the result fits in 32 bits */
#define MULT16_16(a,b) (((int32_t)(int16_t)(a))*((int32_t)(int16_t)(b)))
/** 16x16 multiply-add where the result fits in 32 bits */
#define MAC16_16(c,a,b) (ADD32((c),MULT16_16((a),(b))))
/** 16x32 multiply, followed by a 15-bit shift right and 32-bit add.
b must fit in 31 bits.
Result fits in 32 bits. */
#define MAC16_32_Q15(c,a,b) ADD32((c),ADD32(MULT16_16((a),(b) >> 15), MULT16_16((a),((b)&0x00007fff)) >> 15))
/** 16x32 multiplication, followed by a 16-bit shift right and 32-bit add.
Results fits in 32 bits */
#define MAC16_32_Q16(c,a,b) ADD32((c),ADD32(MULT16_16((a),(b) >> 16), MULT16_16SU((a),((b)&0x0000ffff)) >> 16))
#define MULT16_16_Q11_32(a,b) (MULT16_16((a),(b)) >> 11)
#define MULT16_16_Q11(a,b) (MULT16_16((a),(b)) >> 11)
#define MULT16_16_Q13(a,b) (MULT16_16((a),(b)) >> 13)
#define MULT16_16_Q14(a,b) (MULT16_16((a),(b)) >> 14)
#define MULT16_16_Q15(a,b) (MULT16_16((a),(b)) >> 15)
#define MULT16_16_P13(a,b) (ADD32(4096, MULT16_16((a),(b))) >> 13)
#define MULT16_16_P14(a,b) (ADD32(8192, MULT16_16((a),(b))) >> 14)
#define MULT16_16_P15(a,b) (ADD32(16384,MULT16_16((a),(b))) >> 15)
/** Divide a 32-bit value by a 16-bit value. Result fits in 16 bits */
#define DIV32_16(a,b) ((int16_t)(((int32_t)(a))/((int16_t)(b))))
/** Divide a 32-bit value by a 32-bit value. Result fits in 32 bits */
#define DIV32(a,b) (((int32_t)(a))/((int32_t)(b)))
int32_t celt_rcp(int32_t x);
#define celt_div(a,b) MULT32_32_Q31((int32_t)(a),celt_rcp(b))
#define MAX_PERIOD 1024
#define OPUS_MOVE(dst, src, n) (memmove((dst), (src), (n)*sizeof(*(dst)) + 0*((dst)-(src)) ))
#define ALLOC_STEPS 6
/* Multiplies two 16-bit fractional values. Bit-exactness of this macro is important */
#define FRAC_MUL16(a,b) ((16384+((int32_t)(int16_t)(a)*(int16_t)(b)))>>15)
#define QTHETA_OFFSET 4
#define QTHETA_OFFSET_TWOPHASE 16
#define MAX_FINE_BITS 8
#define MAX_PSEUDO 40
#define LOG_MAX_PSEUDO 6
#define ALLOC_NONE 1
extern const signed char tf_select_table[4][8];
extern const uint32_t SMALL_DIV_TABLE[129];
extern const uint8_t LOG2_FRAC_TABLE[24];
/* Prototypes and inlines*/
static inline int16_t SAT16(int32_t x) {
if(x > INT16_MAX) return INT16_MAX;
if(x < INT16_MIN) return INT16_MIN;
return (int16_t)x;
}
static inline int32_t celt_sudiv(int32_t n, int32_t d) {
assert(d>0); return n/d;
}
static inline int16_t sig2word16(int32_t x){
x = PSHR(x, 12);
x = max(x, -32768);
x = min(x, 32767);
return (int16_t)(x);
}
static inline int32_t ec_tell(ec_ctx *_this){
return _this->nbits_total-EC_ILOG(_this->rng);
}
/* Atan approximation using a 4th order polynomial. Input is in Q15 format and normalized by pi/4. Output is in
Q15 format */
static inline int16_t celt_atan01(int16_t x) {
return MULT16_16_P15(
x, ADD32(32767, MULT16_16_P15(x, ADD32(-21, MULT16_16_P15(x, ADD32(-11943, MULT16_16_P15(4936, x)))))));
}
/* atan2() approximation valid for positive input values */
static inline int16_t celt_atan2p(int16_t y, int16_t x) {
if (y < x) {
int32_t arg;
arg = celt_div(SHL32(EXTEND32(y), 15), x);
if (arg >= 32767) arg = 32767;
return SHR16(celt_atan01((int16_t)(arg)), 1);
} else {
int32_t arg;
arg = celt_div(SHL32(EXTEND32(x), 15), y);
if (arg >= 32767) arg = 32767;
return 25736 - SHR16(celt_atan01((int16_t)(arg)), 1);
}
}
static inline int32_t celt_maxabs16(const int16_t *x, int32_t len) {
int32_t i;
int16_t maxval = 0;
int16_t minval = 0;
for (i = 0; i < len; i++) {
maxval = max(maxval, x[i]);
minval = min(minval, x[i]);
}
return max(EXTEND32(maxval), -EXTEND32(minval));
}
static inline int32_t celt_maxabs32(const int32_t *x, int32_t len) {
int32_t i;
int32_t maxval = 0;
int32_t minval = 0;
for (i = 0; i < len; i++) {
maxval = max(maxval, x[i]);
minval = min(minval, x[i]);
}
return max(maxval, -minval);
}
/** Integer log in base2. Undefined for zero and negative numbers */
static inline int16_t celt_ilog2(int32_t x) {
assert(x > 0);
return EC_ILOG(x) - 1;
}
/** Integer log in base2. Defined for zero, but not for negative numbers */
static inline int16_t celt_zlog2(int32_t x) { return x <= 0 ? 0 : celt_ilog2(x); }
/** Base-2 logarithm approximation (log2(x)). (Q14 input, Q10 output) */
static inline int16_t celt_log2(int32_t x) {
int32_t i;
int16_t n, frac;
/* -0.41509302963303146, 0.9609890551383969, -0.31836011537636605,
0.15530808010959576, -0.08556153059057618 */
static const int16_t C[5] = {-6801 + (1 << 3), 15746, -5217, 2545, -1401};
if (x == 0) return -32767;
i = celt_ilog2(x);
n = VSHR32(x, i - 15) - 32768 - 16384;
frac = ADD16(
C[0],
MULT16_16_Q15(
n, ADD16(C[1], MULT16_16_Q15(n, ADD16(C[2], MULT16_16_Q15(n, ADD16(C[3], MULT16_16_Q15(n, C[4]))))))));
return SHL16(i - 13, 10) + SHR16(frac, 14 - 10);
}
static inline int32_t celt_exp2_frac(int16_t x) {
int16_t frac;
frac = SHL16(x, 4);
return ADD16(16383,
MULT16_16_Q15(frac, ADD16(22804, MULT16_16_Q15(frac, ADD16(14819, MULT16_16_Q15(10204, frac))))));
}
/** Base-2 exponential approximation (2^x). (Q10 input, Q16 output) */
static inline int32_t celt_exp2(int16_t x) {
int32_t integer;
int16_t frac;
integer = SHR16(x, 10);
if (integer > 14)
return 0x7f000000;
else if (integer < -15)
return 0;
frac = celt_exp2_frac(x - SHL16(integer, 10));
return VSHR32(EXTEND32(frac), -integer - 2);
}
static inline void dual_inner_prod(const int16_t *x, const int16_t *y01, const int16_t *y02, int32_t N, int32_t *xy1,
int32_t *xy2) {
int32_t i;
int32_t xy01 = 0;
int32_t xy02 = 0;
for (i = 0; i < N; i++) {
xy01 = MAC16_16(xy01, x[i], y01[i]);
xy02 = MAC16_16(xy02, x[i], y02[i]);
}
*xy1 = xy01;
*xy2 = xy02;
}
/*We make sure a C version is always available for cases where the overhead of vectorization and passing around an
arch flag aren't worth it.*/
static inline int32_t celt_inner_prod(const int16_t *x, const int16_t *y, int32_t N) {
int32_t i;
int32_t xy = 0;
for (i = 0; i < N; i++) xy = MAC16_16(xy, x[i], y[i]);
return xy;
}
static inline int32_t get_pulses(int32_t i){
return i<8 ? i : (8 + (i&7)) << ((i>>3)-1);
}
static inline int32_t bits2pulses(const CELTMode *m, int32_t band, int32_t LM, int32_t bits){
int32_t i;
int32_t lo, hi;
const uint8_t *cache;
LM++;
cache = m->cache.bits + m->cache.index[LM*m->nbEBands+band];
lo = 0;
hi = cache[0];
bits--;
for (i=0;i<LOG_MAX_PSEUDO;i++)
{
int32_t mid = (lo+hi+1)>>1;
/* OPT: Make sure this is implemented with a conditional move */
if ((int32_t)cache[mid] >= bits)
hi = mid;
else
lo = mid;
}
if (bits- (lo == 0 ? -1 : (int32_t)cache[lo]) <= (int32_t)cache[hi]-bits)
return lo;
else
return hi;
}
static inline int32_t pulses2bits(const CELTMode *m, int32_t band, int32_t LM, int32_t pulses){
const uint8_t *cache;
LM++;
cache = m->cache.bits + m->cache.index[LM*m->nbEBands+band];
return pulses == 0 ? 0 : cache[pulses]+1;
}
_Pragma("GCC diagnostic push")
_Pragma("GCC diagnostic ignored \"-Wunused-function\"")
int32_t resampling_factor(int32_t rate);
void comb_filter_const(int32_t *y, int32_t *x, int32_t T, int32_t N, int16_t g10, int16_t g11, int16_t g12);
void comb_filter(int32_t *y, int32_t *x, int32_t T0, int32_t T1, int32_t N, int16_t g0, int16_t g1, int32_t tapset0, int32_t tapset1,
const int16_t *window, int32_t overlap);
void init_caps(const CELTMode *m, int32_t *cap, int32_t LM, int32_t C);
uint32_t celt_lcg_rand(uint32_t seed);
int16_t bitexact_cos(int16_t x);
int32_t bitexact_log2tan(int32_t isin, int32_t icos);
void denormalise_bands(const CELTMode *m, const int16_t * X, int32_t * freq,
const int16_t *bandLogE, int32_t start, int32_t end, int32_t M, int32_t downsample, int32_t silence);
void anti_collapse(const CELTMode *m, int16_t *X_, uint8_t *collapse_masks, int32_t LM, int32_t C, int32_t size, int32_t start,
int32_t end, const int16_t *logE, const int16_t *prev1logE, const int16_t *prev2logE, const int32_t *pulses,
uint32_t seed, int32_t arch);
static void compute_channel_weights(int32_t Ex, int32_t Ey, int16_t w[2]);
static void stereo_split(int16_t * X, int16_t * Y, int32_t N);
static void stereo_merge(int16_t * X, int16_t * Y, int16_t mid, int32_t N, int32_t arch);
static void deinterleave_hadamard(int16_t *X, int32_t N0, int32_t stride, int32_t hadamard);
static void interleave_hadamard(int16_t *X, int32_t N0, int32_t stride, int32_t hadamard);
void haar1(int16_t *X, int32_t N0, int32_t stride);
static int32_t compute_qn(int32_t N, int32_t b, int32_t offset, int32_t pulse_cap, int32_t stereo);
static void compute_theta(struct band_ctx *ctx, struct split_ctx *sctx, int16_t *X, int16_t *Y, int32_t N, int32_t *b, int32_t B,
int32_t __B0, int32_t LM, int32_t stereo, int32_t *fill);
static uint32_t quant_band_n1(struct band_ctx *ctx, int16_t *X, int16_t *Y, int32_t b, int16_t *lowband_out);
static uint32_t quant_partition(struct band_ctx *ctx, int16_t *X, int32_t N, int32_t b, int32_t B, int16_t *lowband, int32_t LM,
int16_t gain, int32_t fill);
static uint32_t quant_band(struct band_ctx *ctx, int16_t *X, int32_t N, int32_t b, int32_t B, int16_t *lowband, int32_t LM,
int16_t *lowband_out, int16_t gain, int16_t *lowband_scratch, int32_t fill);
static uint32_t quant_band_stereo(struct band_ctx *ctx, int16_t *X, int16_t *Y, int32_t N, int32_t b, int32_t B, int16_t *lowband,
int32_t LM, int16_t *lowband_out, int16_t *lowband_scratch, int32_t fill);
static void special_hybrid_folding(const CELTMode *m, int16_t *norm, int16_t *norm2, int32_t start, int32_t M, int32_t dual_stereo);
void quant_all_bands(const CELTMode *m, int32_t start, int32_t end, int16_t *X_, int16_t *Y_,
uint8_t *collapse_masks, const int32_t *bandE, int32_t *pulses, int32_t shortBlocks, int32_t spread,
int32_t dual_stereo, int32_t intensity, int32_t *tf_res, int32_t total_bits, int32_t balance, ec_ctx *ec,
int32_t LM, int32_t codedBands, uint32_t *seed, int32_t complexity, int32_t arch, int32_t disable_inv);
int32_t opus_custom_decoder_get_size(const CELTMode *mode, int32_t channels);
int32_t celt_decoder_get_size(int32_t channels);
int32_t opus_custom_decoder_init(CELTDecoder *st, const CELTMode *mode, int32_t channels);
int32_t celt_decoder_init(CELTDecoder *st, int32_t sampling_rate, int32_t channels);
static void deemphasis_stereo_simple(int32_t *in[], int16_t *pcm, int32_t N, const int16_t coef0, int32_t *mem);
static void deemphasis(int32_t *in[], int16_t *pcm, int32_t N, int32_t C, int32_t downsample, const int16_t *coef,
int32_t *mem, int32_t accum);
static void celt_synthesis(const CELTMode *mode, int16_t *X, int32_t *out_syn[], int16_t *oldBandE, int32_t start,
int32_t effEnd, int32_t C, int32_t CC, int32_t isTransient, int32_t LM, int32_t downsample, int32_t silence, int32_t arch);
static void tf_decode(int32_t start, int32_t end, int32_t isTransient, int32_t *tf_res, int32_t LM, ec_dec *dec);
static void celt_decode_lost(CELTDecoder * st, int32_t N, int32_t LM);
int32_t celt_decode_with_ec(CELTDecoder *st, const uint8_t *data, int32_t len, int16_t * pcm,
int32_t frame_size, ec_dec *dec, int32_t accum);
int32_t celt_decoder_ctl(CELTDecoder * st, int32_t request, ...);
void celt_fir(const int16_t *x, const int16_t *num, int16_t *y, int32_t N, int32_t ord);
void celt_iir(const int32_t *_x, const int16_t *den, int32_t *_y, int32_t N, int32_t ord, int16_t *mem, int32_t arch);
int32_t _celt_autocorr(const int16_t *x, int32_t *ac, const int16_t *window, int32_t overlap, int32_t lag, int32_t n, int32_t arch);
static int32_t cwrsi(int32_t _n, int32_t _k, uint32_t _i, int32_t *_y);
int32_t decode_pulses(int32_t *_y, int32_t _n, int32_t _k, ec_dec *_dec);
uint32_t ec_tell_frac(ec_ctx *_this);
static int32_t ec_read_byte(ec_dec *_this);
static int32_t ec_read_byte_from_end(ec_dec *_this);
static void ec_dec_normalize(ec_dec *_this);
void ec_dec_init(ec_dec *_this, uint8_t *_buf, uint32_t _storage);
uint32_t ec_decode(ec_dec *_this, uint32_t _ft);
uint32_t ec_decode_bin(ec_dec *_this, uint32_t _bits);
void ec_dec_update(ec_dec *_this, uint32_t _fl, uint32_t _fh, uint32_t _ft);
int32_t ec_dec_bit_logp(ec_dec *_this, uint32_t _logp);
int32_t ec_dec_icdf(ec_dec *_this, const uint8_t *_icdf, uint32_t _ftb);
uint32_t ec_dec_uint(ec_dec *_this, uint32_t _ft);
uint32_t ec_dec_bits(ec_dec *_this, uint32_t _bits);
static void kf_bfly2(kiss_fft_cpx *Fout, int32_t m, int32_t N);
static void kf_bfly4(kiss_fft_cpx *Fout, const size_t fstride, const kiss_fft_state *st, int32_t m, int32_t N, int32_t mm);
static void kf_bfly3(kiss_fft_cpx *Fout, const size_t fstride, const kiss_fft_state *st, int32_t m, int32_t N, int32_t mm);
static void kf_bfly5(kiss_fft_cpx *Fout, const size_t fstride, const kiss_fft_state *st, int32_t m, int32_t N, int32_t mm);
void opus_fft_impl(const kiss_fft_state *st, kiss_fft_cpx *fout);
static uint32_t ec_laplace_get_freq1(uint32_t fs0, int32_t decay);
int32_t ec_laplace_decode(ec_dec *dec, uint32_t fs, int32_t decay);
uint32_t isqrt32(uint32_t _val);
int32_t frac_div32(int32_t a, int32_t b);
int16_t celt_rsqrt_norm(int32_t x);
int32_t celt_sqrt(int32_t x);
int16_t celt_cos_norm(int32_t x);
int32_t celt_rcp(int32_t x);
void clt_mdct_backward(const mdct_lookup *l, int32_t *in, int32_t * out, const int16_t * window, int32_t overlap,
int32_t shift, int32_t stride);
CELTMode *opus_custom_mode_create(int32_t Fs, int32_t frame_size, int32_t *error);
static void exp_rotation1(int16_t *X, int32_t len, int32_t stride, int16_t c, int16_t s);
void exp_rotation(int16_t *X, int32_t len, int32_t dir, int32_t stride, int32_t K, int32_t spread);
static void normalise_residual(int32_t * iy, int16_t * X, int32_t N, int32_t Ryy, int16_t gain);
static uint32_t extract_collapse_mask(int32_t *iy, int32_t N, int32_t B);
uint32_t alg_unquant(int16_t *X, int32_t N, int32_t K, int32_t spread, int32_t B, ec_dec *dec, int16_t gain);
void renormalise_vector(int16_t *X, int32_t N, int16_t gain, int32_t arch);
int32_t celt_pitch_xcorr(const int16_t *_x, const int16_t *_y, int32_t *xcorr, int32_t len, int32_t max_pitch, int32_t arch);
static int32_t interp_bits2pulses(const CELTMode *m, int32_t start, int32_t end, int32_t skip_start, const int32_t *bits1, const int32_t *bits2,
const int32_t *thresh, const int32_t *cap, int32_t total, int32_t *_balance, int32_t skip_rsv,
int32_t *intensity, int32_t intensity_rsv, int32_t *dual_stereo, int32_t dual_stereo_rsv, int32_t *bits,
int32_t *ebits, int32_t *fine_priority, int32_t C, int32_t LM, ec_ctx *ec, int32_t prev, int32_t signalBandwidth);
int32_t clt_compute_allocation(const CELTMode *m, int32_t start, int32_t end, const int32_t *offsets, const int32_t *cap, int32_t alloc_trim,
int32_t *intensity, int32_t *dual_stereo, int32_t total, int32_t *balance, int32_t *pulses, int32_t *ebits,
int32_t *fine_priority, int32_t C, int32_t LM, ec_ctx *ec, int32_t prev, int32_t signalBandwidth);
void unquant_coarse_energy(const CELTMode *m, int32_t start, int32_t end, int16_t *oldEBands, int32_t intra, ec_dec *dec, int32_t C,
int32_t LM);
void unquant_fine_energy(const CELTMode *m, int32_t start, int32_t end, int16_t *oldEBands, int32_t *fine_quant, ec_dec *dec,
int32_t C);
void unquant_energy_finalise(const CELTMode *m, int32_t start, int32_t end, int16_t *oldEBands, int32_t *fine_quant,
int32_t *fine_priority, int32_t bits_left, ec_dec *dec, int32_t C);
static void xcorr_kernel(const int16_t *x, const int16_t *y, int32_t sum[4], int32_t len);
_Pragma("GCC diagnostic pop")
#ifdef __cplusplus
}
#endif
...@@ -7,6 +7,7 @@ ...@@ -7,6 +7,7 @@
************************************************************************************/ ************************************************************************************/
#include "opus_decoder.h" #include "opus_decoder.h"
#include "celt.h"
// global vars // global vars
bool f_m_subsequentPage = false; bool f_m_subsequentPage = false;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment