|
|
@ -500,7 +500,6 @@ static void slice_buffer_init(slice_buffer * buf, int line_count, int max_alloca |
|
|
|
|
|
|
|
|
|
|
|
static DWTELEM * slice_buffer_load_line(slice_buffer * buf, int line) |
|
|
|
static DWTELEM * slice_buffer_load_line(slice_buffer * buf, int line) |
|
|
|
{ |
|
|
|
{ |
|
|
|
int i; |
|
|
|
|
|
|
|
int offset; |
|
|
|
int offset; |
|
|
|
DWTELEM * buffer; |
|
|
|
DWTELEM * buffer; |
|
|
|
|
|
|
|
|
|
|
@ -523,7 +522,6 @@ static DWTELEM * slice_buffer_load_line(slice_buffer * buf, int line) |
|
|
|
|
|
|
|
|
|
|
|
static void slice_buffer_release(slice_buffer * buf, int line) |
|
|
|
static void slice_buffer_release(slice_buffer * buf, int line) |
|
|
|
{ |
|
|
|
{ |
|
|
|
int i; |
|
|
|
|
|
|
|
int offset; |
|
|
|
int offset; |
|
|
|
DWTELEM * buffer; |
|
|
|
DWTELEM * buffer; |
|
|
|
|
|
|
|
|
|
|
@ -933,7 +931,7 @@ static void horizontal_decomposeX(DWTELEM *b, int width){ |
|
|
|
DWTELEM temp[width]; |
|
|
|
DWTELEM temp[width]; |
|
|
|
const int width2= width>>1; |
|
|
|
const int width2= width>>1; |
|
|
|
const int w2= (width+1)>>1; |
|
|
|
const int w2= (width+1)>>1; |
|
|
|
int A1,A2,A3,A4, x; |
|
|
|
int x; |
|
|
|
|
|
|
|
|
|
|
|
inplace_lift(b, width, COEFFS1, N1, SHIFT1, LX1, 0); |
|
|
|
inplace_lift(b, width, COEFFS1, N1, SHIFT1, LX1, 0); |
|
|
|
inplace_lift(b, width, COEFFS2, N2, SHIFT2, LX0, 0); |
|
|
|
inplace_lift(b, width, COEFFS2, N2, SHIFT2, LX0, 0); |
|
|
@ -952,7 +950,7 @@ static void horizontal_decomposeX(DWTELEM *b, int width){ |
|
|
|
static void horizontal_composeX(DWTELEM *b, int width){ |
|
|
|
static void horizontal_composeX(DWTELEM *b, int width){ |
|
|
|
DWTELEM temp[width]; |
|
|
|
DWTELEM temp[width]; |
|
|
|
const int width2= width>>1; |
|
|
|
const int width2= width>>1; |
|
|
|
int A1,A2,A3,A4, x; |
|
|
|
int x; |
|
|
|
const int w2= (width+1)>>1; |
|
|
|
const int w2= (width+1)>>1; |
|
|
|
|
|
|
|
|
|
|
|
memcpy(temp, b, width*sizeof(int)); |
|
|
|
memcpy(temp, b, width*sizeof(int)); |
|
|
@ -1010,7 +1008,7 @@ static void spatial_composeX(DWTELEM *buffer, int width, int height, int stride) |
|
|
|
static void horizontal_decompose53i(DWTELEM *b, int width){ |
|
|
|
static void horizontal_decompose53i(DWTELEM *b, int width){ |
|
|
|
DWTELEM temp[width]; |
|
|
|
DWTELEM temp[width]; |
|
|
|
const int width2= width>>1; |
|
|
|
const int width2= width>>1; |
|
|
|
int A1,A2,A3,A4, x; |
|
|
|
int x; |
|
|
|
const int w2= (width+1)>>1; |
|
|
|
const int w2= (width+1)>>1; |
|
|
|
|
|
|
|
|
|
|
|
for(x=0; x<width2; x++){ |
|
|
|
for(x=0; x<width2; x++){ |
|
|
@ -1020,6 +1018,8 @@ static void horizontal_decompose53i(DWTELEM *b, int width){ |
|
|
|
if(width&1) |
|
|
|
if(width&1) |
|
|
|
temp[x ]= b[2*x ]; |
|
|
|
temp[x ]= b[2*x ]; |
|
|
|
#if 0 |
|
|
|
#if 0 |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
int A1,A2,A3,A4; |
|
|
|
A2= temp[1 ]; |
|
|
|
A2= temp[1 ]; |
|
|
|
A4= temp[0 ]; |
|
|
|
A4= temp[0 ]; |
|
|
|
A1= temp[0+width2]; |
|
|
|
A1= temp[0+width2]; |
|
|
@ -1047,6 +1047,7 @@ static void horizontal_decompose53i(DWTELEM *b, int width){ |
|
|
|
A2 += (A1 + A3 + 2)>>2; |
|
|
|
A2 += (A1 + A3 + 2)>>2; |
|
|
|
b[width -1] = A3; |
|
|
|
b[width -1] = A3; |
|
|
|
b[width2-1] = A2; |
|
|
|
b[width2-1] = A2; |
|
|
|
|
|
|
|
} |
|
|
|
#else |
|
|
|
#else |
|
|
|
lift(b+w2, temp+w2, temp, 1, 1, 1, width, -1, 0, 1, 1, 0); |
|
|
|
lift(b+w2, temp+w2, temp, 1, 1, 1, width, -1, 0, 1, 1, 0); |
|
|
|
lift(b , temp , b+w2, 1, 1, 1, width, 1, 2, 2, 0, 0); |
|
|
|
lift(b , temp , b+w2, 1, 1, 1, width, 1, 2, 2, 0, 0); |
|
|
@ -1268,9 +1269,10 @@ static void horizontal_compose53i(DWTELEM *b, int width){ |
|
|
|
DWTELEM temp[width]; |
|
|
|
DWTELEM temp[width]; |
|
|
|
const int width2= width>>1; |
|
|
|
const int width2= width>>1; |
|
|
|
const int w2= (width+1)>>1; |
|
|
|
const int w2= (width+1)>>1; |
|
|
|
int A1,A2,A3,A4, x; |
|
|
|
int x; |
|
|
|
|
|
|
|
|
|
|
|
#if 0 |
|
|
|
#if 0 |
|
|
|
|
|
|
|
int A1,A2,A3,A4; |
|
|
|
A2= temp[1 ]; |
|
|
|
A2= temp[1 ]; |
|
|
|
A4= temp[0 ]; |
|
|
|
A4= temp[0 ]; |
|
|
|
A1= temp[0+width2]; |
|
|
|
A1= temp[0+width2]; |
|
|
@ -1452,7 +1454,9 @@ static void vertical_compose97i(DWTELEM *b0, DWTELEM *b1, DWTELEM *b2, DWTELEM * |
|
|
|
int i; |
|
|
|
int i; |
|
|
|
|
|
|
|
|
|
|
|
for(i=0; i<width; i++){ |
|
|
|
for(i=0; i<width; i++){ |
|
|
|
|
|
|
|
#ifndef lift5 |
|
|
|
int r; |
|
|
|
int r; |
|
|
|
|
|
|
|
#endif |
|
|
|
b4[i] -= (W_DM*(b3[i] + b5[i])+W_DO)>>W_DS; |
|
|
|
b4[i] -= (W_DM*(b3[i] + b5[i])+W_DO)>>W_DS; |
|
|
|
#ifdef lift5 |
|
|
|
#ifdef lift5 |
|
|
|
b3[i] -= (W_CM*(b2[i] + b4[i])+W_CO)>>W_CS; |
|
|
|
b3[i] -= (W_CM*(b2[i] + b4[i])+W_CO)>>W_CS; |
|
|
@ -1877,7 +1881,7 @@ static inline void unpack_coeffs(SnowContext *s, SubBand *b, SubBand * parent, i |
|
|
|
|
|
|
|
|
|
|
|
static inline void decode_subband_slice_buffered(SnowContext *s, SubBand *b, slice_buffer * sb, int start_y, int h, int save_state[1]){ |
|
|
|
static inline void decode_subband_slice_buffered(SnowContext *s, SubBand *b, slice_buffer * sb, int start_y, int h, int save_state[1]){ |
|
|
|
const int w= b->width; |
|
|
|
const int w= b->width; |
|
|
|
int x,y; |
|
|
|
int y; |
|
|
|
const int qlog= clip(s->qlog + b->qlog, 0, QROOT*16); |
|
|
|
const int qlog= clip(s->qlog + b->qlog, 0, QROOT*16); |
|
|
|
int qmul= qexp[qlog&(QROOT-1)]<<(qlog>>QSHIFT); |
|
|
|
int qmul= qexp[qlog&(QROOT-1)]<<(qlog>>QSHIFT); |
|
|
|
int qadd= (s->qbias*qmul)>>QBIAS_SHIFT; |
|
|
|
int qadd= (s->qbias*qmul)>>QBIAS_SHIFT; |
|
|
@ -2583,7 +2587,6 @@ assert(src_stride > 2*MB_SIZE + 5); |
|
|
|
|
|
|
|
|
|
|
|
START_TIMER |
|
|
|
START_TIMER |
|
|
|
|
|
|
|
|
|
|
|
int block_index = 0; |
|
|
|
|
|
|
|
for(y=0; y<b_h; y++){ |
|
|
|
for(y=0; y<b_h; y++){ |
|
|
|
//FIXME ugly missue of obmc_stride
|
|
|
|
//FIXME ugly missue of obmc_stride
|
|
|
|
uint8_t *obmc1= obmc + y*obmc_stride; |
|
|
|
uint8_t *obmc1= obmc + y*obmc_stride; |
|
|
@ -2908,7 +2911,7 @@ static void quantize(SnowContext *s, SubBand *b, DWTELEM *src, int stride, int b |
|
|
|
const int qlog= clip(s->qlog + b->qlog, 0, QROOT*16); |
|
|
|
const int qlog= clip(s->qlog + b->qlog, 0, QROOT*16); |
|
|
|
const int qmul= qexp[qlog&(QROOT-1)]<<(qlog>>QSHIFT); |
|
|
|
const int qmul= qexp[qlog&(QROOT-1)]<<(qlog>>QSHIFT); |
|
|
|
int x,y, thres1, thres2; |
|
|
|
int x,y, thres1, thres2; |
|
|
|
START_TIMER |
|
|
|
// START_TIMER
|
|
|
|
|
|
|
|
|
|
|
|
if(s->qlog == LOSSLESS_QLOG) return; |
|
|
|
if(s->qlog == LOSSLESS_QLOG) return; |
|
|
|
|
|
|
|
|
|
|
@ -2964,7 +2967,6 @@ static void quantize(SnowContext *s, SubBand *b, DWTELEM *src, int stride, int b |
|
|
|
|
|
|
|
|
|
|
|
static void dequantize_slice_buffered(SnowContext *s, slice_buffer * sb, SubBand *b, DWTELEM *src, int stride, int start_y, int end_y){ |
|
|
|
static void dequantize_slice_buffered(SnowContext *s, slice_buffer * sb, SubBand *b, DWTELEM *src, int stride, int start_y, int end_y){ |
|
|
|
const int w= b->width; |
|
|
|
const int w= b->width; |
|
|
|
const int h= b->height; |
|
|
|
|
|
|
|
const int qlog= clip(s->qlog + b->qlog, 0, QROOT*16); |
|
|
|
const int qlog= clip(s->qlog + b->qlog, 0, QROOT*16); |
|
|
|
const int qmul= qexp[qlog&(QROOT-1)]<<(qlog>>QSHIFT); |
|
|
|
const int qmul= qexp[qlog&(QROOT-1)]<<(qlog>>QSHIFT); |
|
|
|
const int qadd= (s->qbias*qmul)>>QBIAS_SHIFT; |
|
|
|
const int qadd= (s->qbias*qmul)>>QBIAS_SHIFT; |
|
|
@ -3042,7 +3044,6 @@ static void decorrelate(SnowContext *s, SubBand *b, DWTELEM *src, int stride, in |
|
|
|
|
|
|
|
|
|
|
|
static void correlate_slice_buffered(SnowContext *s, slice_buffer * sb, SubBand *b, DWTELEM *src, int stride, int inverse, int use_median, int start_y, int end_y){ |
|
|
|
static void correlate_slice_buffered(SnowContext *s, slice_buffer * sb, SubBand *b, DWTELEM *src, int stride, int inverse, int use_median, int start_y, int end_y){ |
|
|
|
const int w= b->width; |
|
|
|
const int w= b->width; |
|
|
|
const int h= b->height; |
|
|
|
|
|
|
|
int x,y; |
|
|
|
int x,y; |
|
|
|
|
|
|
|
|
|
|
|
// START_TIMER
|
|
|
|
// START_TIMER
|
|
|
|