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

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

?? sim.h

?? encoder 視頻會議 視頻編碼算法 源程序
?? H
字號:
//系統定義#include<stdio.h>#include<stdlib.h>#include<string.h>#include<limits.h>#include "config.h"#include"macros.h"// This should not be changed #define MB_SIZE 16#define MBC   88#define MBR   72// 參數定義 #define PREF_NULL_VEC 100#define PREF_16_VEC 200#define PREF_PBDELTA_NULL_VEC 50//全局變量 int headerlength; int pels;int cpels;int lines;int trace;int advanced;int syntax_arith_coding;int pb_frames;int mv_outside_frame;int long_vectors;float target_framerate;FILE *tf;//**************************#define PSC        1#define PSC_LENGTH        17#define ESCAPE                          7167#define PCT_INTER                       1#define PCT_INTRA                       0#define ON                              1#define OFF                             0#define SF_SQCIF                        1  // 001 #define SF_QCIF                         2  // 010 #define SF_CIF                          3  // 011 #define SF_4CIF                         4  // 100 #define SF_16CIF                        5  // 101 #define MODE_INTER                      0#define MODE_INTER_Q                    1#define MODE_INTER4V                    2#define MODE_INTRA                      3#define MODE_INTRA_Q                    4#define PBMODE_NORMAL                   0#define PBMODE_MVDB                     1#define PBMODE_CBPB_MVDB                2#define NO_VEC                          999// 運動向量的結構 typedef struct motionvector {  int x;        // 運動向量的水平分量   int y;        // 運動向量的豎直分量   int x_half;   // 運動向量的水平半像素精度   int y_half;   // 運動向量的豎直半像素精度   int min_error;// 運動向量的最小誤差   int Mode;     // 運動向量的高級預測模式 } MotionVector;// 像素點的結構定義 typedef struct point {  int x;  int y;} Point;// 圖像數據的結構定義 typedef struct pict_image {  unsigned char *lum;  // 亮度信息平面   unsigned char *Cr;   // Cr色度信息平面   unsigned char *Cb;   // Cb色度信息平面 } PictImage;// 關于視頻幀各層的結構定義 // 視頻幀結構定義 typedef struct pict {  int prev;					//上一幀  int curr;					//當前幀  int TR;					//時間參考   int bit_rate;				//碼率  int src_frame_rate;		//源視頻格式的幀率  float target_frame_rate;  //目標視頻格式的幀率  int source_format;		//源視頻格式  int picture_coding_type;	//視頻幀編碼類型  int spare;  int unrestricted_mv_mode;	//非限制性的運動向量模式  int PB;					//PB幀模式  int QUANT;				//量化  int DQUANT;  int MB;					//編碼宏塊  int seek_dist;			//運動向量的搜索窗口  int use_gobsync;			//GOB同步的標志  int MODB;					//B幀模式  int BQUANT;				//在PB幀模式下為B幀宏塊選定的量化器  int TRB;					//為B幀準備的時間參考  float QP_mean;			//均值量化器} Pict;// 圖像分塊的結構定義typedef struct slice {  unsigned int vert_pos;	//圖像分塊的水平位置  unsigned int quant_scale;	//量化范圍} Slice;// 宏塊結構定義typedef struct macroblock {  int mb_address;			//宏塊地址  int macroblock_type;      //宏塊類型  int skipped;				//宏塊跳過表示:1表示跳過  MotionVector motion;	    //運動向量} Macroblock;// 宏塊數據的結構typedef struct mb_structure {  int lum[16][16];  int Cr[8][8];  int Cb[8][8];} MB_Structure;// 數據流統計的數據結構typedef struct bits_counted {  int Y;  int C;  int vec;  int CBPY;  int CBPCM;  int MODB;  int CBPB;  int COD;  int header;  int DQUANT;  int total;  int no_inter;  int no_inter4v;  int no_intra;} Bits;// 編碼結果的結構typedef struct results {  float SNR_l;        //亮度分量的信噪比  float SNR_Cr;       //色度分量的信噪比  float SNR_Cb;  float QP_mean;      //均值量化器} Results;void Help();void AdvancedHelp();int NextTwoPB(PictImage *p2, PictImage *bim, PictImage *p1,               int bskip, int pskip, int seek_dist);void PrintSNR(Results *res, int num);void PrintResult(Bits *bits, int num_units, int num);unsigned char *ReadImage(char *filename, int frame_no, int headerlength);PictImage *FillImage(unsigned char *in);void WriteImage(PictImage *image, char *filename);PictImage *InitImage(int size);void FreeImage(PictImage *image);char *StripName(char *s);int *MB_Encode(MB_Structure *mb_orig, int QP, int I);int MB_Decode(int *qcoeff, MB_Structure *mb_recon, int QP, int I);int Dct( int *block, int *coeff);int idct(int *coeff,int *block);void FillLumBlock( int x, int y, PictImage *image, MB_Structure *data);void FillChromBlock(int x_curr, int y_curr, PictImage *image,            MB_Structure *data);void ReconImage (int i, int j, MB_Structure *data, PictImage *recon);void CodeOneOrTwo(PictImage *curr, PictImage *B_image, PictImage *prev,           PictImage *prev_recon, int QP, int frameskip, Bits *bits,          Pict *pic, PictImage *B_recon, PictImage *recon);PictImage *CodeOneIntra(PictImage *curr, int QP, Bits *bits, Pict *pic);void Dequant(int *qcoeff, int *rcoeff, int QP, int I);void Quant(int *coeff, int *qcoeff, int QP, int I);void CountBitsCoeff(int *qcoeff, int I, int CBP, Bits *bits, int ncoeffs);int CodeCoeff(int Mode, int *qcoeff, int block, int ncoeffs);int FindCBP(int *qcoeff, int Mode, int ncoeffs);void CountBitsVectors(MotionVector *MV[5][MBR+1][MBC+2], Bits *bits,               int i, int j, int Mode, int newgob, Pict *pic);void FindPMV(MotionVector *MV[5][MBR+1][MBC+2], int x, int y,              int *p0, int *p1, int block, int newgob, int half_pel);void ZeroBits(Bits *bits);void ZeroRes(Results *res);void ZeroVec(MotionVector *MV);void MarkVec(MotionVector *MV);void CopyVec(MotionVector *MV1, MotionVector *MV2);int EqualVec(MotionVector *MV2, MotionVector *MV1);void AddBits(Bits *total, Bits *bits);void AddRes(Results *total, Results *res, Pict *pic);void AddBitsPicture(Bits *bits);void FindMB(int x, int y, unsigned char *image, int MB[16][16]);MB_Structure *MB_Recon(PictImage *prev_recon, MB_Structure *diff,               int x_curr, int y_curr, MotionVector *MV);MB_Structure *Predict(PictImage *curr, PictImage *prev_recon,              int x_curr, int y_curr, MotionVector *MV);unsigned char *InterpolateImage(unsigned char *image, int w, int h);void MotionEstimatePicture(unsigned char *curr, unsigned char *prev,            unsigned char *prev_ipol, int seek_dist,            MotionVector *MV[5][MBR+1][MBC+2], int gobsync);void MotionEstimation(unsigned char *curr, unsigned char *prev, int x_curr,              int y_curr, int xoff, int yoff, int seek_dist,               MotionVector *MV[5][MBR+1][MBC+2], int *sad_0);unsigned char *LoadArea(unsigned char *im, int x, int y,         int x_size, int y_size, int lx);int SAD_Macroblock(unsigned char *ii, unsigned char *act_block,           int h_length, int Min_FRAME);int SAD_MB_Bidir(unsigned char *ii, unsigned char *aa, unsigned char *bb,          int width, int min_sofar);int SAD_Block(unsigned char *ii, unsigned char *act_block,              int h_length, int min_sofar);int SAD_MB_integer(int *ii, int *act_block, int h_length, int min_sofar);MB_Structure *Predict_P(PictImage *curr_image, PictImage *prev_image,        unsigned char *prev_ipol,int x_curr, int y_curr,         MotionVector *fr[5][MBR+1][MBC+2], int PB);MB_Structure *Predict_B(PictImage *curr_image, PictImage *prev_image,        unsigned char *prev_ipol,int x_curr, int y_curr,        MotionVector *fr[5][MBR+1][MBC+2],        MB_Structure *recon_P, int TR,int TRB);void Clip(MB_Structure *data);void FindForwLumPredPB(unsigned char *prev_ipol, int x_curr, int y_curr,                MotionVector *fr, int *pred, int TRD, int TRB,                int bdx, int bdy, int bs, int comp);void FindBiDirLumPredPB(int *recon_P, MotionVector *fr, int *pred, int TRD,         int TRB, int bdx, int bdy, int nh, int nv);void FindBiDirChrPredPB(MB_Structure *recon_P, int dx, int dy,         MB_Structure *pred);void FindBiDirLimits(int vec, int *start, int *stop, int nhv);void FindBiDirChromaLimits(int vec, int *start, int *stop);void BiDirPredBlock(int xstart, int xstop, int ystart, int ystop,            int xvec, int yvec, int *recon, int *pred, int bl);void DoPredChrom_P(int x_curr, int y_curr, int dx, int dy,           PictImage *curr, PictImage *prev,            MB_Structure *pred_error);void FindHalfPel(int x, int y, MotionVector *MV, unsigned char *prev,          int *curr, int bs, int comp);void FindPred(int x, int y, MotionVector *fr, unsigned char *prev,               int *pred, int bs, int comp); void FindPredOBMC(int x, int y, MotionVector *MV[5][MBR+1][MBC+2],           unsigned char *prev, int *pred, int comp, int PB);MB_Structure *MB_Recon_P(PictImage *prev_image, unsigned char *prev_ipol,         MB_Structure *diff, int x_curr, int y_curr,          MotionVector *MV[5][MBR+1][MBC+2], int PB);MB_Structure *MB_Recon_B(PictImage *prev, MB_Structure *diff,         unsigned char *prev_ipol,int x_curr, int y_curr,         MotionVector *MV[5][MBR+1][MBC+2],         MB_Structure *recon_P,int TR, int TRB);void ReconLumBlock_P(int x, int y, MotionVector *fr,             unsigned char *prev, int *data,int bs,int comp);void ReconChromBlock_P(int x_curr, int y_curr, int dx, int dy,               PictImage *prev, MB_Structure *data);void FindChromBlock_P(int x_curr, int y_curr, int dx, int dy,               PictImage *prev, MB_Structure *data);void ComputeSNR(PictImage *im1, PictImage *im2, Results *res, int write);     void ZeroMBlock(MB_Structure *data);int CountBitsPicture(Pict *pic);void CountBitsMB(int Mode, int COD, int CBP, int CBPB, Pict *pic, Bits *bits);int CountBitsSlice(int slice, int quant);int ChooseMode(unsigned char *curr, int x_pos, int y_pos, int min_SAD);int ModifyMode(int Mode, int dquant);int *InterleaveCoeff(int *qp, int *qb, int bs);void MakeEdgeImage(unsigned char *src, unsigned char *dst, int width,           int height, int edge);void BitPrint(int length, int val, char *bit);#ifdef OFFLINE_RATE_CONTROLint FrameUpdateQP(int buf, int bits, int frames_left, int QP, int B,           float seconds);#elseint UpdateQuantizer(int mb, float QP_mean, int pict_type, float bit_rate,                     int mb_width, int mb_height, int bitcount) ;int InitializeQuantizer(int pict_type, float bit_rate,                                            float target_frame_rate, float QP_mean);void InitializeRateControl();void UpdateRateControl(int bits);#endif#ifndef FASTIDCT// global declarations for idctref void init_idctref (void);void idctref (int *coeff, int *block);#endif// Syntax based arithmetic coding routines void Count_sac_BitsCoeff(int *qcoeff, int I, int CBP, Bits *bits, int ncoeffs);int Code_sac_Coeff(int Mode, int *qcoeff, int block, int ncoeffs);int CodeTCoef(int mod_index, int position, int intra);void Count_sac_BitsVectors(MotionVector *MV[5][MBR+1][MBC+2], Bits *bits,                      int i, int j, int Mode, int newgob, Pict *pic);void Count_sac_BitsMB(int Mode,int COD,int CBP,int CBPB,Pict *pic,Bits *bits);int AR_Encode(int index, int cumul_freq[]);int indexfn(int value, int table[], int max);int bit_opp_bits(int);int bit_in_psc_layer(int);int encoder_flush();// bitstream-functions void initbits();void putbits (int, int);int alignbits ();int bitcount();// Fix broken header-files on suns to avoid compiler warnings // #define BROKEN_SUN_HEADERS here or in Makefile #ifdef BROKEN_SUN_HEADERSextern int printf();extern int fprintf();extern int time();extern int fclose();extern int rewind();extern int fseek();extern int fread();extern int fwrite();extern int fflush();extern int fscanf();extern int _flsbuf();extern int _filbuf();#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美videossexotv100| 日韩一区二区三| 亚洲成人精品在线观看| 欧美不卡一区二区三区四区| 色一情一乱一乱一91av| 狠狠色丁香久久婷婷综合丁香| 亚洲欧美日韩国产手机在线| 精品免费日韩av| 欧美亚洲动漫精品| 波多野结衣一区二区三区 | 在线成人午夜影院| 东方aⅴ免费观看久久av| 人人超碰91尤物精品国产| 亚洲女子a中天字幕| 久久久久久99久久久精品网站| 欧美日韩在线不卡| 色欧美日韩亚洲| 成人激情动漫在线观看| 国产在线日韩欧美| 蜜臀av性久久久久蜜臀av麻豆| 一区二区三区小说| 亚洲三级理论片| 日韩经典一区二区| 日韩激情一二三区| 亚洲精品视频在线观看网站| 国产午夜一区二区三区| 欧美一级日韩一级| 6080午夜不卡| 欧美精品99久久久**| 欧美性色欧美a在线播放| 99re66热这里只有精品3直播| 国产精品1区2区3区在线观看| 美女被吸乳得到大胸91| 日韩精品一二三四| 日韩极品在线观看| 麻豆免费精品视频| 久久精品72免费观看| 老色鬼精品视频在线观看播放| 日韩av在线播放中文字幕| 视频在线观看一区二区三区| 天天亚洲美女在线视频| 三级精品在线观看| 国产真实精品久久二三区| 美女精品自拍一二三四| 久久99精品久久久久久久久久久久 | 国产欧美日韩精品在线| 久久精品一区四区| 久久精品亚洲乱码伦伦中文| 国产夜色精品一区二区av| 国产欧美一区二区精品仙草咪| 国产嫩草影院久久久久| 国产精品久久久久久一区二区三区 | 欧美老年两性高潮| 欧美一级一区二区| 亚洲精品在线免费播放| 久久精品水蜜桃av综合天堂| 国产精品视频观看| 亚洲免费视频中文字幕| 五月婷婷综合在线| 久久精品99国产精品日本| 国产成人精品亚洲午夜麻豆| 91性感美女视频| 欧美日本不卡视频| 久久久久久99久久久精品网站| **性色生活片久久毛片| 亚洲成av人片在线| 久草在线在线精品观看| 成人黄色av电影| 欧美日本韩国一区二区三区视频| 日韩美一区二区三区| 国产女人水真多18毛片18精品视频| 亚洲免费观看视频| 免费黄网站欧美| 成人亚洲一区二区一| 在线亚洲高清视频| 精品国精品自拍自在线| 亚洲欧洲av色图| 美女www一区二区| 99精品桃花视频在线观看| 欧美精品粉嫩高潮一区二区| 337p粉嫩大胆噜噜噜噜噜91av | 日本一区二区三区四区| 久久丁香综合五月国产三级网站| 成人中文字幕合集| 56国语精品自产拍在线观看| 国产女主播在线一区二区| 亚洲成人在线免费| 国产91丝袜在线播放0| 欧美日韩国产精品成人| 欧美国产视频在线| 日韩成人一级片| 色综合天天综合网天天狠天天| 精品少妇一区二区三区在线视频| 国产精品免费aⅴ片在线观看| 日韩精品国产欧美| 日本久久电影网| 国产日韩精品一区二区浪潮av| 日本视频中文字幕一区二区三区| 99视频在线精品| 久久亚区不卡日本| 三级一区在线视频先锋| 91豆麻精品91久久久久久| 久久影院电视剧免费观看| 五月婷婷久久丁香| 一本色道亚洲精品aⅴ| 国产无遮挡一区二区三区毛片日本| 日韩影视精彩在线| 欧美影院一区二区| 最好看的中文字幕久久| 国产激情一区二区三区四区 | 国产福利一区二区三区视频 | 青娱乐精品视频| 在线精品视频免费观看| 国产精品久99| 福利91精品一区二区三区| 日韩午夜在线影院| 首页欧美精品中文字幕| 欧美日韩亚洲综合一区 | 亚洲色图一区二区| 不卡电影免费在线播放一区| 久久先锋资源网| 精彩视频一区二区三区| 日韩欧美一区二区视频| 日日夜夜精品免费视频| 欧美婷婷六月丁香综合色| 亚洲另类春色校园小说| 99精品国产91久久久久久| 亚洲国产成人av| 欧美性猛交xxxx乱大交退制版 | 久久69国产一区二区蜜臀| 欧美一级免费大片| 视频一区视频二区中文字幕| 欧美日韩一区二区三区高清| 亚洲影视在线播放| 欧美在线影院一区二区| 性感美女久久精品| 欧美一区二区三区在线观看| 日韩成人一级大片| 欧美岛国在线观看| 国产又黄又大久久| 国产婷婷色一区二区三区| 国产精品一区久久久久| 中文字幕va一区二区三区| 成人高清视频免费观看| 中文字幕字幕中文在线中不卡视频| kk眼镜猥琐国模调教系列一区二区| 国产精品美女久久久久久久久| 91女人视频在线观看| 一区二区三区四区不卡在线 | 美腿丝袜在线亚洲一区| 久久综合狠狠综合久久激情| 国产不卡在线一区| 亚洲欧美在线观看| 欧美日韩一本到| 久久电影国产免费久久电影| 久久亚洲欧美国产精品乐播| 成人免费毛片片v| 一区二区三区四区在线免费观看| 欧美日韩黄视频| 国产乱国产乱300精品| 中文字幕一区日韩精品欧美| 欧美日韩国产精选| 国产一区在线精品| 亚洲欧美偷拍卡通变态| 7777精品伊人久久久大香线蕉的| 蜜臀av一区二区三区| 国产肉丝袜一区二区| 在线视频综合导航| 美女视频黄免费的久久 | 色婷婷久久久综合中文字幕| 视频一区视频二区中文| 久久久91精品国产一区二区三区| 99re热这里只有精品免费视频| 亚洲va中文字幕| 久久精品亚洲乱码伦伦中文| 日本韩国欧美三级| 国产一区二区三区四区在线观看| 日韩av一级电影| 国产精品免费视频观看| 欧美精品久久一区| 成人app在线| 麻豆成人在线观看| 亚洲精品国产a久久久久久| 欧美xxxx老人做受| 色综合久久久久网| 国模大尺度一区二区三区| 亚洲精品视频在线看| 久久免费午夜影院| 欧美日本韩国一区| 91丝袜美女网| 国产乱码精品一区二区三区av| 亚洲电影第三页| 国产精品婷婷午夜在线观看| 欧美一区二区三区日韩| 色综合久久综合中文综合网| 国内外成人在线视频| 午夜精品爽啪视频| 亚洲三级免费观看| 久久精品欧美一区二区三区麻豆| 欧美日韩一区三区|