Commit e509ac52 authored by michael's avatar michael

factorize update state out


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@6786 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 89b6ee37
...@@ -187,6 +187,38 @@ static int decode_lse(MJpegDecodeContext *s) ...@@ -187,6 +187,38 @@ static int decode_lse(MJpegDecodeContext *s)
return 0; return 0;
} }
static void inline downscale_state(JLSState *state, int Q){
if(state->N[Q] == state->reset){
state->A[Q] >>=1;
state->B[Q] >>=1;
state->N[Q] >>=1;
}
state->N[Q]++;
}
static inline int update_state_regular(JLSState *state, int Q, int err){
state->A[Q] += FFABS(err);
err *= state->twonear;
state->B[Q] += err;
downscale_state(state, Q);
if(state->B[Q] <= -state->N[Q]) {
state->B[Q] += state->N[Q];
if(state->C[Q] > -128)
state->C[Q]--;
if(state->B[Q] <= -state->N[Q])
state->B[Q] = -state->N[Q] + 1;
}else if(state->B[Q] > 0){
state->B[Q] -= state->N[Q];
if(state->C[Q] < 127)
state->C[Q]++;
if(state->B[Q] > 0)
state->B[Q] = 0;
}
return err;
}
/** /**
* Get context-dependent Golomb code, decode it and update context * Get context-dependent Golomb code, decode it and update context
...@@ -211,30 +243,7 @@ static inline int ls_get_code_regular(GetBitContext *gb, JLSState *state, int Q) ...@@ -211,30 +243,7 @@ static inline int ls_get_code_regular(GetBitContext *gb, JLSState *state, int Q)
if(!state->near && !k && (2 * state->B[Q] <= -state->N[Q])) if(!state->near && !k && (2 * state->B[Q] <= -state->N[Q]))
ret = -(ret + 1); ret = -(ret + 1);
state->A[Q] += FFABS(ret); ret= update_state_regular(state, Q, ret);
ret *= state->twonear;
state->B[Q] += ret;
if(state->N[Q] == state->reset) {
state->A[Q] >>= 1;
state->B[Q] >>= 1;
state->N[Q] >>= 1;
}
state->N[Q]++;
if(state->B[Q] <= -state->N[Q]) {
state->B[Q] += state->N[Q];
if(state->C[Q] > -128)
state->C[Q]--;
if(state->B[Q] <= -state->N[Q])
state->B[Q] = -state->N[Q] + 1;
}else if(state->B[Q] > 0){
state->B[Q] -= state->N[Q];
if(state->C[Q] < 127)
state->C[Q]++;
if(state->B[Q] > 0)
state->B[Q] = 0;
}
return ret; return ret;
} }
...@@ -273,12 +282,7 @@ static inline int ls_get_code_runterm(GetBitContext *gb, JLSState *state, int RI ...@@ -273,12 +282,7 @@ static inline int ls_get_code_runterm(GetBitContext *gb, JLSState *state, int RI
/* update state */ /* update state */
state->A[Q] += FFABS(ret) - RItype; state->A[Q] += FFABS(ret) - RItype;
ret *= state->twonear; ret *= state->twonear;
if(state->N[Q] == state->reset){ downscale_state(state, Q);
state->A[Q] >>=1;
state->B[Q] >>=1;
state->N[Q] >>=1;
}
state->N[Q]++;
return ret; return ret;
} }
...@@ -520,29 +524,7 @@ static inline void ls_encode_regular(JLSState *state, PutBitContext *pb, int Q, ...@@ -520,29 +524,7 @@ static inline void ls_encode_regular(JLSState *state, PutBitContext *pb, int Q,
set_ur_golomb_jpegls(pb, val, k, state->limit, state->qbpp); set_ur_golomb_jpegls(pb, val, k, state->limit, state->qbpp);
state->A[Q] += FFABS(err); update_state_regular(state, Q, err);
state->B[Q] += err * state->twonear;
if(state->N[Q] == state->reset) {
state->A[Q] >>= 1;
state->B[Q] >>= 1;
state->N[Q] >>= 1;
}
state->N[Q]++;
if(state->B[Q] <= -state->N[Q]) {
state->B[Q] += state->N[Q];
if(state->C[Q] > -128)
state->C[Q]--;
if(state->B[Q] <= -state->N[Q])
state->B[Q] = -state->N[Q] + 1;
}else if(state->B[Q] > 0){
state->B[Q] -= state->N[Q];
if(state->C[Q] < 127)
state->C[Q]++;
if(state->B[Q] > 0)
state->B[Q] = 0;
}
} }
/** /**
...@@ -572,12 +554,7 @@ static inline void ls_encode_runterm(JLSState *state, PutBitContext *pb, int RIt ...@@ -572,12 +554,7 @@ static inline void ls_encode_runterm(JLSState *state, PutBitContext *pb, int RIt
state->B[Q]++; state->B[Q]++;
state->A[Q] += (val + 1 - RItype) >> 1; state->A[Q] += (val + 1 - RItype) >> 1;
if(state->N[Q] == state->reset) { downscale_state(state, Q);
state->A[Q] >>= 1;
state->B[Q] >>= 1;
state->N[Q] >>= 1;
}
state->N[Q]++;
} }
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment