亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? global.h

?? h264標準的VC實現
?? H
?? 第 1 頁 / 共 2 頁
字號:
} DataPartition;

//! Slice
typedef struct
{
  int                 ei_flag;       //!< 0 if the partArr[0] contains valid information
  int                 qp;
  int                 slice_qp_delta;
  int                 picture_type;  //!< picture type
  PictureStructure    structure;     //!< Identify picture structure 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                 next_header;
//  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
  
  int                 ref_pic_list_reordering_flag_l0;
  int                 *remapping_of_pic_nums_idc_l0;
  int                 *abs_diff_pic_num_minus1_l0;
  int                 *long_term_pic_idx_l0;
  int                 ref_pic_list_reordering_flag_l1;
  int                 *remapping_of_pic_nums_idc_l1;
  int                 *abs_diff_pic_num_minus1_l1;
  int                 *long_term_pic_idx_l1;

  int     (*readSlice)(struct img_par *, struct inp_par *);

  int                 LFDisableIdc;     //!< Disable loop filter on slice
  int                 LFAlphaC0Offset;  //!< Alpha and C0 offset for filtering slice
  int                 LFBetaOffset;     //!< Beta offset for filtering slice

  int                 pic_parameter_set_id;   //!<the ID of the picture parameter set the slice is reffering to

} Slice;

//****************************** ~DM ***********************************

// image parameters
typedef struct img_par
{
  int number;                                 //!< frame number
  unsigned current_mb_nr; // bitstream order
  unsigned num_dec_mb;
  int current_slice_nr;
  int *intra_block;
  int tr;                                     //!< temporal reference, 8 bit, wrapps at 255
  int qp;                                     //!< quant for the current frame
  int qpsp;                                   //!< quant for SP-picture predicted frame
  int sp_switch;                              //!< 1 for switching sp, 0 for normal sp
  int direct_spatial_mv_pred_flag;            //!< 1 for Spatial Direct, 0 for Temporal
  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;
  imgpel mpr[16][16];                         //!< predicted block
  int mvscale[6][MAX_REFERENCE_PICTURES];
  int m7[16][16];                             //!< final 4x4 block. Extended to 16x16 for ABT
  int cof[4][12][4][4];                       //!< correction coefficients from predicted   
  int cofu[16];                                                                             
  int **ipredmode;                            //!< prediction type [90][74]
  int *quad;
  int ***nz_coeff;
  int **siblock;
  int cod_counter;                            //!< Current count of number of skipped macroblocks in a row

  int newframe;

  int structure;                               //!< Identify picture structure type
  int pstruct_next_P;

  // B pictures
  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 is_intra_block;
  int is_v_block;

  // For MB level frame/field coding
  int MbaffFrameFlag;

  // for signalling to the neighbour logic that this is a deblocker call
  int DeblockCall;

  int **field_anchor;

  DecRefPicMarking_t *dec_ref_pic_marking_buffer;                    //!< stores the memory management control operations

  int disposable_flag;                          //!< flag for disposable frame, 1:disposable
  int num_ref_idx_l0_active;             //!< number of forward reference
  int num_ref_idx_l1_active;             //!< number of backward reference

  int slice_group_change_cycle;
  // JVT-D101
  int redundant_slice_flag; 
  int redundant_pic_cnt; 

  int explicit_B_prediction;

  unsigned int pre_frame_num;           //!< store the frame_num in the last decoded slice. For detecting gap in frame_num.

  // End JVT-D101
  // POC200301: from unsigned int to int
           int toppoc;      //poc for this top field // POC200301
           int bottompoc;   //poc of bottom field of frame
           int framepoc;    //poc of this frame // POC200301
  unsigned int frame_num;   //frame_num for this frame
  unsigned int field_pic_flag;
  unsigned int bottom_field_flag;
  
  //the following is for slice header syntax elements of poc
  // for poc mode 0.
  unsigned int pic_order_cnt_lsb;
           int delta_pic_order_cnt_bottom;
  // for poc mode 1.
           int delta_pic_order_cnt[3];

  // ////////////////////////
  // for POC mode 0:
    signed int PrevPicOrderCntMsb;
  unsigned int PrevPicOrderCntLsb;
    signed int PicOrderCntMsb;

  // for POC mode 1:
  unsigned int AbsFrameNum;
    signed int ExpectedPicOrderCnt, PicOrderCntCycleCnt, FrameNumInPicOrderCntCycle;
  unsigned int PreviousFrameNum, FrameNumOffset;
           int ExpectedDeltaPerPicOrderCntCycle;
           int PreviousPOC, ThisPOC;
           int PreviousFrameNumOffset;
  // /////////////////////////

  //weighted prediction
  unsigned int luma_log2_weight_denom;
  unsigned int chroma_log2_weight_denom;
  int ***wp_weight;  // weight in [list][index][component] order
  int ***wp_offset;  // offset in [list][index][component] order
  int ****wbp_weight; //weight in [list][fw_index][bw_index][component] order
  int wp_round_luma;
  int wp_round_chroma;
  unsigned int apply_weights;

  int idr_flag;
  int nal_reference_idc;                       //!< nal_reference_idc from NAL unit

  int idr_pic_id;

  int MaxFrameNum;

  unsigned PicWidthInMbs;
  unsigned PicHeightInMapUnits;
  unsigned FrameHeightInMbs;
  unsigned PicHeightInMbs;
  unsigned PicSizeInMbs;
  unsigned FrameSizeInMbs;
  unsigned oldFrameSizeInMbs;

  int no_output_of_prior_pics_flag;
  int long_term_reference_flag;
  int adaptive_ref_pic_buffering_flag;

  int last_has_mmco_5;
  int last_pic_bottom_field;

  int model_number;

  // Fidelity Range Extensions Stuff
  int pic_unit_bitsize_on_disk;
  int bitdepth_luma;
  int bitdepth_chroma;
  int bitdepth_luma_qp_scale;
  int bitdepth_chroma_qp_scale;
  unsigned int dc_pred_value;                 //!< value for DC prediction (depends on pel bit depth)
  int max_imgpel_value;                       //!< max value that one luma picture element (pixel) can take (depends on pic_unit_bitdepth)
  int max_imgpel_value_uv;                    //!< max value that one chroma picture element (pixel) can take (depends on pic_unit_bitdepth)
  int AllowTransform8x8;        
  int profile_idc;              
  int yuv_format;
  int lossless_qpprime_flag;
  int num_blk8x8_uv;
  int num_cdc_coeff;
  int mb_cr_size_x;
  int mb_cr_size_y;
  int chroma_qp_offset[2];                    //!< offset for qp for chroma [0-Cb, 1-Cr] 
  
  int idr_psnr_number;
  int psnr_number;

  time_t ltime_start;               // for time measurement
  time_t ltime_end;                 // for time measurement

  // Residue Color Transform
  int residue_transform_flag;

#ifdef WIN32
  struct _timeb tstruct_start;
  struct _timeb tstruct_end;
#else
  struct timeb tstruct_start;
  struct timeb tstruct_end;
#endif

} ImageParameters;

extern ImageParameters *img;
extern struct snr_par  *snr;

// signal to noise 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];                       //!< H.264 inputfile
  char outfile[100];                      //!< Decoded YUV 4:2:0 output
  char reffile[100];                      //!< Optional YUV 4:2:0 reference file for SNR measurement
  int FileFormat;                         //!< File format of the Input file, PAR_OF_ANNEXB or PAR_OF_RTP
  int dpb_size;                          //!< Frame buffer size
  int ref_offset;
  int poc_scale;

#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

  int LowPassForIntra8x8;
};

extern struct inp_par *input;

typedef struct pix_pos
{
  int available;
  int mb_addr;
  int x;
  int y;
  int pos_x;
  int pos_y;
} PixelPos;

typedef struct old_slice_par
{
   unsigned field_pic_flag;
   unsigned bottom_field_flag;
   unsigned frame_num;
   int nal_ref_idc;
   unsigned pic_oder_cnt_lsb;
   int delta_pic_oder_cnt_bottom;
   int delta_pic_order_cnt[2];
   int idr_flag;
   int idr_pic_id;
   int pps_id;
} OldSliceParams;

extern OldSliceParams old_slice;

// files
int p_out;                    //!< file descriptor to output YUV file
//FILE *p_out2;                    //!< pointer to debug output YUV file
int p_ref;                    //!< pointer to input original reference YUV file file

FILE *p_log;                    //!< SNR file

#if TRACE
FILE *p_trace;
#endif

// Residue Color Transform
int mprRGB[3][16][16];
int rec_res[3][16][16];

// 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 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_picture(struct img_par *img, struct inp_par *inp);
void exit_picture();

int  read_new_slice();
void decode_one_slice(struct img_par *img,struct inp_par *inp);

void start_macroblock(struct img_par *img,struct inp_par *inp, int CurrentMBInScanOrder);
int  read_one_macroblock(struct img_par *img,struct inp_par *inp);
void read_ipred_modes(struct img_par *img,struct inp_par *inp);
int  decode_one_macroblock(struct img_par *img,struct inp_par *inp);
int  exit_macroblock(struct img_par *img,struct inp_par *inp, int eos_bit);
void decode_ipcm_mb(struct img_par *img);


void readMotionInfoFromNAL (struct img_par *img,struct inp_par *inp);
void readCBPandCoeffsFromNAL(struct img_par *img,struct inp_par *inp);
void readIPCMcoeffsFromNAL(struct img_par *img, struct inp_par *inp, struct datapartition *dP);

void readLumaCoeff8x8_CABAC (struct img_par *img,struct inp_par *inp, int b8);
void itrans8x8(struct img_par *img, int ioff, int joff);

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, int chroma);
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_16x16(struct img_par *img,int predmode);
void intrapred_chroma(struct img_par *img, int uv);
int  sign(int a , int b);

// SLICE function pointers
int  (*nal_startcode_follows) ();

// NAL functions TML/CABAC bitstream
int  uvlc_startcode_follows();
int  cabac_startcode_follows();
void free_Partition(Bitstream *currStream);

// ErrorConcealment
void reset_ec_flags();

void error(char *text, int code);
int  is_new_picture();
void init_old_slice();

// dynamic mem allocation
int  init_global_buffers();
void free_global_buffers();

void frame_postprocessing(struct img_par *img, struct inp_par *inp);
void field_postprocessing(struct img_par *img, struct inp_par *inp);
int  bottom_field_picture(struct img_par *img,struct inp_par *inp);
void decode_slice(struct img_par *img,struct inp_par *inp, int current_header);

int RBSPtoSODB(byte *streamBuffer, int last_byte_pos);
int EBSPtoRBSP(byte *streamBuffer, int end_bytepos, int begin_bytepos);

// For MB level frame/field coding
void init_super_macroblock(struct img_par *img,struct inp_par *inp);
void exit_super_macroblock(struct img_par *img,struct inp_par *inp);
int  decode_super_macroblock(struct img_par *img,struct inp_par *inp);
void decode_one_Copy_topMB(struct img_par *img,struct inp_par *inp);

void SetOneRefMV(struct img_par* img);
int peekSyntaxElement_UVLC(SyntaxElement *sym, struct img_par *img, struct inp_par *inp, struct datapartition *dP);

void fill_wp_params(struct img_par *img);

void reset_wp_params(struct img_par *img);

void FreePartition (DataPartition *dp, int n);
DataPartition *AllocPartition();

void tracebits2(const char *trace_str, int len, int info);

void init_decoding_engine_IPCM(struct img_par *img);
void readIPCMBytes_CABAC(SyntaxElement *sym, Bitstream *currStream);

#endif

// For Q-matrix
void AssignQuantParam(pic_parameter_set_rbsp_t* pps, seq_parameter_set_rbsp_t* sps);
void CalculateQuantParam(void);
void CalculateQuant8Param(void);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲影视在线观看| 五月激情六月综合| 777xxx欧美| 成人晚上爱看视频| 日韩精品免费专区| 亚洲人成网站在线| 国产午夜精品一区二区| 欧美日韩aaa| 色婷婷综合视频在线观看| 国产真实乱对白精彩久久| 亚洲一区二区三区自拍| 国产精品久久三| 亚洲精品一区二区三区福利| 欧美日韩国产精品自在自线| 成人av先锋影音| 国产乱子轮精品视频| 亚洲国产毛片aaaaa无费看| 国产精品萝li| 久久精品日韩一区二区三区| 欧美一区二区高清| 欧美日韩成人综合在线一区二区| 91免费看片在线观看| 国产久卡久卡久卡久卡视频精品| 日本在线观看不卡视频| 亚洲制服欧美中文字幕中文字幕| 中文字幕永久在线不卡| 日韩1区2区3区| 日韩高清在线一区| 亚洲图片欧美视频| 一区二区三区久久| 亚洲精品视频在线看| 国产精品动漫网站| 国产精品国产三级国产aⅴ入口| wwwwww.欧美系列| 精品国内二区三区| 精品卡一卡二卡三卡四在线| 日韩精品在线看片z| 日韩丝袜美女视频| 在线播放91灌醉迷j高跟美女| 欧美日韩国产精选| 91精品国产福利在线观看 | av网站一区二区三区| 国产美女娇喘av呻吟久久 | 色久优优欧美色久优优| 99久久精品情趣| 9久草视频在线视频精品| 9l国产精品久久久久麻豆| av动漫一区二区| 日本道精品一区二区三区| 日本乱码高清不卡字幕| 在线观看欧美日本| 欧美日韩情趣电影| 日韩一区二区免费在线电影| 精品日韩一区二区三区| 久久影院午夜论| 国产精品色一区二区三区| 国产精品色婷婷久久58| 亚洲免费在线观看视频| 午夜视频一区在线观看| 另类小说色综合网站| 国产一区二区三区蝌蚪| 成人av小说网| 欧美性一级生活| 日韩欧美国产不卡| 久久久久国产精品麻豆| 中文字幕在线不卡| 午夜精品免费在线观看| 精品午夜久久福利影院| 成人性色生活片免费看爆迷你毛片| 91丨porny丨最新| 欧美女孩性生活视频| 欧美videofree性高清杂交| 国产无遮挡一区二区三区毛片日本| 中文字幕va一区二区三区| 亚洲激情中文1区| 蜜臂av日日欢夜夜爽一区| 国产精品1024久久| 91成人网在线| 精品免费99久久| 国产精品久久久一本精品| 日韩精品电影一区亚洲| 国产黄色精品网站| 色8久久精品久久久久久蜜| 日韩视频在线永久播放| 亚洲欧美另类综合偷拍| 蜜臀av性久久久久蜜臀aⅴ| 成人免费视频视频在线观看免费| 综合网在线视频| 午夜欧美2019年伦理| 国产69精品久久久久毛片| 欧美日韩免费一区二区三区视频| 2023国产一二三区日本精品2022| 亚洲资源在线观看| 成人a区在线观看| 日韩精品一区二区三区四区| 亚洲乱码国产乱码精品精小说| 黄页网站大全一区二区| 欧美性色aⅴ视频一区日韩精品| 亚洲精品一区二区三区香蕉| 亚洲成人中文在线| 不卡在线视频中文字幕| 欧美变态口味重另类| 一区二区欧美视频| 国产老女人精品毛片久久| 欧美日韩在线综合| 中文字幕中文字幕在线一区| 麻豆精品一区二区av白丝在线| 色素色在线综合| 国产日产欧美精品一区二区三区| 免费高清在线视频一区·| 91成人在线观看喷潮| 国产精品你懂的| 国产一区不卡视频| 欧美一卡二卡在线观看| 亚洲国产精品人人做人人爽| 99国产精品久久久| 中文字幕精品在线不卡| 美女一区二区视频| 欧美一级夜夜爽| 午夜精品一区二区三区电影天堂 | 伊人一区二区三区| 成人国产亚洲欧美成人综合网| 日韩丝袜情趣美女图片| 免费高清在线视频一区·| 欧美疯狂性受xxxxx喷水图片| 一区二区三区在线不卡| 一本大道综合伊人精品热热| 亚洲图片你懂的| 色婷婷亚洲精品| 一区二区三区高清不卡| 91视频www| 亚洲激情综合网| 欧美亚洲愉拍一区二区| 亚洲第一久久影院| 欧美日韩成人综合在线一区二区| 亚洲尤物视频在线| 欧美日韩在线播| 日日夜夜精品视频天天综合网| 欧美日韩精品一区二区| 青青草精品视频| 欧美tickling网站挠脚心| 精品一区二区三区欧美| 精品国产乱码久久久久久老虎| 经典三级视频一区| 欧美韩日一区二区三区四区| 成人av资源在线观看| 专区另类欧美日韩| 欧美自拍丝袜亚洲| 日本v片在线高清不卡在线观看| 欧美一级理论片| 国产真实乱偷精品视频免| 国产欧美日韩卡一| 91日韩精品一区| 午夜伦欧美伦电影理论片| 日韩免费视频一区| 国产馆精品极品| 亚洲精品老司机| 91精品国产综合久久国产大片| 激情另类小说区图片区视频区| 亚洲国产成人午夜在线一区| 色综合久久久久综合99| 亚洲成av人片| 久久免费电影网| 91毛片在线观看| 午夜精品久久久久久久久久久| 日韩美女天天操| 波多野结衣在线aⅴ中文字幕不卡| 亚洲已满18点击进入久久| 日韩一区二区三区四区| www.亚洲精品| 丝瓜av网站精品一区二区| 久久久亚洲午夜电影| 91蜜桃视频在线| 美女一区二区三区| 亚洲色图欧美偷拍| 日韩午夜激情视频| 91日韩精品一区| 久久99国产精品久久| 亚洲婷婷综合色高清在线| 91精品在线免费观看| 成人黄色电影在线 | 欧美日本一道本在线视频| 精品无人区卡一卡二卡三乱码免费卡 | 亚洲精品免费视频| 亚洲精品一区二区三区在线观看| 99精品国产91久久久久久| 免费久久精品视频| 亚洲精品成人精品456| 欧美精品一区二区三区在线| 欧美影视一区二区三区| 国产精品香蕉一区二区三区| 丝瓜av网站精品一区二区| 国产精品美女久久久久久久久| 91精品中文字幕一区二区三区| 97久久精品人人做人人爽50路| 日本不卡一区二区三区| 亚洲欧美一区二区视频| 精品成人在线观看| 欧美日韩在线直播| 91丨九色丨国产丨porny|