Mercurial > libavcodec.hg
changeset 4955:bbe763044678 libavcodec
Use 1 array with double the size instead of 2 arrays with normal size
Eliminates need for concatenation and adds proper fix for FIXME
author | ramiro |
---|---|
date | Wed, 09 May 2007 22:24:23 +0000 |
parents | 1fd90978db25 |
children | ea7519d7649f |
files | cook.c |
diffstat | 1 files changed, 8 insertions(+), 20 deletions(-) [+] |
line wrap: on
line diff
--- a/cook.c Wed May 09 22:00:08 2007 +0000 +++ b/cook.c Wed May 09 22:24:23 2007 +0000 @@ -387,11 +387,9 @@ int exp_index2[102]; int exp_index1[102]; - int tmp_categorize_array1[128]; - int tmp_categorize_array1_idx=0; - int tmp_categorize_array2[128]; - int tmp_categorize_array2_idx=0; - int category_index_size=0; + int tmp_categorize_array[128*2]; + int tmp_categorize_array1_idx=q->numvector_size; + int tmp_categorize_array2_idx=q->numvector_size; bits_left = q->bits_per_subpacket - get_bits_count(&q->gb); @@ -403,8 +401,7 @@ memset(&exp_index1,0,102*sizeof(int)); memset(&exp_index2,0,102*sizeof(int)); - memset(&tmp_categorize_array1,0,128*sizeof(int)); - memset(&tmp_categorize_array2,0,128*sizeof(int)); + memset(&tmp_categorize_array,0,128*2*sizeof(int)); bias=-32; @@ -446,7 +443,7 @@ } } if(index==-1)break; - tmp_categorize_array1[tmp_categorize_array1_idx++] = index; + tmp_categorize_array[tmp_categorize_array1_idx++] = index; tmpbias1 -= expbits_tab[exp_index1[index]] - expbits_tab[exp_index1[index]+1]; ++exp_index1[index]; @@ -463,7 +460,7 @@ } } if(index == -1)break; - tmp_categorize_array2[tmp_categorize_array2_idx++] = index; + tmp_categorize_array[--tmp_categorize_array2_idx] = index; tmpbias2 -= expbits_tab[exp_index2[index]] - expbits_tab[exp_index2[index]-1]; --exp_index2[index]; @@ -473,17 +470,8 @@ for(i=0 ; i<q->total_subbands ; i++) category[i] = exp_index2[i]; - /* Concatenate the two arrays. */ - for(i=tmp_categorize_array2_idx-1 ; i >= 0; i--) - category_index[category_index_size++] = tmp_categorize_array2[i]; - - for(i=0;i<tmp_categorize_array1_idx;i++) - category_index[category_index_size++ ] = tmp_categorize_array1[i]; - - /* FIXME: mc_sich_ra8_20.rm triggers this, not sure with what we - should fill the remaining bytes. */ - for(i=category_index_size;i<q->numvector_size;i++) - category_index[i]=0; + for(i=0 ; i<q->numvector_size-1 ; i++) + category_index[i] = tmp_categorize_array[tmp_categorize_array2_idx++]; }