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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? countbit.cpp

?? Netmeeting是Windows系統(tǒng)自帶的網(wǎng)上聊天軟件
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
////////////////////////////////////////////////////////////////////////////
//
//
//    Project     : VideoNet version 1.1.
//    Description : Peer to Peer Video Conferencing over the LAN.
//	  Author      :	Nagareshwar Y Talekar ( nsry2002@yahoo.co.in)
//    Date        : 15-6-2004.
//
//    I have converted origional fast h.263 encoder library from C to C++ 
//	  so that it can be integrated into any windows application easily.
//	  I have removed some of unnecessary codes/files from the
//	  fast h263 library.Also moved definitions and declarations
//	  in their proper .h and .cpp files.
//
//    File description : 
//    Name    : countbit.cpp
//
//
/////////////////////////////////////////////////////////////////////////////

/************************************************* * libr263: fast H.263 encoder library * * Copyright (C) 1996, Roalt Aalmoes, Twente University * SPA multimedia group * * Based on Telenor TMN 1.6 encoder (Copyright (C) 1995, Telenor R&D) * created by Karl Lillevold  * * Author encoder: Roalt Aalmoes, <aalmoes@huygens.nl> *  * Date: 31-07-96 **************************************************/ /********************************************************************** * *	Name:		CountBitsMB *	Description:    counts bits used for MB info
 *	
 *	Input:	        Mode, COD, CBP, Picture and Bits structures
 *	Returns:       
 *	Side effects:
 *
 *	Date: 941129	Author: Karl.Lillevold@nta.no * ***********************************************************************/
#include "stdafx.h"
#include "countbit.h"

void CountBitsMB(int Mode, int COD, int CBP, int CBPB, Pict *pic, Bits *bits){  extern EHUFF *vlc_cbpy, *vlc_cbpcm, *vlc_cbpcm_intra;  int cbpy, cbpcm, length;  /* COD */  if (Global::trace) {    fprintf(Global::tf,"MB-nr: %d",pic->MB);    if (pic->picture_coding_type == PCT_INTER)      fprintf(Global::tf,"  COD: %d\n",COD);  }  if (pic->picture_coding_type == PCT_INTER) {    mputv(1,COD);    bits->COD++;  }  if (COD)     return;    /* not coded */  /* CBPCM */  cbpcm = Mode | ((CBP&3)<<4);  if (Global::trace) {    fprintf(Global::tf,"CBPCM (CBP=%d) (cbpcm=%d): ",CBP,cbpcm);  }  if (pic->picture_coding_type == PCT_INTRA) {    length = Encode(cbpcm,vlc_cbpcm_intra);  } else {    length = Encode(cbpcm,vlc_cbpcm);  }  bits->CBPCM += length;      /* CBPY */  cbpy = CBP>>2;  if (Mode == MODE_INTRA || Mode == MODE_INTRA_Q) /* Intra */    cbpy = cbpy^15;  if (Global::trace) {    fprintf(Global::tf,"CBPY (CBP=%d) (cbpy=%d): ",CBP,cbpy);  }  length = Encode(cbpy, vlc_cbpy);  bits->CBPY += length;    return;}/********************************************************************** * *	Name:		CountBitsSlice *	Description:    couonts bits used for slice (GOB) info *	 *	Input:	        slice no., quantizer * *	Date: 94????	Author: Karl.Lillevold@nta.no * ***********************************************************************/int CountBitsSlice(int slice, int quant){  int bits = 0;  /* Picture Start Code */  if (Global::trace)    fprintf(Global::tf,"GOB sync (GBSC): ");  mputv(PSC_LENGTH,PSC); /* PSC */  bits += PSC_LENGTH;  /* Group Number */  if (Global::trace)    fprintf(Global::tf,"GN: ");  mputv(5,slice);  bits += 5;  /* GOB Sub Bitstream Indicator */  /* if CPM == 1: read 2 bits GSBI */  /* not supported in this version */  /* GOB Frame ID */  if (Global::trace)    fprintf(Global::tf,"GFID: ");  mputv(2, 0);    /* NB: in error-prone environments this value should change if      PTYPE in picture header changes. In this version of the encoder     PTYPE only changes when PB-frames are used in the following cases:     (i) after the first intra frame     (ii) if the distance between two P-frames is very large      Therefore I haven't implemented this GFID change */  /* GFID is not allowed to change unless PTYPE changes */  bits += 2;  /* Gquant */  if (Global::trace)    fprintf(Global::tf,"GQUANT: ");  mputv(5,quant);  bits += 5;  return bits;}/********************************************************************** * *	Name:		CountBitsCoeff *	Description:	counts bits used for coeffs *	 *	Input:		qcoeff, coding mode CBP, bits structure, no. of  *                      coeffs *			 *	Returns:	struct with no. of bits used *	Side effects:	 * *	Date: 940111	Author:	Karl.Lillevold@nta.no * ***********************************************************************/void CountBitsCoeff(int *qcoeff, int Mode, int CBP, Bits *bits, int ncoeffs){    int i;  if (Mode == MODE_INTRA) {    for (i = 0; i < 4; i++) {      bits->Y += CodeCoeff(Mode, qcoeff,i,ncoeffs);    }    for (i = 4; i < 6; i++) {      bits->C += CodeCoeff(Mode, qcoeff,i,ncoeffs);    }  }  else {    for (i = 0; i < 4; i++) {      if ((i==0 && CBP&32) || 	  (i==1 && CBP&16) ||	  (i==2 && CBP&8) || 	  (i==3 && CBP&4) || 	  (i==4 && CBP&2) ||	  (i==5 && CBP&1)) {	bits->Y += CodeCoeff(Mode, qcoeff, i, ncoeffs);      }    }    for (i = 4; i < 6; i++) {      if ((i==0 && CBP&32) || 	  (i==1 && CBP&16) ||	  (i==2 && CBP&8) || 	  (i==3 && CBP&4) || 	  (i==4 && CBP&2) ||	  (i==5 && CBP&1)) {	bits->C += CodeCoeff(Mode, qcoeff, i, ncoeffs);      }    }  }  return;}  int CodeCoeff(int Mode, int *qcoeff, int block, int ncoeffs){  int j, bits;  int prev_run, run, prev_level, level, first;  int prev_ind, ind, prev_s, s, length;  extern EHUFF *vlc_3d;  run = bits = 0;  first = 1;  prev_run = prev_level = prev_ind = level = s = prev_s = ind = 0;    for (j = block*ncoeffs; j< (block + 1)*ncoeffs; j++) {    /* Do this block's DC-coefficient first */    if (!(j%ncoeffs) && (Mode == MODE_INTRA)) {      /* DC coeff */      if (Global::trace) {	fprintf(Global::tf,"DC: ");      }      if (qcoeff[block*ncoeffs] != 128)	mputv(8,qcoeff[block*ncoeffs]);      else	mputv(8,255);      bits += 8;    }    else {      /* AC coeff */      s = 0;      /* Increment run if coeff is zero */      if ((level = qcoeff[j]) == 0) {	run++;      }      else {	/* code run & level and count bits */	if (level < 0) {	  s = 1;	  level = -level;	}	ind = level | run<<4;	ind = ind | 0<<12; /* Not last coeff */	if (!first) {	  /* Encode the previous ind */	  if (prev_level  < 13 && prev_run < 64) {	    length = Encode(prev_ind,vlc_3d);	  } else	    length = 0;	  if (length == 0) {  /* Escape coding */	    if (Global::trace) {	      fprintf(Global::tf,"Escape coding:\n");	    }	    if (prev_s == 1) {prev_level = (prev_level^0xff)+1;}	    Encode(ESCAPE,vlc_3d);	    mputv(1,0);	    mputv(6,prev_run);	    mputv(8,prev_level);	    bits += 22;	  }	  else {	    mputv(1,prev_s);	    bits += length + 1;	  }	}	prev_run = run; prev_s = s;	prev_level = level; prev_ind = ind;	run = first = 0;      }    }  }  /* Encode the last coeff */  if (!first) {    if (Global::trace) {      fprintf(Global::tf,"Last coeff: ");    }    prev_ind = prev_ind | 1<<12;   /* last coeff */    if (prev_level  < 13 && prev_run < 64) {       length = Encode(prev_ind,vlc_3d);    } else      length = 0;    if (length == 0) {  /* Escape coding */      if (Global::trace) {	fprintf(Global::tf,"Escape coding:\n");      }      if (prev_s == 1) {prev_level = (prev_level^0xff)+1;}      Encode(ESCAPE,vlc_3d);      mputv(1,1);      mputv(6,prev_run);      mputv(8,prev_level);      bits += 22;    }    else {      mputv(1,prev_s);      bits += length + 1;    }  }  return bits;} /********************************************************************** * *	Name:		FindCBP *	Description:	Finds the CBP for a macroblock *	 *	Input:		qcoeff and mode *			 *	Returns:	CBP *	Side effects:	 * *	Date: 940829	Author:	Karl.Lillevold@nta.no * ***********************************************************************/int FindCBP(int *qcoeff, int Mode, int ncoeffs){    int i,j;  int CBP = 0;				/* IF INTRABLOCK then intra =1 else 0 */  int intra = (Mode == MODE_INTRA);  /* Set CBP for this Macroblock */  for (i = 0; i < 6; i++) {				    /* First time i = 0: j = 0 ..64-1  set bit 5 if coeff != 0       Sec. time  i = 1; j = 64..128-1 set bit 4 if coeff != 0       */    /* OPTIMIZE: I think for i can be removed        and only values i=0 must be proessed */    for (j = i*ncoeffs + intra; j < (i+1)*ncoeffs; j++) {      if (qcoeff[j]) {	if (i == 0) {CBP |= 32;}	else if (i == 1) {CBP |= 16;}	else if (i == 2) {CBP |= 8;}	else if (i == 3) {CBP |= 4;}	else if (i == 4) {CBP |= 2;}	else if (i == 5) {CBP |= 1;}	else {	  fprintf(stderr,"Error in CBP assignment\n");	  exit(-1);	}	break;      }    }  }  return CBP;}void CountBitsVectors(MotionVector *MV_ptr, Bits *bits, 		      int x, int y, int Mode, int newgob, Pict *pic){  int y_vec, x_vec;  extern EHUFF *vlc_mv;  int pmv0, pmv1;  int start,stop,block;  MotionVector *MV_xy;  start = 0; stop = 0;  MV_xy = MV_ptr + y*Global::mbc + x;  for (block = start; block <= stop;  block++) {    FindPMV(MV_ptr,x,y,&pmv0,&pmv1, block, newgob, 1);    x_vec = (2*(*MV_xy).x + (*MV_xy).x_half) - pmv0;    y_vec = (2*(*MV_xy).y + (*MV_xy).y_half) - pmv1;    if (!Global::long_vectors) {      if (x_vec < -32) x_vec += 64;      else if (x_vec > 31) x_vec -= 64;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲美女淫视频| 精品精品国产高清一毛片一天堂| 看电视剧不卡顿的网站| 欧美三日本三级三级在线播放| 最新国产成人在线观看| 91网站最新地址| 亚洲精品免费在线播放| 欧美日韩一区在线观看| 美女被吸乳得到大胸91| 精品久久久久久久久久久院品网| 久久精品国产久精国产爱| 久久视频一区二区| thepron国产精品| 亚洲制服丝袜一区| 日韩精品一区二区三区中文精品| 国产一区亚洲一区| 亚洲久草在线视频| 7777精品伊人久久久大香线蕉完整版 | 精品视频999| 日韩一区精品字幕| 26uuu亚洲| 成熟亚洲日本毛茸茸凸凹| 亚洲精品国产视频| 欧美一区二区三区喷汁尤物| 国产美女精品一区二区三区| 国产精品灌醉下药二区| 欧美区在线观看| 国产a精品视频| 夜夜嗨av一区二区三区网页 | 国产精品456露脸| 亚洲欧美aⅴ...| 日韩一区二区三区三四区视频在线观看| 麻豆免费精品视频| 亚洲欧美偷拍另类a∨色屁股| 在线日韩一区二区| 国产在线精品一区二区不卡了| 亚洲人成网站在线| www国产成人免费观看视频 深夜成人网| gogo大胆日本视频一区| 秋霞影院一区二区| 综合久久国产九一剧情麻豆| 日韩免费福利电影在线观看| 色婷婷久久一区二区三区麻豆| 国内外精品视频| 香蕉成人啪国产精品视频综合网 | 亚洲国产成人av好男人在线观看| 久久久久久97三级| 制服视频三区第一页精品| 成人网页在线观看| 狠狠色丁香婷婷综合久久片| 亚洲第一搞黄网站| 最新久久zyz资源站| 26uuu精品一区二区三区四区在线| 欧美日韩亚洲综合在线 | 一区二区在线免费观看| 国产精品人人做人人爽人人添| 日韩欧美卡一卡二| 欧美日韩小视频| 一本色道综合亚洲| 99精品一区二区| 波多野结衣中文字幕一区二区三区| 久久99深爱久久99精品| 日本一不卡视频| 香蕉久久夜色精品国产使用方法 | 在线观看www91| 97se亚洲国产综合自在线| 国产成人福利片| 国产综合久久久久久鬼色| 男男视频亚洲欧美| 久久精品国内一区二区三区| 日本视频免费一区| 免费欧美高清视频| 琪琪久久久久日韩精品| 日韩电影在线看| 秋霞影院一区二区| 精品一区二区三区在线播放| 免费观看久久久4p| 日韩av午夜在线观看| 日本午夜一本久久久综合| 麻豆国产精品777777在线| 奇米影视7777精品一区二区| 免费看日韩a级影片| 久久99热这里只有精品| 精品一区在线看| 国产精一区二区三区| 成人av一区二区三区| 97久久精品人人做人人爽50路| 91麻豆国产自产在线观看| 欧美自拍偷拍午夜视频| 欧洲视频一区二区| 717成人午夜免费福利电影| 日韩一二在线观看| 久久精品水蜜桃av综合天堂| 中文字幕精品综合| 亚洲伊人色欲综合网| 视频一区视频二区在线观看| 久久99精品国产麻豆婷婷| 国产成人精品三级麻豆| 色综合久久精品| 337p亚洲精品色噜噜狠狠| 久久久久久久国产精品影院| 中文字幕在线一区| 亚洲资源在线观看| 美女一区二区三区| 97精品国产露脸对白| 欧美精品 国产精品| 久久久一区二区三区| 综合网在线视频| 裸体健美xxxx欧美裸体表演| 成人亚洲一区二区一| 在线观看视频欧美| 亚洲精品一区二区三区在线观看| 国产精品久久久久永久免费观看| 亚洲福利视频三区| 国产精品 日产精品 欧美精品| av网站免费线看精品| 91精品国产丝袜白色高跟鞋| 亚洲一线二线三线视频| 国产日韩一级二级三级| 国产一区二区三区在线观看精品| 欧美一区二区观看视频| 日韩电影免费一区| 亚洲欧洲精品成人久久奇米网| 色综合色综合色综合| 亚洲精品亚洲人成人网 | 亚洲综合区在线| 91精品国产91热久久久做人人| 一区二区三区中文在线观看| 日日噜噜夜夜狠狠视频欧美人| 国产精品911| 91精品婷婷国产综合久久竹菊| 国产日韩欧美电影| 日韩精品一二三区| a级高清视频欧美日韩| 日韩欧美激情在线| 亚洲一区二区五区| av午夜精品一区二区三区| 精品电影一区二区| 日日摸夜夜添夜夜添亚洲女人| 成人av午夜电影| 久久久精品2019中文字幕之3| 午夜精品国产更新| 色综合久久中文字幕| 国产精品美女久久久久av爽李琼| 日韩电影免费在线观看网站| 在线免费观看一区| 中文字幕中文在线不卡住| 国产乱子伦视频一区二区三区 | a级精品国产片在线观看| 精品少妇一区二区三区| 亚洲午夜羞羞片| 日本电影亚洲天堂一区| 亚洲欧美在线aaa| 粉嫩高潮美女一区二区三区 | 欧美日韩在线三级| 亚洲人成精品久久久久| eeuss鲁片一区二区三区| 国产日本亚洲高清| 国产成人综合在线播放| 久久尤物电影视频在线观看| 日韩国产精品久久久久久亚洲| 欧美日韩一区三区四区| 亚洲成人你懂的| 欧美三级一区二区| 亚洲国产一区二区在线播放| 欧美中文字幕一二三区视频| 一区二区三区中文字幕电影| 色婷婷精品久久二区二区蜜臀av| 亚洲三级在线播放| 91麻豆国产在线观看| 一区二区三区日本| 色婷婷av一区二区三区之一色屋| 亚洲免费在线看| 欧美性生活影院| 亚洲成av人片在www色猫咪| 欧美日韩综合不卡| 三级欧美韩日大片在线看| 欧美一区二区三区视频| 日韩精品福利网| 欧美成人精精品一区二区频| 国产一区二区免费看| 亚洲国产精品二十页| 91在线观看美女| 亚洲国产欧美另类丝袜| 91精品欧美久久久久久动漫 | 国产精品拍天天在线| 99久久伊人网影院| 一二三区精品视频| 日韩一区二区三区免费观看| 国产一区二区久久| 亚洲欧美另类久久久精品2019 | 91精品国产麻豆| 九九国产精品视频| 国产精品麻豆一区二区| 91丨九色丨蝌蚪富婆spa| 亚洲福利视频导航| 久久亚洲一级片| 色94色欧美sute亚洲13| 奇米色一区二区三区四区| 亚洲国产精品激情在线观看|