[FFmpeg-devel] [PATCH] G.722 decoder

Martin Storsjö martin
Wed Sep 8 23:37:49 CEST 2010


On Wed, 8 Sep 2010, Michael Niedermayer wrote:

> On Wed, Sep 08, 2010 at 06:06:42PM +0300, Martin Storsj? wrote:
> [...]
> > +static int g722_decode_frame(AVCodecContext *avctx, void *data,
> > +                             int *data_size, AVPacket *avpkt)
> > +{
> > +    G722Context *c = avctx->priv_data;
> > +    int16_t *out_buf = data;
> > +    int j, out_len = 0;
> > +    const int skip = 8 - avctx->bits_per_coded_sample;
> > +    const int16_t *quantizer_table = low_inv_quants[skip];
> > +    GetBitContext gb;
> > +
> > +    init_get_bits(&gb, avpkt->data, avpkt->size * 8);
> > +
> > +    for (j = 0; j < avpkt->size; j++) {
> > +        int ilow, ihigh, rlow;
> > +        int dhigh, rhigh;
> > +        int xout1, xout2;
> > +
> > +        ihigh = get_bits(&gb, 2);
> > +        ilow = get_bits(&gb, 6 - skip);
> > +        skip_bits(&gb, skip);
> > +
> > +        rlow = av_clip((c->band[0].scale_factor * quantizer_table[ilow] >> 10)
> > +                      + c->band[0].s_predictor, -16384, 16383);
> > +        update_low_predictor(&c->band[0], ilow >> (2 - skip));
> > +
> > +        dhigh = c->band[1].scale_factor * high_inv_quant[ihigh] >> 10;
> > +        rhigh = av_clip(dhigh + c->band[1].s_predictor, -16384, 16383);
> > +        update_high_predictor(&c->band[1], dhigh, ihigh);
> > +
> > +        c->prev_samples[c->prev_samples_pos++] = rlow + rhigh;
> > +        c->prev_samples[c->prev_samples_pos++] = rlow - rhigh;
> > +        apply_qmf(c->prev_samples + c->prev_samples_pos - 24,
> > +                  &xout1, &xout2);
> > +        out_buf[out_len++] = av_clip_int16(xout1 >> 12);
> > +        out_buf[out_len++] = av_clip_int16(xout2 >> 12);
> > +        if (c->prev_samples_pos >= PREV_SAMPLES_BUF_SIZE) {
> > +            memmove(c->prev_samples,
> > +                    c->prev_samples + c->prev_samples_pos - 22,
> > +                    22 * sizeof(c->prev_samples[0]));
> > +            c->prev_samples_pos = 22;
> > +        }
> 
> lowres could be checked for this

Ah, so if avctx->lowres == 1, we'd just output the lower subband? Good 
idea, I'll try to implement that tomorrow.

> except that iam fine with the patch

Good, I'll resend once more when I've implemented the lowres option.

// Martin



More information about the ffmpeg-devel mailing list