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

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

?? countbit.cpp

?? Netmeeting是Windows系統自帶的網上聊天軟件
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
////////////////////////////////////////////////////////////////////////////
//
//
//    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;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品一区二区三区影院| 亚洲靠逼com| 国产丝袜欧美中文另类| 国产精品成人一区二区艾草| 亚洲一区二区三区爽爽爽爽爽| 亚洲国产精品嫩草影院| 激情综合色综合久久综合| av综合在线播放| 欧美一区在线视频| 国产精品久久久久久久久晋中| 日韩中文字幕1| 成人高清视频在线| 日韩欧美亚洲另类制服综合在线| 中文字幕乱码亚洲精品一区| 日本vs亚洲vs韩国一区三区 | 国产麻豆成人精品| 91国偷自产一区二区三区成为亚洲经典 | 日韩欧美国产综合| 亚洲欧洲日本在线| 国产一区二区三区视频在线播放| 欧美少妇一区二区| 国产精品美女一区二区| 久久99精品久久久久久| 欧美日韩一级黄| 综合久久久久久| 国产盗摄精品一区二区三区在线| 欧美肥大bbwbbw高潮| 一区二区三区在线免费播放| 高清在线观看日韩| 精品免费视频.| 婷婷中文字幕综合| 欧美亚洲综合在线| 一区在线播放视频| 激情综合色丁香一区二区| 欧美日韩一区 二区 三区 久久精品| 精品奇米国产一区二区三区| 亚洲午夜一二三区视频| 一本在线高清不卡dvd| 最新国产成人在线观看| 成人avav在线| 国产精品久久毛片av大全日韩| 国产在线精品一区二区三区不卡| 欧洲生活片亚洲生活在线观看| 亚洲婷婷国产精品电影人久久| 丰满少妇在线播放bd日韩电影| 欧美精品一区二区三区一线天视频 | 精品国产一区二区三区忘忧草| 调教+趴+乳夹+国产+精品| 欧美最猛黑人xxxxx猛交| 亚洲精品福利视频网站| 91国偷自产一区二区使用方法| 国产婷婷色一区二区三区在线| 亚洲高清免费观看| 不卡的电影网站| 中文字幕中文字幕一区二区 | 国产精品国产三级国产专播品爱网 | 亚洲一区二区在线观看视频| 色婷婷综合久色| 一区二区三区在线视频免费| 欧美性一级生活| 五月婷婷综合网| 日韩一区二区在线看| 麻豆国产欧美一区二区三区| 久久综合五月天婷婷伊人| 国产呦精品一区二区三区网站| 国产日韩欧美在线一区| 成人av网址在线观看| 亚洲综合视频网| 日韩三级精品电影久久久| 国产成人一区二区精品非洲| 亚洲精品在线免费播放| 懂色av一区二区三区蜜臀| 国产精品久久精品日日| 欧美日韩在线播放一区| 蜜臀av性久久久久蜜臀aⅴ| 日韩一二三四区| 国模套图日韩精品一区二区| 国产欧美日韩不卡免费| 91视频www| 天堂成人国产精品一区| 国产日韩精品久久久| 91福利视频在线| 精品无码三级在线观看视频| 欧美国产乱子伦| 欧美视频精品在线观看| 国产精品白丝av| 一区二区成人在线观看| 欧美成人猛片aaaaaaa| 99综合影院在线| 日韩国产一区二| 亚洲色图色小说| 精品久久久久久久一区二区蜜臀| 99视频一区二区三区| 日韩主播视频在线| 国产精品的网站| 日韩午夜在线影院| 一本大道综合伊人精品热热| 久久国产人妖系列| 亚洲精品成a人| 久久先锋影音av鲁色资源| 欧美午夜精品久久久久久超碰| 天堂精品中文字幕在线| 国产精品私人影院| 欧美日韩精品系列| 国产精品亚洲第一区在线暖暖韩国 | 9人人澡人人爽人人精品| 久久国产视频网| 五月婷婷激情综合| 欧美国产精品劲爆| 91麻豆精品国产综合久久久久久| www.日韩在线| 国产精品一区二区三区乱码| 美女视频网站黄色亚洲| 亚洲精品大片www| 中文字幕日韩一区| 国产丝袜在线精品| 久久久一区二区三区捆绑**| 欧美一区2区视频在线观看| 91女厕偷拍女厕偷拍高清| 高清日韩电视剧大全免费| 国产精品一二三区在线| 国内一区二区在线| 久久91精品久久久久久秒播| 日韩经典中文字幕一区| 亚洲国产精品一区二区尤物区| 国产精品成人网| 日韩伦理av电影| 亚洲私人影院在线观看| 日韩伦理电影网| 亚洲黄色免费网站| 国产欧美一区在线| 国产午夜精品久久久久久免费视| 欧美大片在线观看一区二区| 欧美日韩高清一区二区不卡| 91污片在线观看| 一本色道久久综合亚洲精品按摩| av中文字幕在线不卡| 91视频.com| 欧美日韩一区高清| 欧美在线制服丝袜| 精品视频资源站| 欧美群妇大交群的观看方式| 欧美日韩一区二区在线观看视频| 欧美日韩一区在线| 欧美日韩在线免费视频| 欧美一区二区三区视频在线| 精品日产卡一卡二卡麻豆| 国产亚洲1区2区3区| 国产精品免费aⅴ片在线观看| 中文字幕制服丝袜一区二区三区 | 国产精品午夜久久| 亚洲三级久久久| 天堂资源在线中文精品| 久久国产精品99久久久久久老狼 | 欧美三级视频在线播放| 欧美一个色资源| 久久综合九色综合97_久久久| 欧美一激情一区二区三区| 国产精品三级电影| 国产精品久久久久毛片软件| 亚洲欧美日本韩国| 婷婷国产在线综合| 高清av一区二区| 欧美性一二三区| 久久久久久久久久久久久久久99| 国产精品久久久久久久久免费丝袜| 亚洲精品日韩综合观看成人91| 香蕉影视欧美成人| 国产成人亚洲精品青草天美| 欧美熟乱第一页| 日韩免费视频一区| 一区二区三区四区在线播放| 久久成人av少妇免费| 91精品福利视频| 亚洲精品在线免费播放| 亚洲免费观看高清完整版在线观看| 另类的小说在线视频另类成人小视频在线| 狠狠色丁香久久婷婷综合_中 | 亚洲在线视频网站| 国产精品亚洲一区二区三区妖精| 一本大道av一区二区在线播放| 日韩三级在线观看| 亚洲资源中文字幕| 男人的j进女人的j一区| eeuss鲁片一区二区三区| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 蜜臀av在线播放一区二区三区| 精品婷婷伊人一区三区三| 亚洲免费av观看| 91丝袜高跟美女视频| 国产精品私人自拍| 国产传媒日韩欧美成人| 久久一夜天堂av一区二区三区| 日本少妇一区二区| 欧美一区二区三区系列电影| 日韩精品亚洲专区| 这里只有精品电影| 麻豆一区二区三| 777奇米成人网| 蓝色福利精品导航|