📄 image.c
字号:
{
img->luma_log2_weight_denom = 5;
img->chroma_log2_weight_denom = 5;
img->wp_round_luma = 16;
img->wp_round_chroma = 16;
for (i=0; i<MAX_REFERENCE_PICTURES; i++)
{
for (comp=0; comp<3; comp++)
{
log_weight_denom = (comp == 0) ? img->luma_log2_weight_denom : img->chroma_log2_weight_denom;
img->wp_weight[0][i][comp] = 1<<log_weight_denom;
img->wp_weight[1][i][comp] = 1<<log_weight_denom;
img->wp_offset[0][i][comp] = 0;
img->wp_offset[1][i][comp] = 0;
}
}
}
if (bframe)
{
for (i=0; i<max_l0_ref; i++)
{
for (j=0; j<max_l1_ref; j++)
{
for (comp = 0; comp<3; comp++)
{
log_weight_denom = (comp == 0) ? img->luma_log2_weight_denom : img->chroma_log2_weight_denom;
if (active_pps->weighted_bipred_idc == 1)
{
img->wbp_weight[0][i][j][comp] = img->wp_weight[0][i][comp];
img->wbp_weight[1][i][j][comp] = img->wp_weight[1][j][comp];
}
else if (active_pps->weighted_bipred_idc == 2)
{
td = iClip3(-128,127,listX[LIST_1][j]->poc - listX[LIST_0][i]->poc);
if (td == 0 || listX[LIST_1][j]->is_long_term || listX[LIST_0][i]->is_long_term)
{
img->wbp_weight[0][i][j][comp] = 32;
img->wbp_weight[1][i][j][comp] = 32;
}
else
{
tb = iClip3(-128,127,img->ThisPOC - listX[LIST_0][i]->poc);
tx = (16384 + iabs(td/2))/td;
DistScaleFactor = iClip3(-1024, 1023, (tx*tb + 32 )>>6);
img->wbp_weight[1][i][j][comp] = DistScaleFactor >> 2;
img->wbp_weight[0][i][j][comp] = 64 - img->wbp_weight[1][i][j][comp];
if (img->wbp_weight[1][i][j][comp] < -64 || img->wbp_weight[1][i][j][comp] > 128)
{
img->wbp_weight[0][i][j][comp] = 32;
img->wbp_weight[1][i][j][comp] = 32;
img->wp_offset[0][i][comp] = 0;
img->wp_offset[1][j][comp] = 0;
}
}
}
}
}
}
}
if (bframe && img->MbaffFrameFlag)
{
for (i=0; i<2*max_l0_ref; i++)
{
for (j=0; j<2*max_l1_ref; j++)
{
for (comp = 0; comp<3; comp++)
{
for (k=2; k<6; k+=2)
{
img->wp_offset[k+0][i][comp] = img->wp_offset[0][i>>1][comp];
img->wp_offset[k+1][j][comp] = img->wp_offset[1][j>>1][comp];
log_weight_denom = (comp == 0) ? img->luma_log2_weight_denom : img->chroma_log2_weight_denom;
if (active_pps->weighted_bipred_idc == 1)
{
img->wbp_weight[k+0][i][j][comp] = img->wp_weight[0][i>>1][comp];
img->wbp_weight[k+1][i][j][comp] = img->wp_weight[1][j>>1][comp];
}
else if (active_pps->weighted_bipred_idc == 2)
{
td = iClip3(-128,127,listX[k+LIST_1][j]->poc - listX[k+LIST_0][i]->poc);
if (td == 0 || listX[k+LIST_1][j]->is_long_term || listX[k+LIST_0][i]->is_long_term)
{
img->wbp_weight[k+0][i][j][comp] = 32;
img->wbp_weight[k+1][i][j][comp] = 32;
}
else
{
tb = iClip3(-128,127,((k==2)?img->toppoc:img->bottompoc) - listX[k+LIST_0][i]->poc);
tx = (16384 + iabs(td/2))/td;
DistScaleFactor = iClip3(-1024, 1023, (tx*tb + 32 )>>6);
img->wbp_weight[k+1][i][j][comp] = DistScaleFactor >> 2;
img->wbp_weight[k+0][i][j][comp] = 64 - img->wbp_weight[k+1][i][j][comp];
if (img->wbp_weight[k+1][i][j][comp] < -64 || img->wbp_weight[k+1][i][j][comp] > 128)
{
img->wbp_weight[k+1][i][j][comp] = 32;
img->wbp_weight[k+0][i][j][comp] = 32;
img->wp_offset[k+0][i][comp] = 0;
img->wp_offset[k+1][j][comp] = 0;
}
}
}
}
}
}
}
}
}
static void decode_slice(ImageParameters *img, Slice *currSlice, struct inp_par *inp, int current_header)
{
if (active_pps->entropy_coding_mode_flag)
{
init_contexts (img);
cabac_new_slice();
}
if ( (active_pps->weighted_bipred_idc > 0 && (img->type == B_SLICE)) || (active_pps->weighted_pred_flag && img->type !=I_SLICE))
fill_wp_params(img);
//printf("frame picture %d %d %d\n",img->structure,img->ThisPOC,img->direct_spatial_mv_pred_flag);
// decode main slice information
if ((current_header == SOP || current_header == SOS) && currSlice->ei_flag == 0)
decode_one_slice(img, currSlice, inp);
// setMB-Nr in case this slice was lost
// if(currSlice->ei_flag)
// img->current_mb_nr = currSlice->last_mb_nr + 1;
}
/*!
************************************************************************
* \brief
* Error tracking: if current frame is lost or any reference frame of
* current frame is lost, current frame is incorrect.
************************************************************************
*/
static void Error_tracking(void)
{
int i;
if(img->redundant_pic_cnt == 0)
{
Is_primary_correct = Is_redundant_correct = 1;
}
if(img->redundant_pic_cnt == 0 && img->type != I_SLICE)
{
for(i=0;i<img->num_ref_idx_l0_active;i++)
{
if(ref_flag[i] == 0) // any reference of primary slice is incorrect
{
Is_primary_correct = 0; // primary slice is incorrect
}
}
}
else if(img->redundant_pic_cnt != 0 && img->type != I_SLICE)
{
if(ref_flag[redundant_slice_ref_idx] == 0) // reference of redundant slice is incorrect
{
Is_redundant_correct = 0; // redundant slice is incorrect
}
}
}
/*!
***********************************************************************
* \brief
* decodes one I- or P-frame
*
***********************************************************************
*/
int decode_one_frame(ImageParameters *img, struct inp_par *inp, struct snr_par *snr)
{
int current_header;
Slice *currSlice = img->currentSlice;
int i;
img->current_slice_nr = 0;
img->current_mb_nr = -4711; // initialized to an impossible value for debugging -- correct value is taken from slice header
currSlice->next_header = -8888; // initialized to an impossible value for debugging -- correct value is taken from slice header
img->num_dec_mb = 0;
img->newframe = 1;
while ((currSlice->next_header != EOS && currSlice->next_header != SOP))
{
current_header = read_new_slice(img->currentSlice);
// error tracking of primary and redundant slices.
Error_tracking();
// If primary and redundant are received and primary is correct, discard the redundant
// else, primary slice will be replaced with redundant slice.
if(img->frame_num == previous_frame_num && img->redundant_pic_cnt !=0
&& Is_primary_correct !=0 && current_header != EOS)
{
continue;
}
// update reference flags and set current ref_flag
if(!(img->redundant_pic_cnt != 0 && previous_frame_num == img->frame_num))
{
for(i=16;i>0;i--)
{
ref_flag[i] = ref_flag[i-1];
}
}
ref_flag[0] = img->redundant_pic_cnt==0 ? Is_primary_correct : Is_redundant_correct;
previous_frame_num = img->frame_num;
if (current_header == EOS)
{
exit_picture(&dec_picture);
return EOS;
}
decode_slice(img, currSlice, inp, current_header);
img->newframe = 0;
img->current_slice_nr++;
}
exit_picture(&dec_picture);
return (SOP);
}
/*!
************************************************************************
* \brief
* Convert file read buffer to source picture structure
* \param imgX
* Pointer to image plane
* \param buf
* Buffer for file output
* \param size_x
* horizontal image size in pixel
* \param size_y
* vertical image size in pixel
* \param symbol_size_in_bytes
* number of bytes used per pel
************************************************************************
*/
void buf2img (imgpel** imgX, unsigned char* buf, int size_x, int size_y, int symbol_size_in_bytes)
{
int i,j;
unsigned short tmp16, ui16;
unsigned long tmp32, ui32;
if (symbol_size_in_bytes> sizeof(imgpel))
{
error ("Source picture has higher bit depth than imgpel data type. \nPlease recompile with larger data type for imgpel.", 500);
}
if (( sizeof(char) == sizeof (imgpel)) && ( sizeof(char) == symbol_size_in_bytes))
{
// imgpel == pixel_in_file == 1 byte -> simple copy
memcpy(&imgX[0][0], buf, size_x * size_y);
//for(j=0;j<size_y;j++)
//memcpy(&imgX[j][0], buf+j*size_x, size_x);
}
else
{
// sizeof (imgpel) > sizeof(char)
if (testEndian())
{
// big endian
switch (symbol_size_in_bytes)
{
case 1:
{
for(j=0;j<size_y;j++)
for(i=0;i<size_x;i++)
{
imgX[j][i]= buf[i+j*size_x];
}
break;
}
case 2:
{
for(j=0;j<size_y;j++)
for(i=0;i<size_x;i++)
{
memcpy(&tmp16, buf+((i+j*size_x)*2), 2);
ui16 = (unsigned short) ((tmp16 >> 8) | ((tmp16&0xFF)<<8));
imgX[j][i] = (imgpel) ui16;
}
break;
}
case 4:
{
for(j=0;j<size_y;j++)
for(i=0;i<size_x;i++)
{
memcpy(&tmp32, buf+((i+j*size_x)*4), 4);
ui32 = ((tmp32&0xFF00)<<8) | ((tmp32&0xFF)<<24) | ((tmp32&0xFF0000)>>8) | ((tmp32&0xFF000000)>>24);
imgX[j][i] = (imgpel) ui32;
}
}
default:
{
error ("reading only from formats of 8, 16 or 32 bit allowed on big endian architecture", 500);
break;
}
}
}
else
{
// little endian
if (symbol_size_in_bytes == 1)
{
for (j=0; j < size_y; j++)
{
for (i=0; i < size_x; i++)
{
imgX[j][i]=*(buf++);
}
}
}
else
{
for (j=0; j < size_y; j++)
{
int jpos = j*size_x;
for (i=0; i < size_x; i++)
{
imgX[j][i]=0;
memcpy(&(imgX[j][i]), buf +((i+jpos)*symbol_size_in_bytes), symbol_size_in_bytes);
}
}
}
}
}
}
/*!
************************************************************************
* \brief
* Calculate the value of frame_no
************************************************************************
*/
void calculate_frame_no(StorablePicture *p)
{
// calculate frame number
int psnrPOC = active_sps->mb_adaptive_frame_field_flag ? p->poc /(params->poc_scale) : p->poc/(params->poc_scale);
if (psnrPOC==0)// && img->psnr_number)
img->idr_psnr_number = img->number*img->ref_poc_gap/(params->poc_scale);
img->psnr_number=imax(img->psnr_number,img->idr_psnr_number+psnrPOC);
frame_no = img->idr_psnr_number + psnrPOC;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -