ffv1enc: better heuristic to calculate initial states
Slightly improves compression of 2pass files Tested-by: "Peter B." <pb@das-werkstatt.com> Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
parent
c177f2ec4a
commit
0aa1d848ec
@ -856,18 +856,29 @@ static av_cold int encode_init(AVCodecContext *avctx)
|
||||
find_best_state(best_state, s->state_transition);
|
||||
|
||||
for (i = 0; i < s->quant_table_count; i++) {
|
||||
for (j = 0; j < s->context_count[i]; j++)
|
||||
for (k = 0; k < 32; k++) {
|
||||
for (k = 0; k < 32; k++) {
|
||||
double a=0, b=0;
|
||||
int jp = 0;
|
||||
for (j = 0; j < s->context_count[i]; j++) {
|
||||
double p = 128;
|
||||
if (s->rc_stat2[i][j][k][0] + s->rc_stat2[i][j][k][1]) {
|
||||
p = 256.0 * s->rc_stat2[i][j][k][1] /
|
||||
(s->rc_stat2[i][j][k][0] + s->rc_stat2[i][j][k][1]);
|
||||
if (s->rc_stat2[i][j][k][0] + s->rc_stat2[i][j][k][1] > 200 && j || a+b > 200) {
|
||||
if (a+b)
|
||||
p = 256.0 * b / (a + b);
|
||||
s->initial_states[i][jp][k] =
|
||||
best_state[av_clip(round(p), 1, 255)][av_clip((a + b) / gob_count, 0, 255)];
|
||||
for(jp++; jp<j; jp++)
|
||||
s->initial_states[i][jp][k] = s->initial_states[i][jp-1][k];
|
||||
a=b=0;
|
||||
}
|
||||
a += s->rc_stat2[i][j][k][0];
|
||||
b += s->rc_stat2[i][j][k][1];
|
||||
if (a+b) {
|
||||
p = 256.0 * b / (a + b);
|
||||
}
|
||||
s->initial_states[i][j][k] =
|
||||
best_state[av_clip(round(p), 1, 255)][av_clip((s->rc_stat2[i][j][k][0] +
|
||||
s->rc_stat2[i][j][k][1]) /
|
||||
gob_count, 0, 255)];
|
||||
best_state[av_clip(round(p), 1, 255)][av_clip((a + b) / gob_count, 0, 255)];
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user