00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00028 #include "jpegls.h"
00029
00030 void ff_jpegls_init_state(JLSState *state){
00031 int i;
00032
00033 state->twonear = state->near * 2 + 1;
00034 state->range = ((state->maxval + state->twonear - 1) / state->twonear) + 1;
00035
00036
00037 for(state->qbpp = 0; (1 << state->qbpp) < state->range; state->qbpp++);
00038
00039 state->bpp = FFMAX(av_log2(state->maxval)+1, 2);
00040 state->limit = 2*(state->bpp + FFMAX(state->bpp, 8)) - state->qbpp;
00041
00042 for(i = 0; i < 367; i++) {
00043 state->A[i] = FFMAX((state->range + 32) >> 6, 2);
00044 state->N[i] = 1;
00045 }
00046
00047 }
00048
00052 static inline int iso_clip(int v, int vmin, int vmax){
00053 if(v > vmax || v < vmin) return vmin;
00054 else return v;
00055 }
00056
00057 void ff_jpegls_reset_coding_parameters(JLSState *s, int reset_all){
00058 const int basic_t1= 3;
00059 const int basic_t2= 7;
00060 const int basic_t3= 21;
00061 int factor;
00062
00063 if(s->maxval==0 || reset_all) s->maxval= (1 << s->bpp) - 1;
00064
00065 if(s->maxval >=128){
00066 factor= (FFMIN(s->maxval, 4095) + 128)>>8;
00067
00068 if(s->T1==0 || reset_all)
00069 s->T1= iso_clip(factor*(basic_t1-2) + 2 + 3*s->near, s->near+1, s->maxval);
00070 if(s->T2==0 || reset_all)
00071 s->T2= iso_clip(factor*(basic_t2-3) + 3 + 5*s->near, s->T1, s->maxval);
00072 if(s->T3==0 || reset_all)
00073 s->T3= iso_clip(factor*(basic_t3-4) + 4 + 7*s->near, s->T2, s->maxval);
00074 }else{
00075 factor= 256 / (s->maxval + 1);
00076
00077 if(s->T1==0 || reset_all)
00078 s->T1= iso_clip(FFMAX(2, basic_t1/factor + 3*s->near), s->near+1, s->maxval);
00079 if(s->T2==0 || reset_all)
00080 s->T2= iso_clip(FFMAX(3, basic_t2/factor + 5*s->near), s->T1, s->maxval);
00081 if(s->T3==0 || reset_all)
00082 s->T3= iso_clip(FFMAX(4, basic_t3/factor + 7*s->near), s->T2, s->maxval);
00083 }
00084
00085 if(s->reset==0 || reset_all) s->reset= 64;
00086
00087 }