📄 lencod.c
字号:
img->last_ref_idc = img->nal_reference_idc ? 1 : 0;
// if key frame is encoded, encode one redundant frame
if (input->redundant_pic_flag && key_frame)
{
encode_one_redundant_frame();
}
if (img->type == I_SLICE && input->EnableOpenGOP)
img->last_valid_reference = img->ThisPOC;
if (input->ReportFrameStats)
report_frame_statistic();
if (img->nal_reference_idc == 0)
{
primary_disp ++;
//img->frame_num -= 1;
//img->frame_num %= max_frame_num;
}
if (img->currentPicture->idr_flag)
{
img->idr_gop_number = 0;
//start_frame_no_in_this_IGOP = img->frm_number;
//start_tr_in_this_IGOP = img->toppoc;
// start_tr_in_this_IGOP = (img->frm_number - 1 ) * (input->jumpd + 1) +1;
}
else
img->idr_gop_number ++;
encode_enhancement_layer();
}
// terminate sequence
terminate_sequence();
flush_dpb();
close(p_in);
if (-1 != p_dec)
close(p_dec);
if (p_trace)
fclose(p_trace);
Clear_Motion_Search_Module ();
RandomIntraUninit();
FmoUninit();
if (input->HierarchicalCoding)
clear_gop_structure ();
// free structure for rd-opt. mode decision
clear_rdopt ();
#ifdef _LEAKYBUCKET_
calc_buffer();
#endif
// report everything
report();
#ifdef _LEAKYBUCKET_
if (Bit_Buffer)
free(Bit_Buffer);
#endif
free_dpb();
if( IS_INDEPENDENT(input) )
{
for( nplane=0; nplane<MAX_PLANE; nplane++ )
{
free_colocated(Co_located_JV[nplane]);
}
}
else
{
free_colocated(Co_located);
}
uninit_out_buffer();
free_global_buffers();
// free image mem
free_img ();
free_context_memory ();
FreeNalPayloadBuffer();
FreeParameterSets();
return 0;
}
/*!
***********************************************************************
* \brief
* Terminates and reports statistics on error.
*
***********************************************************************
*/
void report_stats_on_error(void)
{
int nplane;
input->no_frames = img->frm_number;
terminate_sequence();
flush_dpb();
close(p_in);
if (-1 != p_dec)
close(p_dec);
if (p_trace)
fclose(p_trace);
Clear_Motion_Search_Module ();
RandomIntraUninit();
FmoUninit();
if (input->HierarchicalCoding)
clear_gop_structure ();
// free structure for rd-opt. mode decision
clear_rdopt ();
#ifdef _LEAKYBUCKET_
calc_buffer();
#endif
if (input->ReportFrameStats)
report_frame_statistic();
// report everything
report();
free_dpb();
if( IS_INDEPENDENT(input) )
{
for( nplane=0; nplane<MAX_PLANE; nplane++ )
{
free_colocated(Co_located_JV[nplane]);
}
}
else
{
free_colocated(Co_located);
}
uninit_out_buffer();
free_global_buffers();
// free image mem
free_img ();
free_context_memory ();
FreeNalPayloadBuffer();
FreeParameterSets();
exit (-1);
}
/*!
***********************************************************************
* \brief
* Initializes the POC structure with appropriate parameters.
*
***********************************************************************
*/
void init_poc()
{
//the following should probably go in sequence parameters
// frame poc's increase by 2, field poc's by 1
img->pic_order_cnt_type=input->pic_order_cnt_type;
img->delta_pic_order_always_zero_flag = FALSE;
img->num_ref_frames_in_pic_order_cnt_cycle= 1;
if (input->BRefPictures == 1)
{
img->offset_for_non_ref_pic = 0;
img->offset_for_ref_frame[0] = 2;
}
else
{
img->offset_for_non_ref_pic = -2*(input->successive_Bframe);
img->offset_for_ref_frame[0] = 2*(input->successive_Bframe+1);
}
if ((input->PicInterlace==FRAME_CODING) && (input->MbInterlace==FRAME_CODING))
img->offset_for_top_to_bottom_field=0;
else
img->offset_for_top_to_bottom_field=1;
if ((input->PicInterlace==FRAME_CODING) && (input->MbInterlace==FRAME_CODING))
{
img->pic_order_present_flag = FALSE;
img->delta_pic_order_cnt_bottom = 0;
}
else
{
img->pic_order_present_flag = TRUE;
img->delta_pic_order_cnt_bottom = 1;
}
}
/*!
***********************************************************************
* \brief
* Initializes the img->nz_coeff
* \par Input:
* none
* \par Output:
* none
* \ side effects
* sets omg->nz_coef[][][][] to -1
***********************************************************************
*/
void CAVLC_init(void)
{
unsigned int i, k, l;
for (i = 0; i < img->PicSizeInMbs; i++)
for (k = 0; k < 4; k++)
for (l = 0; l < (4 + (unsigned int)img->num_blk8x8_uv); l++)
img->nz_coeff[i][k][l] = 0;
}
/*!
***********************************************************************
* \brief
* Initializes the Image structure with appropriate parameters.
* \par Input:
* Input Parameters struct inp_par *inp
* \par Output:
* Image Parameters struct img_par *img
***********************************************************************
*/
void init_img()
{
int i;
int byte_abs_range;
static int mb_width_cr[4] = {0,8, 8,16};
static int mb_height_cr[4]= {0,8,16,16};
// Color format
img->yuv_format = input->yuv_format;
//pel bitdepth init
img->bitdepth_luma = input->BitDepthLuma;
img->bitdepth_scale[0] = 1 << (img->bitdepth_luma - 8);
img->bitdepth_lambda_scale = 2 * (img->bitdepth_luma - 8);
img->bitdepth_luma_qp_scale = 3 * img->bitdepth_lambda_scale;
img->dc_pred_value_luma = 1<<(img->bitdepth_luma - 1);
img->max_imgpel_value = (1<<img->bitdepth_luma) - 1;
img->mb_size[0][0] = img->mb_size[0][1] = MB_BLOCK_SIZE;
if (img->yuv_format != YUV400)
{
img->bitdepth_chroma = input->BitDepthChroma;
img->bitdepth_scale[1] = 1 << (img->bitdepth_chroma - 8);
img->dc_pred_value_chroma = 1<<(img->bitdepth_chroma - 1);
img->max_imgpel_value_uv = (1<<img->bitdepth_chroma) - 1;
img->num_blk8x8_uv = (1<<img->yuv_format)&(~(0x1));
img->num_cdc_coeff = img->num_blk8x8_uv<<1;
img->mb_size[1][0] = img->mb_size[2][0] = img->mb_cr_size_x = (img->yuv_format == YUV420 || img->yuv_format == YUV422) ? 8 : 16;
img->mb_size[1][1] = img->mb_size[2][1] = img->mb_cr_size_y = (img->yuv_format == YUV444 || img->yuv_format == YUV422) ? 16 : 8;
img->bitdepth_chroma_qp_scale = 6*(img->bitdepth_chroma - 8);
img->chroma_qp_offset[0] = active_pps->cb_qp_index_offset;
img->chroma_qp_offset[1] = active_pps->cr_qp_index_offset;
}
else
{
img->bitdepth_chroma = 0;
img->bitdepth_scale[1] = 0;
img->max_imgpel_value_uv = 0;
img->num_blk8x8_uv = 0;
img->num_cdc_coeff = 0;
img->mb_size[1][0] = img->mb_size[2][0] = img->mb_cr_size_x = 0;
img->mb_size[1][1] = img->mb_size[2][1] = img->mb_cr_size_y = 0;
img->bitdepth_chroma_qp_scale = 0;
img->bitdepth_chroma_qp_scale = 0;
img->chroma_qp_offset[0] = 0;
img->chroma_qp_offset[1] = 0;
}
if ((img->bitdepth_luma > img->bitdepth_chroma) || (img->yuv_format == YUV400))
img->pic_unit_size_on_disk = (img->bitdepth_luma > 8)? 16:8;
else
img->pic_unit_size_on_disk = (img->bitdepth_chroma > 8)? 16:8;
img->max_bitCount = 128 + 256 * img->bitdepth_luma + 2 * img->mb_cr_size_y * img->mb_cr_size_x * img->bitdepth_chroma;
img->max_qp_delta = (25 + (img->bitdepth_luma_qp_scale>>1));
img->min_qp_delta = img->max_qp_delta + 1;
img->num_ref_frames = active_sps->num_ref_frames;
img->max_num_references = active_sps->frame_mbs_only_flag ? active_sps->num_ref_frames : 2 * active_sps->num_ref_frames;
img->buf_cycle = input->num_ref_frames;
img->base_dist = input->jumpd;
// Intra/IDR related parameters
img->lastIntraNumber = 0;
img->lastINTRA = 0;
img->lastIDR = 0;
img->lastIDRnumber = 0;
img->last_ref_idc = 0;
img->idr_refresh = 0;
img->idr_gop_number = 0;
img->rewind_frame = 0;
img->DeblockCall = 0;
img->framerate = (float) input->FrameRate; // The basic frame rate (of the original sequence)
// Allocate proper memory space for different parameters (i.e. MVs, coefficients, etc)
get_mem_mv (&(img->pred_mv));
get_mem_mv (&(img->all_mv));
if (input->BiPredMotionEstimation)
{
get_mem_mv (&(img->bipred_mv1));
get_mem_mv (&(img->bipred_mv2));
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -