1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-08-04 22:03:09 +02:00

avcodec/ffv1enc: Eliminate copy_state

Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
Michael Niedermayer
2025-03-28 09:17:58 +01:00
parent 2f0500f22c
commit 3faee894fc

View File

@ -1271,34 +1271,17 @@ typedef struct RemapEncoderState {
int run1start_mul_index; int run1start_mul_index;
} RemapEncoderState; } RemapEncoderState;
static inline void copy_state(RemapEncoderState *dst, const RemapEncoderState *src)
{
dst->rc = src->rc;
memcpy(dst->mul, src->mul, (src->mul_count + 1) * sizeof(src->mul[0]));
memcpy(dst->state, src->state, sizeof(dst->state));
dst->lu = src->lu;
dst->run = src->run;
dst->last_val = src->last_val;
dst->compact_index = src->compact_index;
dst->mul_count = src->mul_count;
dst->i = src->i;
dst->pixel_num = src->pixel_num;
dst->p = src->p;
dst->current_mul_index = src->current_mul_index;
dst->run1final = src->run1final;
dst->run1start_i = src->run1start_i;
dst->run1start_last_val = src->run1start_last_val;
dst->run1start_mul_index = src->run1start_mul_index;
}
static int encode_float32_remap_segment(FFV1SliceContext *sc, static int encode_float32_remap_segment(FFV1SliceContext *sc,
RemapEncoderState *state_arg, int update, int final) int p, int mul_count, int *mul_tab, int update, int final)
{ {
RemapEncoderState s; RemapEncoderState s;
copy_state(&s, state_arg); s.pixel_num = sc->slice_width * sc->slice_height;
s.p = p;
if (s.i == 0) { s.i = 0;
s.rc = sc->c;
s.mul_count = mul_count;
memcpy(s.mul, mul_tab, sizeof(*mul_tab)*(mul_count+1));
memset(s.state, 128, sizeof(s.state)); memset(s.state, 128, sizeof(s.state));
put_symbol(&s.rc, s.state[0][0], s.mul_count, 0); put_symbol(&s.rc, s.state[0][0], s.mul_count, 0);
memset(s.state, 128, sizeof(s.state)); memset(s.state, 128, sizeof(s.state));
@ -1308,7 +1291,6 @@ static int encode_float32_remap_segment(FFV1SliceContext *sc,
s.run = 0; s.run = 0;
s.current_mul_index = -1; s.current_mul_index = -1;
s.run1final = 0; s.run1final = 0;
}
for (; s.i < s.pixel_num+1; s.i++) { for (; s.i < s.pixel_num+1; s.i++) {
int current_mul = s.current_mul_index < 0 ? 1 : FFABS(s.mul[s.current_mul_index]); int current_mul = s.current_mul_index < 0 ? 1 : FFABS(s.mul[s.current_mul_index]);
@ -1395,7 +1377,7 @@ static int encode_float32_remap_segment(FFV1SliceContext *sc,
} }
if (update) { if (update) {
copy_state(state_arg, &s); sc->c = s.rc;
} }
return get_rac_count(&s.rc); return get_rac_count(&s.rc);
} }
@ -1403,25 +1385,22 @@ static int encode_float32_remap_segment(FFV1SliceContext *sc,
static void encode_float32_remap(FFV1Context *f, FFV1SliceContext *sc, static void encode_float32_remap(FFV1Context *f, FFV1SliceContext *sc,
const uint8_t *src[4]) const uint8_t *src[4])
{ {
RemapEncoderState s; int pixel_num = sc->slice_width * sc->slice_height;
s.pixel_num = sc->slice_width * sc->slice_height; int mul_count;
av_assert0 (s.pixel_num <= 65536); av_assert0 (pixel_num <= 65536);
for (int p= 0; p < 1 + 2*f->chroma_planes + f->transparency; p++) { for (int p= 0; p < 1 + 2*f->chroma_planes + f->transparency; p++) {
float score_sum[2] = {0}; float score_sum[2] = {0};
int mul_all[2][513]; int mul_all[2][513];
s.rc = sc->c;
s.i = 0;
s.p = p;
for (int mul_count= 1; mul_count<=512; mul_count+=511) { for (mul_count= 1; mul_count<=512; mul_count+=511) {
float score_tab_all[513][23] = {0}; float score_tab_all[513][23] = {0};
int64_t last_val = -1; int64_t last_val = -1;
int *mul_tab = mul_all[mul_count>>9]; int *mul_tab = mul_all[mul_count>>9];
int last_mul_index = -1; int last_mul_index = -1;
score_sum[mul_count>>9] += log2(mul_count); score_sum[mul_count>>9] += log2(mul_count);
for (int i= 0; i<s.pixel_num; i++) { for (int i= 0; i<pixel_num; i++) {
int64_t val = sc->unit[p][i].val; int64_t val = sc->unit[p][i].val;
int mul_index = (val + 1LL)*mul_count >> 32; int mul_index = (val + 1LL)*mul_count >> 32;
if (val != last_val) { if (val != last_val) {
@ -1461,17 +1440,11 @@ static void encode_float32_remap(FFV1Context *f, FFV1SliceContext *sc,
} }
mul_tab[mul_count] = 1; mul_tab[mul_count] = 1;
s.mul_count = mul_count; score_sum[mul_count>>9] = encode_float32_remap_segment(sc, p, mul_count, mul_all[mul_count>>9], 0, 0);
memcpy(s.mul, mul_all[s.mul_count>>9], sizeof(*s.mul)*(s.mul_count+1));
score_sum[mul_count>>9] = encode_float32_remap_segment(sc, &s, 0, 0);
} }
s.mul_count = score_sum[0] <= score_sum[1] ? 1 : 512; mul_count = score_sum[0] <= score_sum[1] ? 1 : 512;
memcpy(s.mul, mul_all[s.mul_count>>9], sizeof(*s.mul)*(s.mul_count+1)); encode_float32_remap_segment(sc, p, mul_count, mul_all[mul_count>>9], 1, 1);
encode_float32_remap_segment(sc, &s, 1, 1);
sc->c = s.rc;
} }
} }