ac3enc: choose the closest bit rate to the one requested instead of failing
This commit is contained in:
parent
78e9852a2e
commit
6aeea1dfb2
@ -2189,15 +2189,20 @@ static av_cold int validate_options(AC3EncodeContext *s)
|
|||||||
wpf--;
|
wpf--;
|
||||||
s->frame_size_min = 2 * wpf;
|
s->frame_size_min = 2 * wpf;
|
||||||
} else {
|
} else {
|
||||||
|
int best_br = 0, best_code = 0, best_diff = INT_MAX;
|
||||||
for (i = 0; i < 19; i++) {
|
for (i = 0; i < 19; i++) {
|
||||||
if ((ff_ac3_bitrate_tab[i] >> s->bit_alloc.sr_shift)*1000 == avctx->bit_rate)
|
int br = (ff_ac3_bitrate_tab[i] >> s->bit_alloc.sr_shift) * 1000;
|
||||||
|
int diff = abs(br - avctx->bit_rate);
|
||||||
|
if (diff < best_diff) {
|
||||||
|
best_br = br;
|
||||||
|
best_code = i;
|
||||||
|
best_diff = diff;
|
||||||
|
}
|
||||||
|
if (!best_diff)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (i == 19) {
|
avctx->bit_rate = best_br;
|
||||||
av_log(avctx, AV_LOG_ERROR, "invalid bit rate\n");
|
s->frame_size_code = best_code << 1;
|
||||||
return AVERROR(EINVAL);
|
|
||||||
}
|
|
||||||
s->frame_size_code = i << 1;
|
|
||||||
s->frame_size_min = 2 * ff_ac3_frame_size_tab[s->frame_size_code][s->bit_alloc.sr_code];
|
s->frame_size_min = 2 * ff_ac3_frame_size_tab[s->frame_size_code][s->bit_alloc.sr_code];
|
||||||
s->num_blks_code = 0x3;
|
s->num_blks_code = 0x3;
|
||||||
s->num_blocks = 6;
|
s->num_blocks = 6;
|
||||||
|
Loading…
Reference in New Issue
Block a user