36 9,8,7,7,6,6,6,6,5,5,5,5,5,5,5,5,
37 4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,
38 3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,
39 3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,
40 2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,
41 2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,
42 2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,
43 2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,
44 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,
45 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,
46 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,
47 1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,
48 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
49 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
50 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
51 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
52 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
53 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
54 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
55 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
59 {128,176,208,240}, {128,167,197,227}, {128,158,187,216}, {123,150,178,205},
60 {116,142,169,195}, {111,135,160,185}, {105,128,152,175}, {100,122,144,166},
61 { 95,116,137,158}, { 90,110,130,150}, { 85,104,123,142}, { 81, 99,117,135},
62 { 77, 94,111,128}, { 73, 89,105,122}, { 69, 85,100,116}, { 66, 80, 95,110},
63 { 62, 76, 90,104}, { 59, 72, 86, 99}, { 56, 69, 81, 94}, { 53, 65, 77, 89},
64 { 51, 62, 73, 85}, { 48, 59, 69, 80}, { 46, 56, 66, 76}, { 43, 53, 63, 72},
65 { 41, 50, 59, 69}, { 39, 48, 56, 65}, { 37, 45, 54, 62}, { 35, 43, 51, 59},
66 { 33, 41, 48, 56}, { 32, 39, 46, 53}, { 30, 37, 43, 50}, { 29, 35, 41, 48},
67 { 27, 33, 39, 45}, { 26, 31, 37, 43}, { 24, 30, 35, 41}, { 23, 28, 33, 39},
68 { 22, 27, 32, 37}, { 21, 26, 30, 35}, { 20, 24, 29, 33}, { 19, 23, 27, 31},
69 { 18, 22, 26, 30}, { 17, 21, 25, 28}, { 16, 20, 23, 27}, { 15, 19, 22, 25},
70 { 14, 18, 21, 24}, { 14, 17, 20, 23}, { 13, 16, 19, 22}, { 12, 15, 18, 21},
71 { 12, 14, 17, 20}, { 11, 14, 16, 19}, { 11, 13, 15, 18}, { 10, 12, 15, 17},
72 { 10, 12, 14, 16}, { 9, 11, 13, 15}, { 9, 11, 12, 14}, { 8, 10, 12, 14},
73 { 8, 9, 11, 13}, { 7, 9, 11, 12}, { 7, 9, 10, 12}, { 7, 8, 10, 11},
74 { 6, 8, 9, 11}, { 6, 7, 9, 10}, { 6, 7, 8, 9}, { 2, 2, 2, 2},
78 1, 2, 3, 4, 5, 6, 7, 8,
79 9,10,11,12,13,14,15,16,
80 17,18,19,20,21,22,23,24,
81 25,26,27,28,29,30,31,32,
82 33,34,35,36,37,38,39,40,
83 41,42,43,44,45,46,47,48,
84 49,50,51,52,53,54,55,56,
85 57,58,59,60,61,62,62,63,
89 0, 0, 1, 2, 2, 4, 4, 5,
90 6, 7, 8, 9, 9,11,11,12,
91 13,13,15,15,16,16,18,18,
92 19,19,21,21,22,22,23,24,
93 24,25,26,26,27,27,28,29,
94 29,30,30,30,31,32,32,33,
95 33,33,34,34,35,35,35,36,
96 36,36,37,37,37,38,38,63,
100 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
101 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
102 3, 3, 3, 3, 3, 3, 3, 3, 4, 4, 4, 4, 4, 4, 4, 4,
103 5, 5, 5, 5, 6, 6, 6, 6, 7, 7, 7, 7, 8, 8, 8
141 static int initialized = 0;
162 for(i=0; i< 63; i++){
182 static inline void renorm_cabac_encoder(
CABACContext *c){
183 while(c->
range < 0x100){
187 }
else if(c->
low<0x200){
203 if(bit == ((*state)&1)){
204 c->
range -= RangeLPS;
212 renorm_cabac_encoder(c);
227 }
else if(c->
low<0x400){
240 static int put_cabac_terminate(
CABACContext *c,
int bit){
244 renorm_cabac_encoder(c);
249 renorm_cabac_encoder(c);
252 put_cabac_bit(c, c->
low>>9);
273 for(i=0; i<
SIZE; i++){
275 else r[i] = (i>>8)&1;
278 for(i=0; i<
SIZE; i++){
280 put_cabac_bypass(&c, r[i]&1);
284 for(i=0; i<
SIZE; i++){
286 put_cabac(&c, state, r[i]&1);
290 put_cabac_terminate(&c, 1);
294 memset(state, 0,
sizeof(state));
296 for(i=0; i<
SIZE; i++){
303 for(i=0; i<
SIZE; i++){