[FFmpeg-soc] [soc]: r2735 - aacenc/aacenc.c
kostya
subversion at mplayerhq.hu
Tue Jul 8 07:00:54 CEST 2008
Author: kostya
Date: Tue Jul 8 07:00:54 2008
New Revision: 2735
Log:
Use windows in the same way AAC decoder does
Modified:
aacenc/aacenc.c
Modified: aacenc/aacenc.c
==============================================================================
--- aacenc/aacenc.c (original)
+++ aacenc/aacenc.c Tue Jul 8 07:00:54 2008
@@ -32,6 +32,10 @@
#include "aacpsy.h"
// XXX: borrowed from aac.c, move to some header eventually
+DECLARE_ALIGNED_16(static float, kbd_long_1024[1024]);
+DECLARE_ALIGNED_16(static float, kbd_short_128[128]);
+DECLARE_ALIGNED_16(static float, sine_long_1024[1024]);
+DECLARE_ALIGNED_16(static float, sine_short_128[128]);
#include "aactab.h"
/**
@@ -167,8 +171,6 @@ typedef struct {
PutBitContext pb;
MDCTContext mdct1024;
MDCTContext mdct128;
- DECLARE_ALIGNED_16(float, kbd_long_1024[1024]);
- DECLARE_ALIGNED_16(float, kbd_short_128[128]);
DECLARE_ALIGNED_16(FFTSample, output[2048]);
DECLARE_ALIGNED_16(FFTSample, tmp[1024]);
@@ -229,8 +231,10 @@ static int aac_encode_init(AVCodecContex
ff_mdct_init(&s->mdct1024, 11, 0);
ff_mdct_init(&s->mdct128, 8, 0);
// window init
- ff_kbd_window_init(s->kbd_long_1024, 4.0, 1024);
- ff_kbd_window_init(s->kbd_short_128, 6.0, 128);
+ ff_kbd_window_init(kbd_long_1024, 4.0, 1024);
+ ff_kbd_window_init(kbd_short_128, 6.0, 128);
+ ff_sine_window_init(sine_long_1024, 1024);
+ ff_sine_window_init(sine_short_128, 128);
ff_aac_psy_init(&s->psy, avctx, AAC_PSY_3GPP, 0, s->swb_sizes1024, s->swb_num1024, s->swb_sizes128, s->swb_num128);
avctx->extradata = av_malloc(2);
@@ -243,14 +247,16 @@ static int aac_encode_init(AVCodecContex
static void analyze(AVCodecContext *avctx, AACEncContext *s, ChannelElement *cpe, short *audio, int channel)
{
int i, j, k;
+ const float * lwindow = cpe->ch[channel].ics.use_kb_window[0] ? kbd_long_1024 : sine_long_1024;
+ const float * swindow = cpe->ch[channel].ics.use_kb_window[0] ? kbd_short_128 : sine_short_128;
if (cpe->ch[channel].ics.window_sequence != EIGHT_SHORT_SEQUENCE) {
// perform MDCT
memcpy(s->output, cpe->ch[channel].saved, sizeof(float)*1024);
j = channel;
for (i = 0; i < 1024; i++, j += avctx->channels){
- s->output[i+1024] = audio[j] / 512.0 * s->kbd_long_1024[1024 - i - 1];
- cpe->ch[channel].saved[i] = audio[j] / 512.0 * s->kbd_long_1024[i];
+ s->output[i+1024] = audio[j] / 512.0 * lwindow[1024 - i - 1];
+ cpe->ch[channel].saved[i] = audio[j] / 512.0 * lwindow[i];
}
ff_mdct_calc(&s->mdct1024, cpe->ch[channel].coeffs, s->output, s->tmp);
}else{
@@ -258,8 +264,8 @@ static void analyze(AVCodecContext *avct
memcpy(s->output, cpe->ch[channel].saved + k + !k*1024 - 128, sizeof(float)*128);
j = channel + k * avctx->channels;
for (i = 0; i < 128; i++, j += avctx->channels){
- s->output[i+128] = audio[j] / 512.0 * s->kbd_short_128[128 - i - 1];
- cpe->ch[channel].saved[i+k] = audio[j] / 512.0 * s->kbd_short_128[i];
+ s->output[i+128] = audio[j] / 512.0 * swindow[128 - i - 1];
+ cpe->ch[channel].saved[i+k] = audio[j] / 512.0 * swindow[i];
}
ff_mdct_calc(&s->mdct128, cpe->ch[channel].coeffs + k, s->output, s->tmp);
}
More information about the FFmpeg-soc
mailing list