diff options
author | Justin Ruggles <justin.ruggles@gmail.com> | 2010-07-30 20:53:02 +0000 |
---|---|---|
committer | Justin Ruggles <justin.ruggles@gmail.com> | 2010-07-30 20:53:02 +0000 |
commit | 6266cfb4ce1cd4d57cb47e167163c978cd80c621 (patch) | |
tree | 76e4896ea1b1c2676ca42e9f45d31e1f7bf93a07 | |
parent | fc001d6cc1aa3fc740381a6806899be9143cf292 (diff) | |
download | ffmpeg-6266cfb4ce1cd4d57cb47e167163c978cd80c621.tar.gz |
Combine and simplify output_residual() and output_subframe_lpc().
Originally committed as revision 24607 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavcodec/flacenc.c | 58 |
1 files changed, 21 insertions, 37 deletions
diff --git a/libavcodec/flacenc.c b/libavcodec/flacenc.c index b8a36718f0..dd39bc0d83 100644 --- a/libavcodec/flacenc.c +++ b/libavcodec/flacenc.c @@ -1113,47 +1113,15 @@ static void output_subframe_verbatim(FlacEncodeContext *s, FlacSubframe *sub) } -static void output_residual(FlacEncodeContext *s, FlacSubframe *sub) -{ - int i, j, p, n, parts; - int k, porder, psize, res_cnt; - FlacFrame *frame; - int32_t *res; - - frame = &s->frame; - res = sub->residual; - n = frame->blocksize; - - /* rice-encoded block */ - put_bits(&s->pb, 2, 0); - - /* partition order */ - porder = sub->rc.porder; - psize = n >> porder; - parts = (1 << porder); - put_bits(&s->pb, 4, porder); - res_cnt = psize - sub->order; - - /* residual */ - j = sub->order; - for (p = 0; p < parts; p++) { - k = sub->rc.params[p]; - put_bits(&s->pb, 4, k); - if (p == 1) - res_cnt = psize; - for (i = 0; i < res_cnt && j < n; i++, j++) - set_sr_golomb_flac(&s->pb, res[j], k, INT32_MAX, 0); - } -} - - static void output_subframe_lpc(FlacEncodeContext *s, FlacSubframe *sub) { - int i; + int i, p, porder, psize; + int32_t *res, *part_end, *frame_end; /* warm-up samples */ + res = sub->residual; for (i = 0; i < sub->order; i++) - put_sbits(&s->pb, sub->obits, sub->residual[i]); + put_sbits(&s->pb, sub->obits, *res++); /* LPC coefficients */ if (sub->type == FLAC_SUBFRAME_LPC) { @@ -1164,8 +1132,24 @@ static void output_subframe_lpc(FlacEncodeContext *s, FlacSubframe *sub) put_sbits(&s->pb, cbits, sub->coefs[i]); } + /* rice-encoded block */ + put_bits(&s->pb, 2, 0); + + /* partition order */ + porder = sub->rc.porder; + psize = s->frame.blocksize >> porder; + put_bits(&s->pb, 4, porder); + /* residual */ - output_residual(s, sub); + part_end = &sub->residual[psize ]; + frame_end = &sub->residual[s->frame.blocksize]; + for (p = 0; p < 1 << porder; p++) { + int k = sub->rc.params[p]; + put_bits(&s->pb, 4, k); + while (res < part_end) + set_sr_golomb_flac(&s->pb, *res++, k, INT32_MAX, 0); + part_end = FFMIN(frame_end, part_end + psize); + } } |