|
|
@ -31,16 +31,16 @@ void ff_jpegls_init_state(JLSState *state){ |
|
|
|
int i; |
|
|
|
int i; |
|
|
|
|
|
|
|
|
|
|
|
state->twonear = state->near * 2 + 1; |
|
|
|
state->twonear = state->near * 2 + 1; |
|
|
|
state->range = ((state->maxval + state->twonear - 1) / state->twonear) + 1; |
|
|
|
state->range = (state->maxval + state->twonear - 1) / state->twonear + 1; |
|
|
|
|
|
|
|
|
|
|
|
// QBPP = ceil(log2(RANGE))
|
|
|
|
// QBPP = ceil(log2(RANGE))
|
|
|
|
for(state->qbpp = 0; (1 << state->qbpp) < state->range; state->qbpp++); |
|
|
|
for(state->qbpp = 0; (1 << state->qbpp) < state->range; state->qbpp++); |
|
|
|
|
|
|
|
|
|
|
|
state->bpp = FFMAX(av_log2(state->maxval)+1, 2); |
|
|
|
state->bpp = FFMAX(av_log2(state->maxval) + 1, 2); |
|
|
|
state->limit = 2*(state->bpp + FFMAX(state->bpp, 8)) - state->qbpp; |
|
|
|
state->limit = 2*(state->bpp + FFMAX(state->bpp, 8)) - state->qbpp; |
|
|
|
|
|
|
|
|
|
|
|
for(i = 0; i < 367; i++) { |
|
|
|
for(i = 0; i < 367; i++) { |
|
|
|
state->A[i] = FFMAX((state->range + 32) >> 6, 2); |
|
|
|
state->A[i] = FFMAX(state->range + 32 >> 6, 2); |
|
|
|
state->N[i] = 1; |
|
|
|
state->N[i] = 1; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -63,7 +63,7 @@ void ff_jpegls_reset_coding_parameters(JLSState *s, int reset_all){ |
|
|
|
if(s->maxval==0 || reset_all) s->maxval= (1 << s->bpp) - 1; |
|
|
|
if(s->maxval==0 || reset_all) s->maxval= (1 << s->bpp) - 1; |
|
|
|
|
|
|
|
|
|
|
|
if(s->maxval >=128){ |
|
|
|
if(s->maxval >=128){ |
|
|
|
factor= (FFMIN(s->maxval, 4095) + 128)>>8; |
|
|
|
factor = FFMIN(s->maxval, 4095) + 128 >> 8; |
|
|
|
|
|
|
|
|
|
|
|
if(s->T1==0 || reset_all) |
|
|
|
if(s->T1==0 || reset_all) |
|
|
|
s->T1= iso_clip(factor*(basic_t1-2) + 2 + 3*s->near, s->near+1, s->maxval); |
|
|
|
s->T1= iso_clip(factor*(basic_t1-2) + 2 + 3*s->near, s->near+1, s->maxval); |
|
|
|