📄 global.h
字号:
{
int qp;
int slice_nr;
int delta_quant; //!< for rate control
struct macroblock *mb_available[3][3]; /*!< pointer to neighboring MBs in a 3x3 window of current MB, which is located at [1][1]
NULL pointer identifies neighboring MBs which are unavailable */
// some storage of macroblock syntax elements for global access
int mb_type;
int mvd[2][BLOCK_MULTIPLE][BLOCK_MULTIPLE][2]; //!< indices correspond to [forw,backw][block_y][block_x][x,y]
int intra_pred_modes[BLOCK_MULTIPLE*BLOCK_MULTIPLE];
int coeffs_count[BLOCK_MULTIPLE][BLOCK_MULTIPLE];
int cbp, cbp_blk ;
int i16mode;
int b8mode[4];
int b8pdir[4];
int ei_flag;
} Macroblock;
//! Bitstream
typedef struct
{
// CABAC Decoding
int read_len; //!< actual position in the codebuffer, CABAC only
int code_len; //!< overall codebuffer length, CABAC only
// UVLC Decoding
int frame_bitoffset; //!< actual position in the codebuffer, bit-oriented, UVLC only
int bitstream_length; //!< over codebuffer lnegth, byte oriented, UVLC only
// ErrorConcealment
byte *streamBuffer; //!< actual codebuffer for read bytes
int ei_flag; //!< error indication, 0: no error, else unspecified error
} Bitstream;
//! DataPartition
typedef struct datapartition
{
Bitstream *bitstream;
DecodingEnvironment de_cabac;
int (*readSyntaxElement)(SyntaxElement *, struct img_par *, struct inp_par *, struct datapartition *);
/*!< virtual function;
actual method depends on chosen data partition and
entropy coding method */
} DataPartition;
//! Slice
typedef struct
{
int ei_flag; //!< 0 if the partArr[0] contains valid information
int picture_id; //!< MUST be set by NAL even in case ei_flag == 1
int qp;
int picture_type; //!< picture type
int start_mb_nr; //!< MUST be set by NAL even in case of ei_flag == 1
int max_part_nr;
int dp_mode; //!< data partioning mode
int eos_flag; //!< end of sequence flag
int next_header;
int next_eiflag;
int last_mb_nr; //!< only valid when entropy coding == CABAC
DataPartition *partArr; //!< array of partitions
MotionInfoContexts *mot_ctx; //!< pointer to struct of context models for use in CABAC
TextureInfoContexts *tex_ctx; //!< pointer to struct of context models for use in CABAC
RMPNIbuffer_t *rmpni_buffer; //!< stores the slice temporary buffer remapping commands
int (*readSlice)(struct img_par *, struct inp_par *);
} Slice;
//****************************** ~DM ***********************************
// image parameters
typedef struct img_par
{
int number; //<! frame number
int pn; //<! short term picture number
int current_mb_nr;
int max_mb_nr;
int current_slice_nr;
int **intra_block;
int tr; //<! temporal reference, 8 bit, wrapps at 255
int tr_old; //<! old temporal reference, for detection of a new frame, added by WYK
int refPicID; //<! temporal reference for reference frames (non-B frames), 4 bit, wrapps at 15, added by WYK
int refPicID_old; //<! to detect how many reference frames are lost, added by WYK
int qp; //<! quant for the current frame
int qpsp; //<! quant for SP-picture predicted frame
int type; //<! image type INTER/INTRA
int width;
int height;
int width_cr; //<! width chroma
int height_cr; //<! height chroma
int mb_y;
int mb_x;
int block_y;
int pix_y;
int pix_x;
int pix_c_y;
int block_x;
int pix_c_x;
int allrefzero;
int ***mv; //<! [92][72][3]
int mpr[16][16]; //<! predicted block
int m7[4][4]; //<! final 4x4 block
int cof[4][6][4][4]; //<! correction coefficients from predicted
int cofu[4];
int **ipredmode; //<! prediction type [90][74]
int quad[256];
int UseConstrainedIntraPred;
int cod_counter; //<! Current count of number of skipped macroblocks in a row
int ***dfMV; //<! [92][72][3];
int ***dbMV; //<! [92][72][3];
int **fw_refFrArr; //<! [72][88];
int **bw_refFrArr; //<! [72][88];
// B pictures
int ***fw_mv; //<! [92][72][3];
int ***bw_mv; //<! [92][72][3];
Slice *currentSlice; //<! pointer to current Slice data struct
Macroblock *mb_data; //<! array containing all MBs of a whole frame
int subblock_x;
int subblock_y;
int mv_res;
int buf_cycle;
MMCObuffer_t *mmco_buffer; //<! stores the memory management control operations
} ImageParameters;
// signal to noice ratio parameters
struct snr_par
{
float snr_y; //<! current Y SNR
float snr_u; //<! current U SNR
float snr_v; //<! current V SNR
float snr_y1; //<! SNR Y(dB) first frame
float snr_u1; //<! SNR U(dB) first frame
float snr_v1; //<! SNR V(dB) first frame
float snr_ya; //<! Average SNR Y(dB) remaining frames
float snr_ua; //<! Average SNR U(dB) remaining frames
float snr_va; //<! Average SNR V(dB) remaining frames
};
int tot_time;
// input parameters from configuration file
struct inp_par
{
char infile[100]; //<! Telenor H.26L input
char outfile[100]; //<! Decoded YUV 4:2:0 output
char reffile[100]; //<! Optional YUV 4:2:0 reference file for SNR measurement
int postfilter; //<! postfilter (0=OFF,1=ON)
int symbol_mode; //<! Specifies the mode the symbols are mapped on bits
int UseConstrainedIntraPred; //<! 0: Inter MB pixels are allowed for intra prediction 1: Not allowed
int of_mode; //<! Specifies the mode of the output file
int partition_mode; //<! Specifies the mode of data partitioning
int buf_cycle; //<! Frame buffer size
#ifdef _LEAKYBUCKET_
unsigned long R_decoder; //<! Decoder Rate in HRD Model
unsigned long B_decoder; //<! Decoder Buffer size in HRD model
unsigned long F_decoder; //<! Decoder Inital buffer fullness in HRD model
char LeakyBucketParamFile[100]; //<! LeakyBucketParamFile
#endif
};
// files
FILE *p_out; //<! pointer to output YUV file
FILE *p_ref; //<! pointer to input original reference YUV file file
FILE *p_log; //<! SNR file
FILE *p_datpart; //<! file to write bitlength and id of all partitions
#if TRACE
FILE *p_trace;
#endif
// prototypes
void init_conf(struct inp_par *inp, char *config_filename);
void report(struct inp_par *inp, struct img_par *img, struct snr_par *snr);
void find_snr(struct snr_par *snr,struct img_par *img, FILE *p_ref, int postfilter);
void init(struct img_par *img);
void malloc_slice(struct inp_par *inp, struct img_par *img);
void free_slice(struct inp_par *inp, struct img_par *img);
int decode_one_frame(struct img_par *img,struct inp_par *inp, struct snr_par *snr);
void init_frame(struct img_par *img, struct inp_par *inp);
void exit_frame(struct img_par *img, struct inp_par *inp);
void DeblockFrame(struct img_par *img, byte **imgY, byte ***imgUV ) ;
void write_frame(struct img_par *img,int,FILE *p_out);
void write_prev_Pframe(struct img_par *img,FILE *p_out);// B pictures
void copy_Pframe(struct img_par *img,int);// B pictures
int read_new_slice(struct img_par *img, struct inp_par *inp);
void decode_one_slice(struct img_par *img,struct inp_par *inp);
void start_macroblock(struct img_par *img,struct inp_par *inp);
void init_macroblock_Bframe(struct img_par *img);// B pictures
int read_one_macroblock(struct img_par *img,struct inp_par *inp);
int read_one_macroblock_Bframe(struct img_par *img,struct inp_par *inp);// B pictures
int decode_one_macroblock(struct img_par *img,struct inp_par *inp);
int decode_one_macroblock_Bframe(struct img_par *img);// B pictures
void decode_one_CopyMB(struct img_par *img,struct inp_par *inp);
int exit_macroblock(struct img_par *img,struct inp_par *inp);
void readMotionInfoFromNAL (struct img_par *img,struct inp_par *inp);
void readMotionInfoFromNAL_Bframe(struct img_par *img,struct inp_par *inp);// B pictures
void readMotionInfoFromNAL_Pframe(struct img_par *img,struct inp_par *inp);
void readCBPandCoeffsFromNAL(struct img_par *img,struct inp_par *inp);
void copyblock_sp(struct img_par *img,int block_x,int block_y);
void itrans_sp_chroma(struct img_par *img,int ll);
void itrans(struct img_par *img,int ioff,int joff,int i0,int j0);
void itrans_sp(struct img_par *img,int ioff,int joff,int i0,int j0);
int intrapred(struct img_par *img,int ioff,int joff,int i4,int j4);
void itrans_2(struct img_par *img);
int intrapred_luma_2(struct img_par *img,int predmode);
int sign(int a , int b);
// UVLC mapping
void linfo(int len, int info, int *value1, int *dummy);
void linfo_mvd(int len,int info, int *signed_mvd, int *dummy);
void linfo_cbp_intra(int len,int info,int *cbp, int *dummy);
void linfo_cbp_inter(int len,int info,int *cbp, int *dummy);
void linfo_dquant(int len, int info, int *signed_dquant, int *dummy);
void linfo_levrun_inter(int len,int info,int *level,int *irun);
void linfo_levrun_intra(int len,int info,int *level,int *irun);
void linfo_levrun_c2x2(int len,int info,int *level,int *irun);
int readSyntaxElement_UVLC(SyntaxElement *sym, struct img_par *img, struct inp_par *inp, struct datapartition *dp);
int readSliceUVLC(struct img_par *img, struct inp_par *inp);
// Direct interpolation
void get_block(int ref_frame,int x_pos, int y_pos, struct img_par *img, int block[BLOCK_SIZE][BLOCK_SIZE]);
void get_quarterpel_block(int ref_frame,int x_pos, int y_pos, struct img_par *img, int block[BLOCK_SIZE][BLOCK_SIZE]);
void get_eighthpel_block(int ref_frame,int x_pos, int y_pos, struct img_par *img, int block[BLOCK_SIZE][BLOCK_SIZE]);
int GetVLCSymbol (byte buffer[],int totbitoffset,int *info, int bytecount);
// int inter_intra(struct img_par *img);
// SLICE function pointers
int (*nal_startcode_follows) ();
// NAL functions TML/CABAC bitstream
int uvlc_startcode_follows();
int cabac_startcode_follows();
int GetOnePartitionIntoSourceBitBuffer(int PartitionSize, byte *Buf);
void free_Partition(Bitstream *currStream);
// ErrorConcealment
void reset_ec_flags();
// CABAC
void arideco_start_decoding(DecodingEnvironmentPtr dep, unsigned char *code_buffer, int firstbyte, int *code_len );
int arideco_bits_read(DecodingEnvironmentPtr dep);
void arideco_done_decoding(DecodingEnvironmentPtr dep);
void biari_init_context( BiContextTypePtr ctx, int ini_count_0, int ini_count_1, int max_cum_freq );
void biari_copy_context( BiContextTypePtr ctx_orig, BiContextTypePtr ctx_dest );
void biari_print_context( BiContextTypePtr ctx );
void rescale_cum_freq(BiContextTypePtr bi_ct);
unsigned int biari_decode_symbol(DecodingEnvironmentPtr dep, BiContextTypePtr bi_ct );
MotionInfoContexts* create_contexts_MotionInfo(void);
TextureInfoContexts* create_contexts_TextureInfo(void);
void init_contexts_MotionInfo(struct img_par *img, MotionInfoContexts *enco_ctx, int ini_flag);
void init_contexts_TextureInfo(struct img_par *img, TextureInfoContexts *enco_ctx, int ini_flag);
void delete_contexts_MotionInfo(MotionInfoContexts *enco_ctx);
void delete_contexts_TextureInfo(TextureInfoContexts *enco_ctx);
void readMB_typeInfoFromBuffer_CABAC(SyntaxElement *se, struct inp_par *inp, struct img_par *img, DecodingEnvironmentPtr dep_dp);
void readB8_typeInfoFromBuffer_CABAC(SyntaxElement *se, struct inp_par *inp, struct img_par *img, DecodingEnvironmentPtr dep_dp);
void readIntraPredModeFromBuffer_CABAC(SyntaxElement *se, struct inp_par *inp,struct img_par *img, DecodingEnvironmentPtr dep_dp);
void readRefFrameFromBuffer_CABAC(SyntaxElement *se, struct inp_par *inp, struct img_par *img, DecodingEnvironmentPtr dep_dp);
void readMVDFromBuffer_CABAC(SyntaxElement *se, struct inp_par *inp, struct img_par *img, DecodingEnvironmentPtr dep_dp);
void readCBPFromBuffer_CABAC(SyntaxElement *se, struct inp_par *inp, struct img_par *img, DecodingEnvironmentPtr dep_dp);
void readRunLevelFromBuffer_CABAC(SyntaxElement *se, struct inp_par *inp, struct img_par *img, DecodingEnvironmentPtr dep_dp);
void readMVD2Buffer_CABAC(SyntaxElement *se, struct inp_par *inp, struct img_par *img, DecodingEnvironmentPtr dep_dp);
void readBiMVD2Buffer_CABAC(SyntaxElement *se,struct inp_par *inp,struct img_par *img,DecodingEnvironmentPtr dep_dp);
void readBiDirBlkSize2Buffer_CABAC(SyntaxElement *se,struct inp_par *inp,struct img_par *img,DecodingEnvironmentPtr dep_dp);
int readSliceCABAC(struct img_par *img, struct inp_par *inp);
int readSyntaxElement_CABAC(SyntaxElement *se, struct img_par *img, struct inp_par *inp, DataPartition *this_dataPart);
void readDquant_inter_FromBuffer_CABAC(SyntaxElement *se,struct inp_par *inp,struct img_par *img,DecodingEnvironmentPtr dep_dp);
void readDquant_intra_FromBuffer_CABAC(SyntaxElement *se,struct inp_par *inp,struct img_par *img,DecodingEnvironmentPtr dep_dp);
void error(char *text, int code);
void start_slice(struct img_par *img, struct inp_par *inp);
int terminate_slice(struct img_par *img, struct inp_par *inp, struct stat_par *stat);
// dynamic mem allocation
int init_global_buffers(struct inp_par *inp, struct img_par *img);
void free_global_buffers(struct inp_par *inp, struct img_par *img);
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -