📄 lencod.c
字号:
img->delta_pic_order_cnt_bottom = 1;
}
}
/*!
***********************************************************************
* \brief
* Pushes values onto the POC ref arrays toprefpoc[] & bottomrefpoc[]
*
***********************************************************************
*/
void push_poc(unsigned int topvalue, unsigned int bottomvalue, unsigned int ref_frame_ind )
{
int i;
static int current_is_ref = 0; //indicates if current top value is for a ref frame
if(current_is_ref){
for(i=MAX_NO_POC_FRAMES-1; i>0; i--){ //move all the data down by one
toprefpoc[i] = toprefpoc[i-1] ;
bottomrefpoc[i] = bottomrefpoc[i-1] ;
}
}
toprefpoc[0] = topvalue; //put new data
bottomrefpoc[0] = bottomvalue;
current_is_ref = ref_frame_ind; //new data type
}
/*!
***********************************************************************
* \brief
* Initializes the img->nz_coeff
* \par Input:
* none
* \par Output:
* none
* \ side effects
* sets omg->nz_coef[][][][] to -1
***********************************************************************
*/
void CAVLC_init()
{
unsigned int i, k, l;
for (i=0;i < img->PicSizeInMbs; i++)
for (k=0;k<4;k++)
for (l=0;l<6;l++)
img->nz_coeff[i][k][l]=-1;
}
/*!
***********************************************************************
* \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,j;
img->num_reference_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_reference_frames;
img->DeblockCall = 0;
// img->framerate=INIT_FRAME_RATE; // The basic frame rate (of the original sequence)
img->framerate=input->PictureRate; // The basic frame rate (of the original sequence)
get_mem_mv (&(img->pred_mv));
get_mem_mv (&(img->all_mv));
get_mem_ACcoeff (&(img->cofAC));
get_mem_DCcoeff (&(img->cofDC));
if(input->MbInterlace)
{
get_mem_mv (&(rddata_top_frame_mb.pred_mv));
get_mem_mv (&(rddata_top_frame_mb.all_mv));
get_mem_mv (&(rddata_bot_frame_mb.pred_mv));
get_mem_mv (&(rddata_bot_frame_mb.all_mv));
get_mem_mv (&(rddata_top_field_mb.pred_mv));
get_mem_mv (&(rddata_top_field_mb.all_mv));
get_mem_mv (&(rddata_bot_field_mb.pred_mv));
get_mem_mv (&(rddata_bot_field_mb.all_mv));
get_mem_ACcoeff (&(rddata_top_frame_mb.cofAC));
get_mem_DCcoeff (&(rddata_top_frame_mb.cofDC));
get_mem_ACcoeff (&(rddata_bot_frame_mb.cofAC));
get_mem_DCcoeff (&(rddata_bot_frame_mb.cofDC));
get_mem_ACcoeff (&(rddata_top_field_mb.cofAC));
get_mem_DCcoeff (&(rddata_top_field_mb.cofDC));
get_mem_ACcoeff (&(rddata_bot_field_mb.cofAC));
get_mem_DCcoeff (&(rddata_bot_field_mb.cofDC));
}
if ((img->quad = (int*)calloc (511, sizeof(int))) == NULL)
no_mem_exit ("init_img: img->quad");
img->quad+=255;
for (i=0; i < 256; ++i)
{
img->quad[i]=img->quad[-i]=i*i;
}
img->width = input->img_width;
img->height = input->img_height;
img->width_cr = input->img_width/2;
img->height_cr= input->img_height/2;
img->PicWidthInMbs = input->img_width/MB_BLOCK_SIZE;
img->FrameHeightInMbs = input->img_height/MB_BLOCK_SIZE;
img->FrameSizeInMbs = img->PicWidthInMbs * img->FrameHeightInMbs;
img->PicHeightInMapUnits = ( active_sps->frame_mbs_only_flag ? img->FrameHeightInMbs : img->FrameHeightInMbs/2 );
if(((img->mb_data) = (Macroblock *) calloc(img->FrameSizeInMbs,sizeof(Macroblock))) == NULL)
no_mem_exit("init_img: img->mb_data");
if(input->UseConstrainedIntraPred)
{
if(((img->intra_block) = (int*)calloc(img->FrameSizeInMbs,sizeof(int))) == NULL)
no_mem_exit("init_img: img->intra_block");
}
get_mem2Dint(&(img->ipredmode), img->width/BLOCK_SIZE, img->height/BLOCK_SIZE); //need two extra rows at right and bottom
if(input->MbInterlace)
{
get_mem2Dint(&(rddata_top_frame_mb.ipredmode), img->width/BLOCK_SIZE, img->height/BLOCK_SIZE);
get_mem2Dint(&(rddata_bot_frame_mb.ipredmode), img->width/BLOCK_SIZE, img->height/BLOCK_SIZE);
get_mem2Dint(&(rddata_top_field_mb.ipredmode), img->width/BLOCK_SIZE, img->height/BLOCK_SIZE);
get_mem2Dint(&(rddata_bot_field_mb.ipredmode), img->width/BLOCK_SIZE, img->height/BLOCK_SIZE);
}
// CAVLC mem
get_mem3Dint(&(img->nz_coeff), img->FrameSizeInMbs, 4, 6);
CAVLC_init();
for (i=0; i < img->width/BLOCK_SIZE; i++)
for (j=0; j < img->height/BLOCK_SIZE; j++)
{
img->ipredmode[i][j]=-1;
}
img->mb_y_upd=0;
RandomIntraInit (img->width/16, img->height/16, input->RandomIntraMBRefresh);
FmoInit (img->width/16, img->height/16, input->num_slice_groups_minus1, input->FmoType, NULL);
InitSEIMessages(); // Tian Dong (Sept 2002)
// Initialize filtering parameters. If sending parameters, the offsets are
// multiplied by 2 since inputs are taken in "div 2" format.
// If not sending paramters, all fields are cleared
if (input->LFSendParameters)
{
input->LFAlphaC0Offset <<= 1;
input->LFBetaOffset <<= 1;
}
else
{
input->LFDisableIdc = 0;
input->LFAlphaC0Offset = 0;
input->LFBetaOffset = 0;
}
}
/*!
***********************************************************************
* \brief
* Free the Image structures
* \par Input:
* Image Parameters struct img_par *img
***********************************************************************
*/
void free_img ()
{
CloseSEIMessages(); // Tian Dong (Sept 2002)
free_mem_mv (img->pred_mv);
free_mem_mv (img->all_mv);
free_mem_ACcoeff (img->cofAC);
free_mem_DCcoeff (img->cofDC);
free (img->quad-255);
}
/*!
************************************************************************
* \brief
* Allocates the picture structure along with its dependent
* data structures
* \return
* Pointer to a Picture
************************************************************************
*/
Picture *malloc_picture()
{
Picture *pic;
if ((pic = calloc (1, sizeof (Picture))) == NULL) no_mem_exit ("malloc_picture: Picture structure");
//! Note: slice structures are allocated as needed in code_a_picture
return pic;
}
/*!
************************************************************************
* \brief
* Frees a picture
* \param
* pic: POinter to a Picture to be freed
************************************************************************
*/
void free_picture(Picture *pic)
{
if (pic != NULL)
{
free_slice_list(pic);
free (pic);
}
}
/*!
************************************************************************
* \brief
* Reports the gathered information to appropriate outputs
* \par Input:
* struct inp_par *inp, \n
* struct img_par *img, \n
* struct stat_par *stat, \n
* struct stat_par *stat \n
*
* \par Output:
* None
************************************************************************
*/
void report()
{
int bit_use[NUM_PIC_TYPE][2] ;
int i,j;
char name[20];
int total_bits;
float frame_rate;
float mean_motion_info_bit_use[2];
#ifndef WIN32
time_t now;
struct tm *l_time;
char string[1000];
#else
char timebuf[128];
#endif
bit_use[I_SLICE][0] = 1;
bit_use[P_SLICE][0] = max(1,input->no_frames-1);
bit_use[B_SLICE][0] = Bframe_ctr;
// Accumulate bit usage for inter and intra frames
for (j=0;j<NUM_PIC_TYPE;j++)
{
bit_use[j][1] = 0;
}
for (j=0;j<NUM_PIC_TYPE;j++)
{
for(i=0; i<MAXMODE; i++)
bit_use[j][1] += stat->bit_use_mode [j][i];
bit_use[j][1]+=stat->bit_use_header [j];
bit_use[j][1]+=stat->bit_use_mb_type [j];
bit_use[j][1]+=stat->tmp_bit_use_cbp [j];
bit_use[j][1]+=stat->bit_use_coeffY [j];
bit_use[j][1]+=stat->bit_use_coeffC [j];
bit_use[j][1]+=stat->bit_use_delta_quant [j];
bit_use[j][1]+=stat->bit_use_stuffingBits[j];
}
// B pictures
if(Bframe_ctr!=0)
{
frame_rate = (float)(img->framerate *(input->successive_Bframe + 1)) / (float) (input->jumpd+1);
stat->bitrate_P=(stat->bit_ctr_0+stat->bit_ctr_P)*(float)(frame_rate)/(float) (input->no_frames + Bframe_ctr);
#ifdef _ADAPT_LAST_GROUP_
stat->bitrate_B=(stat->bit_ctr_B)*(float)(frame_rate)/(float) (input->no_frames + Bframe_ctr);
#else
stat->bitrate_B=(stat->bit_ctr_B)*(float)(frame_rate)/(float) (input->no_frames + Bframe_ctr);
#endif
}
else
{
if (input->no_frames > 1)
{
stat->bitrate=(bit_use[I_SLICE][1]+bit_use[P_SLICE][1])*(float)img->framerate/(input->no_frames*(input->jumpd+1));
}
}
fprintf(stdout,"--------------------------------------------------------------------------\n");
fprintf(stdout, " Freq. for encoded bitstream : %1.0f\n",(float)img->framerate/(float)(input->jumpd+1));
if(input->hadamard)
fprintf(stdout," Hadamard transform : Used\n");
else
fprintf(stdout," Hadamard transform : Not used\n");
fprintf(stdout," Image format : %dx%d\n",input->img_width,input->img_height);
if(input->intra_upd)
fprintf(stdout," Error robustness : On\n");
else
fprintf(stdout," Error robustness : Off\n");
fprintf(stdout, " Search range : %d\n",input->search_range);
fprintf(stdout, " No of ref. frames used in P pred : %d\n",input->num_reference_frames);
if(input->successive_Bframe != 0)
fprintf(stdout, " No of ref. frames used in B pred : %d\n",input->num_reference_frames);
fprintf(stdout, " Total encoding time for the seq. : %.3f sec \n",tot_time*0.001);
// B pictures
fprintf(stdout, " Sequence type :" );
if(input->successive_Bframe==0 && input->StoredBPictures > 0)
fprintf(stdout, " I-P-BS-BS (QP: I %d, P BS %d) \n",input->qp0, input->qpN);
else if(input->successive_Bframe==1 && input->StoredBPictures > 0)
fprintf(stdout, " I-B-P-BS-B-BS (QP: I %d, P BS %d, B %d) \n",input->qp0, input->qpN, input->qpB);
else if(input->successive_Bframe==2 && input->StoredBPictures > 0)
fprintf(stdout, " I-B-B-P-B-B-BS (QP: I %d, P BS %d, B %d) \n",input->qp0, input->qpN, input->qpB);
else if(input->successive_Bframe==1) fprintf(stdout, " IBPBP (QP: I %d, P %d, B %d) \n",
input->qp0, input->qpN, input->qpB);
else if(input->successive_Bframe==2) fprintf(stdout, " IBBPBBP (QP: I %d, P %d, B %d) \n",
input->qp0, input->qpN, input->qpB);
else if(input->successive_Bframe==0 && input->sp_periodicity==0) fprintf(stdout, " IPPP (QP: I %d, P %d) \n", input->qp0, input->qpN);
else fprintf(stdout, " I-P-P-SP-P (QP: I %d, P %d, SP (%d, %d)) \n", input->qp0, input->qpN, input->qpsp, input->qpsp_pred);
// report on entropy coding method
if (input->symbol_mode == UVLC)
fprintf(stdout," Entropy coding method : CAVLC\n");
else
fprintf(stdout," Entropy coding method : CABAC\n");
#ifdef _FULL_SEARCH_RANGE_
if (input->full_search == 2)
fprintf(stdout," Search range restrictions : none\n");
else if (input->full_search == 1)
fprintf(stdout," Search range restrictions : older reference frames\n");
else
fprintf(stdout," Search range restrictions : smaller blocks and older reference frames\n");
#endif
if (input->rdopt)
fprintf(stdout," RD-optimized mode decision : used\n");
else
fprintf(stdout," RD-optimized mode decision : not used\n");
switch(input->partition_mode)
{
case PAR_DP_1:
fprintf(stdout," Data Partitioning Mode : 1 partition \n");
break;
case PAR_DP_3:
fprintf(stdout," Data Partitioning Mode : 3 partitions \n");
break;
default:
fprintf(stdout," Data Partitioning Mode : not supported\n");
break;
}
switch(input->of_mode)
{
case PAR_OF_ANNEXB:
fprintf(stdout," Output File Format : H.26L Bit Stream File Format \n");
break;
case PAR_OF_RTP:
fprintf(stdout," Output File Format : RTP Packet File Format \n");
break;
default:
fprintf(stdout," Output File Format : not supported\n");
break;
}
fprintf(stdout,"------------------ Average data all frames ------------------------------\n");
fprintf(stdout," SNR Y(dB) : %5.2f\n",snr->snr_ya);
fprintf(stdout," SNR U(dB) : %5.2f\n",snr->snr_ua);
fprintf(stdout," SNR V(dB) : %5.2f\n",snr->snr_va);
if(Bframe_ctr!=0)
{
fprintf(stdout, " Total bits : %d (I %5d, P %5d, B %d) \n",
total_bits=stat->bit_ctr_P + stat->bit_ctr_0 + stat->bit_ctr_B, stat->bit_ctr_0, stat->bit_ctr_P, stat->bit_ctr_B);
frame_rate = (float)(img->framerate *(input->successive_Bframe + 1)) / (float) (input->jumpd+1);
stat->bitrate= ((float) total_bits * frame_rate)/((float) (input->no_frames + Bframe_ctr));
fprintf(stdout, " Bit rate (kbit/s) @ %2.2f Hz : %5.2f\n", frame_rate, stat->bitrate/1000);
}
else if (input->sp_periodicity==0)
{
fprintf(stdout, " Total bits : %d (I %5d, P %5d) \n",
total_bits=stat->bit_ctr_P + stat->bit_ctr_0 , stat->bit_ctr_0, stat->bit_ctr_P);
frame_rate = (float)img->framerate / ( (float) (input->jumpd + 1) );
stat->bitrate= ((float) total_bits * frame_rate)/((float) input->no_frames );
fprintf(stdout, " Bit rate (kbit/s) @ %2.2f Hz : %5.2f\n", frame_rate, stat->bitrate/1000);
}else
{
fprintf(stdout, " Total bits : %d (I %5d, P %5d) \n",
total_bits=stat->bit_ctr_P + stat->bit_ctr_0 , stat->bit_ctr_0, stat->bit_ctr_P);
frame_rate = (float)img->framerate / ( (float) (input->jumpd + 1) );
stat->bitrate= ((float) total_bits * frame_rate)/((float) input->no_frames );
fprintf(stdout, " Bit rate (kbit/s) @ %2.2f Hz : %5.2f\n", frame_rate, stat->bitrate/1000);
}
fprintf(stdout, " Bits to avoid Startcode Emulation : %d \n", stat->bit_ctr_emulationprevention);
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -