ref: bc272de74be78be9ca9e5c2f93126d08b8f2d0dd
parent: 531f2ae7e3db9e05b5c34e47d25190260253fb3e
author: Jean-Marc Valin <[email protected]>
date: Mon Aug 2 05:41:31 EDT 2010
Code simplifications for log->amplitude conversion
--- a/libcelt/celt.c
+++ b/libcelt/celt.c
@@ -1061,13 +1061,15 @@
quant_energy_finalise(st->mode, st->start, st->end, bandE, st->oldBandE, error, fine_quant, fine_priority, nbCompressedBytes*8-ec_enc_tell(enc, 0), enc, C);
-#ifdef MEASURE_NORM_MSE
- measure_norm_mse(st->mode, X, X0, bandE, bandE0, M, N, C);
-#endif
-
/* Re-synthesis of the coded audio if required */
if (resynth)
{
+ log2Amp(st->mode, st->start, st->end, bandE, st->oldBandE, C);
+
+#ifdef MEASURE_NORM_MSE
+ measure_norm_mse(st->mode, X, X0, bandE, bandE0, M, N, C);
+#endif
+
if (st->pitch_available>0 && st->pitch_available<MAX_PERIOD)
st->pitch_available+=N;
@@ -1827,6 +1829,8 @@
quant_all_bands(0, st->mode, st->start, st->end, X, C==2 ? X+N : NULL, NULL, pulses, shortBlocks, has_fold, tf_res, 1, len*8, dec, LM);
unquant_energy_finalise(st->mode, st->start, st->end, bandE, st->oldBandE, fine_quant, fine_priority, len*8-ec_dec_tell(dec, 0), dec, C);
+
+ log2Amp(st->mode, st->start, st->end, bandE, st->oldBandE, C);
if (mdct_weight_shift)
{
--- a/libcelt/quant_bands.c
+++ b/libcelt/quant_bands.c
@@ -227,15 +227,6 @@
} while (++c < C);
}
}
- c=0;
- do {
- for (i=start;i<m->nbEBands;i++)
- {
- eBands[i+c*m->nbEBands] = log2Amp(oldEBands[i+c*m->nbEBands]);
- if (oldEBands[i+c*m->nbEBands] < -QCONST16(7.f,DB_SHIFT))
- oldEBands[i+c*m->nbEBands] = -QCONST16(7.f,DB_SHIFT);
- }
- } while (++c < C);
}
void unquant_coarse_energy(const CELTMode *m, int start, int end, celt_ener *eBands, celt_word16 *oldEBands, int intra, int *prob, ec_dec *dec, int _C, int LM)
@@ -324,13 +315,22 @@
} while (++c < C);
}
}
+}
+
+void log2Amp(const CELTMode *m, int start, int end,
+ celt_ener *eBands, celt_word16 *oldEBands, int _C)
+{
+ int c, i;
+ const int C = CHANNELS(_C);
c=0;
do {
for (i=start;i<m->nbEBands;i++)
{
- eBands[i+c*m->nbEBands] = log2Amp(oldEBands[i+c*m->nbEBands]);
+ celt_word16 lg = oldEBands[i+c*m->nbEBands];
+ eBands[i+c*m->nbEBands] = PSHR32(celt_exp2(SHL16(lg,11-DB_SHIFT)),4);
if (oldEBands[i+c*m->nbEBands] < -QCONST16(7.f,DB_SHIFT))
oldEBands[i+c*m->nbEBands] = -QCONST16(7.f,DB_SHIFT);
}
} while (++c < C);
}
+
--- a/libcelt/quant_bands.h
+++ b/libcelt/quant_bands.h
@@ -44,15 +44,11 @@
return celt_log2(MAX32(QCONST32(.001f,14),SHL32(amp,2)));
}
-static inline celt_word32 log2Amp(celt_word16 lg)
-{
- return PSHR32(celt_exp2(SHL16(lg,11-DB_SHIFT)),4);
-}
+void log2Amp(const CELTMode *m, int start, int end,
+ celt_ener *eBands, celt_word16 *oldEBands, int _C);
int *quant_prob_alloc(const CELTMode *m);
void quant_prob_free(int *freq);
-
-void compute_fine_allocation(const CELTMode *m, int *bits, int budget);
int intra_decision(celt_word16 *eBands, celt_word16 *oldEBands, int start, int end, int len, int C);