aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/flacenc.c
diff options
context:
space:
mode:
authorJustin Ruggles <justin.ruggles@gmail.com>2010-07-30 20:53:02 +0000
committerJustin Ruggles <justin.ruggles@gmail.com>2010-07-30 20:53:02 +0000
commit6266cfb4ce1cd4d57cb47e167163c978cd80c621 (patch)
tree76e4896ea1b1c2676ca42e9f45d31e1f7bf93a07 /libavcodec/flacenc.c
parentfc001d6cc1aa3fc740381a6806899be9143cf292 (diff)
downloadffmpeg-6266cfb4ce1cd4d57cb47e167163c978cd80c621.tar.gz
Combine and simplify output_residual() and output_subframe_lpc().
Originally committed as revision 24607 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/flacenc.c')
-rw-r--r--libavcodec/flacenc.c58
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);
+ }
}