Go to the documentation of this file.
   34 #define RESTORE_PRED(sce, sfb) \ 
   35         if (sce->ics.prediction_used[sfb]) {\ 
   36             sce->ics.prediction_used[sfb] = 0;\ 
   37             sce->band_type[sfb] = sce->band_alt[sfb];\ 
   44     tmp.i = (
tmp.i + 0x00008000
U) & 0xFFFF0000U;
 
   52     tmp.i = (
tmp.i + 0x00007FFF
U + (
tmp.i & 0x00010000
U >> 16)) & 0xFFFF0000
U;
 
   67     const float a     = 0.953125; 
 
   68     const float alpha = 0.90625;  
 
   69     const float   k1 = ps->
k1;
 
   70     const float   r0 = ps->
r0,     r1 = ps->
r1;
 
   71     const float cor0 = ps->
cor0, cor1 = ps->
cor1;
 
   72     const float var0 = ps->
var0, var1 = ps->
var1;
 
   73     const float e0 = *coef - ps->
x_est;
 
   74     const float e1 = e0 - k1 * r0;
 
  125         for (sfb = 0; sfb < pmax; sfb++) {
 
  126             for (k = sce->
ics.
swb_offset[sfb]; k < sce->ics.swb_offset[sfb + 1]; k++) {
 
  143     for (
i = 1; 
i < 31; 
i++) {
 
  153     int start, 
w, w2, 
g, 
i, count = 0;
 
  158     const int pmax  = 
FFMIN(pmax0, pmax1);
 
  170             float ener0 = 0.0f, ener1 = 0.0f, ener01 = 0.0f;
 
  172             if (sfb < PRED_SFB_START || sfb > pmax || sum != 2) {
 
  180                     float coef0 = sce0->
pcoeffs[start+(
w+w2)*128+
i];
 
  181                     float coef1 = sce1->
pcoeffs[start+(
w+w2)*128+
i];
 
  182                     ener0  += coef0*coef0;
 
  183                     ener1  += coef1*coef1;
 
  184                     ener01 += (coef0 + coef1)*(coef0 + coef1);
 
  188                                              ener0, ener1, 
ener01, 1, -1);
 
  190                                              ener0, ener1, 
ener01, 1, +1);
 
  209     int i, max_group_id_c, max_frame = 0;
 
  210     float avg_frame = 0.0f;
 
  217     for (
i = 1; 
i < 31; 
i++) {
 
  235     int sfb, 
i, count = 0, cost_coeffs = 0, cost_pred = 0;
 
  237     float *O34  = &
s->scoefs[128*0], *P34 = &
s->scoefs[128*1];
 
  238     float *SENT = &
s->scoefs[128*2], *S34 = &
s->scoefs[128*3];
 
  239     float *QERR = &
s->scoefs[128*4];
 
  250         for (
i = 1; 
i < 31; 
i++)
 
  258         int cost1, cost2, cb_p;
 
  261         const int cb_min = sce->
zeroes[sfb] ? 0 : 1;
 
  264         const int num_coeffs = sce->
ics.
swb_offset[sfb + 1] - start_coef;
 
  265         const FFPsyBand *band = &
s->psy.ch[
s->cur_channel].psy_bands[sfb];
 
  273         s->aacdsp.abs_pow34(O34, &sce->
coeffs[start_coef], num_coeffs);
 
  275                                                  O34, num_coeffs, sce->
sf_idx[sfb],
 
  277         cost_coeffs += cost1;
 
  280         for (
i = 0; 
i < num_coeffs; 
i++)
 
  282         s->aacdsp.abs_pow34(S34, SENT, num_coeffs);
 
  292         for (
i = 0; 
i < num_coeffs; 
i++)
 
  293             sce->
prcoeffs[start_coef + 
i] += QERR[
i] != 0.0f ? (sce->
prcoeffs[start_coef + 
i] - QERR[
i]) : 0.0f;
 
  294         s->aacdsp.abs_pow34(P34, &sce->
prcoeffs[start_coef], num_coeffs);
 
  300                                                  P34, num_coeffs, sce->
sf_idx[sfb],
 
  302         for (
i = 0; 
i < num_coeffs; 
i++)
 
  303             dist_spec_err += (O34[
i] - P34[
i])*(O34[
i] - P34[
i]);
 
  305         dist2 += dist_spec_err;
 
  319     if (count && cost_coeffs < cost_pred) {
 
  345     for (sfb = 0; sfb < pmax; sfb++)
 
  
static void update_pred_resets(SingleChannelElement *sce)
enum BandType band_alt[128]
alternative band type
struct PredictorState * predictor_state
uint8_t zeroes[128]
band is not coded
static void reset_all_predictors(PredictorState *ps)
static void put_bits(Jpeg2000EncoderContext *s, int val, int n)
put n times val bit
SingleChannelElement ch[2]
int num_swb
number of scalefactor window bands
float coeffs[1024]
coefficients for IMDCT, maybe processed
static void predict(PredictorState *ps, float *coef, float *rcoef, int set)
IndividualChannelStream ics
float prcoeffs[1024]
Main prediction coefs.
int predictor_reset_count[31]
used to count prediction resets
static void set(uint8_t *a[], int ch, int index, int ch_count, enum AVSampleFormat f, double v)
static float flt16_trunc(float pf)
@ NOISE_BT
Spectral data are scaled white noise not coded in the bitstream.
void ff_aac_apply_main_pred(AACEncContext *s, SingleChannelElement *sce)
float ff_quantize_and_encode_band_cost(struct AACEncContext *s, PutBitContext *pb, const float *in, float *quant, const float *scaled, int size, int scale_idx, int cb, const float lambda, const float uplim, int *bits, float *energy)
const uint8_t * swb_sizes
table of scalefactor band sizes for a particular window
@ INTENSITY_BT2
Scalefactor data are intensity stereo positions (out of phase).
Individual Channel Stream.
static void reset_predict_state(PredictorState *ps)
single band psychoacoustic information
static int inc(int num, int period)
int sf_idx[128]
scalefactor indices
const uint8_t ff_aac_pred_sfb_max[]
enum WindowSequence window_sequence[2]
void ff_aac_adjust_common_pred(AACEncContext *s, ChannelElement *cpe)
static int update_counters(IndividualChannelStream *ics, int inc)
int common_window
Set if channels share a common 'IndividualChannelStream' in bitstream.
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
enum BandType band_type[128]
band types
static float flt16_round(float pf)
Single Channel Element - used for both SCE and LFE elements.
#define i(width, name, range_min, range_max)
static int find_min_book(float maxval, int sf)
float pcoeffs[1024]
coefficients for IMDCT, pristine
channel element - generic struct for SCE/CPE/CCE/LFE
const uint16_t * swb_offset
table of offsets to the lowest spectral coefficient of a scalefactor band, sfb, for a particular wind...
static double erf(double z)
erf function Algorithm taken from the Boost project, source: http://www.boost.org/doc/libs/1_46_1/boo...
@ RESERVED_BT
Band types following are encoded differently from others.
struct AACISError ff_aac_is_encoding_err(AACEncContext *s, ChannelElement *cpe, int start, int w, int g, float ener0, float ener1, float ener01, int use_pcoeffs, int phase)
uint8_t prediction_used[41]
#define AV_PROFILE_AAC_MAIN
void ff_aac_encode_main_pred(AACEncContext *s, SingleChannelElement *sce)
Encoder predictors data.
static float flt16_even(float pf)
static float find_max_val(int group_len, int swb_size, const float *scaled)
static const int16_t alpha[]
void ff_aac_search_for_pred(AACEncContext *s, SingleChannelElement *sce)
static void reset_predictor_group(SingleChannelElement *sce, int group_num)
uint8_t max_sfb
number of scalefactor bands per group
int predictor_reset_group
#define RESTORE_PRED(sce, sfb)
#define PRED_RESET_FRAME_MIN
int predictor_initialized