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

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

?? countbit.c

?? H.263的壓縮算法
?? C
?? 第 1 頁 / 共 5 頁
字號:
/************************************************************************ * *  countbit.c, bitstream generation for tmn (TMN encoder) * *  Copyright (C) 1997  University of BC, Canada * *  Contacts:  *  Michael Gallant                   <mikeg@ee.ubc.ca> *  Guy Cote                          <guyc@ee.ubc.ca> *  Berna Erol                        <bernae@ee.ubc.ca> * *  UBC Image Processing Laboratory   http://www.ee.ubc.ca/image *  2356 Main Mall                    tel.: +1 604 822 4051 *  Vancouver BC Canada V6T1Z4        fax.: +1 604 822 5949 * *  Copyright (C) 1995, 1996  Telenor R&D, Norway * *  Contacts:  *  Robert Danielsen                  <Robert.Danielsen@nta.no> * *  Telenor Research and Development  http://www.nta.no/brukere/DVC/ *  P.O.Box 83                        tel.:   +47 63 84 84 00 *  N-2007 Kjeller, Norway            fax.:   +47 63 81 00 76 *   ************************************************************************//* Disclaimer of Warranty *  * These software programs are available to the user without any license fee * or royalty on an "as is" basis. The University of British Columbia * disclaims any and all warranties, whether express, implied, or * statuary, including any implied warranties or merchantability or of * fitness for a particular purpose.  In no event shall the * copyright-holder be liable for any incidental, punitive, or * consequential damages of any kind whatsoever arising from the use of * these programs. *  * This disclaimer of warranty extends to the user of these programs and * user's customers, employees, agents, transferees, successors, and * assigns. *  * The University of British Columbia does not represent or warrant that the * programs furnished hereunder are free of infringement of any * third-party patents. *  * Commercial implementations of H.263, including shareware, are subject to * royalty fees to patent holders.  Many of these patents are general * enough such that they are unavoidable regardless of implementation * design. *  */#include"sim.h"#include"sactbls.h"#include"indices.h"#include "putvlc.h"int arith_used = 0;int true_b_length[5][3] = { {0,2,4}, {3,3,5}, {3,3,5}, {5,5,5}, {6,7,9} };int true_b_code[5][3] = { {1,3,1}, {4,5,6}, {2,3,7}, {4,5,1}, {1,1,1} };int ei_length[4][4] = { {1,3,3,3}, {4,7,7,7}, {8,8,8,8}, {8,8,8,8} };int ei_code[4][4] = { {1,1,2,3}, {1,1,2,3}, {1,9,10,11}, {12,13,14,15} };int ep_length[4][3] = { {0,1,3}, {3,3,5}, {5,5,6}, {7,8,9} };int ep_code[4][3] = { {1,1,1}, {2,3,1}, {2,3,1}, {1,1,1} };/********************************************************************** * *	Name:        CountBitsMB *	Description:    counts bits used for MB info * *	Input:	        Mode, COD, CBP, Picture and Bits structures *	Returns: *	Side effects: * *	Date: 941129	Author: <klillevo@mailbox.jf.intel.com> * ***********************************************************************/void CountBitsMB (int Mode, int COD, int CBP, int CBPB, Pict * pic,                   Bits * bits, int scalability_prediction_type){  int cbpy, cbpcm, length;  int true_B_cbp_present = 0;  /* COD */  if (trace)  {    fprintf (tf, "MB-nr: %d\n", pic->MB);    if (pic->picture_coding_type == PCT_INTER ||        pic->picture_coding_type == PCT_IPB   ||        pic->picture_coding_type == PCT_PB)      fprintf (tf, "  COD: %d\n", COD);  }  if (pic->picture_coding_type == PCT_INTER ||      pic->picture_coding_type == PCT_IPB   ||      pic->picture_coding_type == PCT_PB )  {    putbits (1, COD);    bits->COD++;  }  if (COD)    return;                     /* not coded */  /* CBPCM */  cbpcm = Mode | ((CBP & 3) << 4);  if (trace)  {    fprintf (tf, "CBPCM (CBP=%d) (cbpcm=%d): ", CBP, cbpcm);  }  if (pic->picture_coding_type == PCT_INTRA)    length = put_cbpcm_intra (CBP, Mode);  else     length = put_cbpcm_inter (CBP, Mode);  bits->CBPCM += length;  /* INTRA_MODE when advanced intra coding mode is used */  if ((advanced_intra_coding) && (Mode == MODE_INTRA || Mode == MODE_INTRA_Q))  {    if (trace)      fprintf (tf, "INTRA_MODE: ");    if (pic->Intra_Mode)    {      /* length is two bits */      putbits (2, pic->Intra_Mode);      bits->INTRA_MODE += 2;    } else    {      /* length is one bit */      putbits (1, pic->Intra_Mode);      bits->INTRA_MODE++;    }  }  /* MODB & CBPB */  if (pic->PB == PB_FRAMES)  {    switch (pic->MODB)    {      case PBMODE_NORMAL:        putbits (1, 0);        bits->MODB += 1;        break;      case PBMODE_MVDB:        putbits (2, 2);        bits->MODB += 2;        break;      case PBMODE_CBPB_MVDB:        putbits (2, 3);        bits->MODB += 2;        /* CBPB */        putbits (6, CBPB);        bits->CBPB += 6;        break;    }    if (trace)    {      fprintf (tf, "MODB: %d, CBPB: %d\n", pic->MODB, CBPB);    }  }  if (pic->PB == IM_PB_FRAMES)  {    switch (pic->MODB)    {      case PBMODE_BIDIR_PRED:        putbits (1, 0);        bits->MODB += 1;        break;      case PBMODE_CBPB_BIDIR_PRED:        putbits (2, 2);        bits->MODB += 2;        /* CBPB */        putbits (6, CBPB);        bits->CBPB += 6;        break;      case PBMODE_FRW_PRED:        putbits (3, 6);        bits->MODB += 3;        break;      case PBMODE_CBPB_FRW_PRED:        putbits (4, 14);        bits->MODB += 4;        /* CBPB */        putbits (6, CBPB);        bits->CBPB += 6;        break;      case PBMODE_BCKW_PRED:        putbits (5, 30);        bits->MODB += 5;        break;      case PBMODE_CBPB_BCKW_PRED:        putbits (5, 31);        bits->MODB += 5;        /* CBPB */        putbits (6, CBPB);        bits->CBPB += 6;        break;    }    if (trace)    {      fprintf (tf, "MODB: %d, CBPB: %d\n", pic->MODB, CBPB);    }  }  /* CBPY */  cbpy = CBP >> 2;  /* Intra. */  if (Mode == MODE_INTRA || Mode == MODE_INTRA_Q)    cbpy = cbpy ^ 15;  else if (alternative_inter_vlc && ((CBP & 3) == 3))     cbpy = cbpy ^ 15;  if (trace)  {    fprintf (tf, "CBPY (CBP=%d) (cbpy=%d): ", CBP, cbpy);  }  length = put_cbpy (CBP, Mode);  bits->CBPY += length;  /* DQUANT */  if ((Mode == MODE_INTER_Q) || (Mode == MODE_INTRA_Q)     || (Mode == MODE_INTER4V_Q))  {    if (trace)    {      fprintf (tf, "DQUANT: %d\n ",pic->DQUANT);    }    if (!modified_quantization)    {      switch (pic->DQUANT)      {        case -1:          putbits (2, 0);          break;        case -2:          putbits (2, 1);          break;        case 1:          putbits (2, 2);          break;        case 2:          putbits (2, 3);          break;        default:          fprintf (stderr, "Invalid DQUANT\n");          exit (-1);      }      bits->DQUANT += 2;    }    else    {      /* modified quantization mode, dquant take any value between 0 and       * 31 */      if (pic->dquant_size == 2)      {        putbits (2, pic->DQUANT);        bits->DQUANT += 2;      } else      {        /* DQUANT will be coded into 6 bits */        putbits (1, 0);        putbits (5, pic->DQUANT);        bits->DQUANT += 6;      }    }  }  return;}/********************************************************************** * *	Name:         CountBitsScalMB *	Description:  counts bits used for EI, EP, and B MB info * *	Input:	      Mode, COD, CBP, Picture and Bits structures *	Returns: *	Side effects: * *	Date: 970831  Author: Michael Gallant <mikeg@ee.ubc.ca> * ***********************************************************************/void CountBitsScalMB (int Mode, int COD, int CBP, int CBPB, Pict * pic,                      Bits * bits, int scalability_prediction_type,                      int MV_present){  int cbpy, cbpcm, length, code;  int cbp_present = 0;  int param = 0;  /* COD */  if (trace)  {    fprintf (tf, "MB-nr: %d", pic->MB);    fprintf (tf, "  COD: %d\n", COD);  }  putbits (1, COD);  bits->COD++;  if (COD)    return;                     /* not coded */  /* MBTYPE */  if (trace)  {    fprintf (tf, "MBTYPE: ");  }  switch (pic->picture_coding_type)  {    case PCT_B:      if (B_INTRA_PREDICTION != scalability_prediction_type)      {        if (pic->DQUANT)          param = 2;        else          param = ((CBP) ? 1 : 0);      }      else      {        if (pic->DQUANT)          param = 1;        else          param = 0;      }      length = true_b_length[scalability_prediction_type][param];      code = true_b_code[scalability_prediction_type][param];      break;    case PCT_EI:      length = ei_length[scalability_prediction_type<<1+((pic->DQUANT) ? 1:0)][CBP&3];      code = ei_code[scalability_prediction_type<<1+((pic->DQUANT) ? 1:0)][CBP&3];      break;    case PCT_EP:      if (EP_INTRA_PREDICTION != scalability_prediction_type)      {        param += (CBP || MV_present) ? 1 : 0;      }      param += (pic->DQUANT) ? 1 : 0;      if (MV_present)      {        cbp_present = 1;      }      length = ep_length[scalability_prediction_type][param];      code = ep_code[scalability_prediction_type][param];      break;    default:      break;  }  putbits(length, code);  if ( (PCT_EI != pic->picture_coding_type) &&        (MODE_INTRA == Mode || MODE_INTRA_Q == Mode || 0 != CBP ||          ( (PCT_B == pic->picture_coding_type) && (pic->DQUANT) ) ) )  {    cbp_present = 1;  }   /* INTRA_MODE when advanced intra coding mode is used */  if ((advanced_intra_coding) && (Mode == MODE_INTRA || Mode == MODE_INTRA_Q))  {    if (trace)      fprintf (tf, "INTRA_MODE: ");    if (pic->Intra_Mode)    {      /* length is two bits */      putbits (2, pic->Intra_Mode);      bits->INTRA_MODE += 2;    }     else    {      /* length is one bit */      putbits (1, pic->Intra_Mode);      bits->INTRA_MODE++;    }  }  /* Coded Block Patterns. */  if (cbp_present)  {    cbpcm = (CBP & 3);    if (trace)    {      fprintf (tf, "CBPC: ");    }    if (0 == cbpcm)    {      putbits (1, 0);      bits->CBPCM += 1;    }     else if (1 == cbpcm)    {      putbits (2, 2);      bits->CBPCM += 2;    }     else if (2 == cbpcm)    {      putbits (3, 7);      bits->CBPCM += 3;    }     else    {      putbits (3, 6);      bits->CBPCM += 3;    }  }  if (cbp_present || (PCT_EI == pic->picture_coding_type) )  {    cbpy = CBP >> 2;    if (trace)    {      fprintf (tf, "CBPY: ");    }    if ( (MODE_INTRA == Mode || MODE_INTRA_Q == Mode) ||         (PCT_EI == pic->picture_coding_type && EI_UPWARD_PREDICTION == scalability_prediction_type) ||         (PCT_EP == pic->picture_coding_type &&           (EP_UPWARD_PREDICTION == scalability_prediction_type ||            EP_BIDIRECTIONAL_PREDICTION == scalability_prediction_type) ) )    {      length = put_cbpy (CBP, MODE_INTRA);      bits->CBPY += length;    }    else if (alternative_inter_vlc && (3 == cbpcm) )    {      length = put_cbpy (CBP, MODE_INTRA);      bits->CBPY += length;    }    else    {      length = put_cbpy (CBP, MODE_INTER);      bits->CBPY += length;    }  }  /* DQUANT */  if ((Mode == MODE_INTER_Q) || (Mode == MODE_INTRA_Q) || (Mode == MODE_INTER4V_Q))  {    if (trace)    {      fprintf (tf, "DQUANT: %d\n ",pic->DQUANT);    }    if (!modified_quantization)    {      switch (pic->DQUANT)      {        case -1:          putbits (2, 0);          break;        case -2:          putbits (2, 1);          break;        case 1:          putbits (2, 2);          break;        case 2:          putbits (2, 3);          break;        default:          fprintf (stderr, "Invalid DQUANT\n");          exit (-1);      }      bits->DQUANT += 2;    }     else    {      /* modified quantization mode, dquant take any value between 0 and       * 31 */      if (pic->dquant_size == 2)      {        putbits (2, pic->DQUANT);        bits->DQUANT += 2;      }       else      {        /* DQUANT will be coded into 6 bits */        putbits (1, 0);        putbits (5, pic->DQUANT);        bits->DQUANT += 6;      }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品国产亚洲一区二区三区| 亚洲欧美另类综合偷拍| 免费成人在线观看| 日韩午夜电影在线观看| 精品中文字幕一区二区小辣椒| 精品久久一二三区| 国产在线播放一区二区三区| 国产欧美日产一区| 色婷婷久久久久swag精品 | 色综合久久中文综合久久97| 亚洲免费观看高清完整版在线观看熊 | 欧美日韩一区二区在线视频| 秋霞电影网一区二区| 精品国产91乱码一区二区三区 | 亚洲欧美日韩国产中文在线| 欧美午夜理伦三级在线观看| 日韩综合在线视频| 国产婷婷色一区二区三区在线| heyzo一本久久综合| 亚洲一区二区3| 精品日韩欧美在线| 成人av在线一区二区三区| 亚洲国产婷婷综合在线精品| 日韩欧美的一区| 91丨porny丨国产入口| 日韩黄色一级片| 欧美韩国日本不卡| 欧美日韩国产色站一区二区三区| 国内久久婷婷综合| 亚洲卡通动漫在线| 久久综合久久99| 91成人在线观看喷潮| 精品午夜一区二区三区在线观看| 国产精品国产三级国产a | 精品日韩在线一区| 色婷婷av一区二区三区软件| 精品伊人久久久久7777人| 日韩美女视频19| 亚洲精品在线免费观看视频| 91福利资源站| 国产suv精品一区二区6| 日韩福利视频网| 国产精品久久久久aaaa樱花 | 亚洲色图视频网站| 欧美成人一级视频| 日本高清不卡aⅴ免费网站| 视频一区视频二区中文字幕| 中文字幕永久在线不卡| 精品av久久707| 91麻豆精品国产自产在线| 94色蜜桃网一区二区三区| 紧缚奴在线一区二区三区| 五月天激情综合网| 亚洲精品日韩专区silk| 国产蜜臀av在线一区二区三区| 欧美一区二区三区在线看 | 欧美挠脚心视频网站| 波波电影院一区二区三区| 精品一二三四区| 蜜桃av一区二区| 日韩av不卡在线观看| 一卡二卡三卡日韩欧美| 亚洲人妖av一区二区| 欧美国产禁国产网站cc| 337p日本欧洲亚洲大胆精品| 欧美一区二视频| 欧美日韩日本视频| 欧美伊人精品成人久久综合97 | 国产乱人伦偷精品视频免下载 | 国产精品1区2区3区在线观看| 日韩电影免费在线观看网站| 亚州成人在线电影| 亚洲国产精品影院| 亚洲国产另类精品专区| 一区二区三区中文字幕精品精品| 亚洲视频网在线直播| 亚洲欧洲美洲综合色网| 国产精品麻豆视频| 国产精品不卡一区| 亚洲伦理在线免费看| 亚洲精品视频观看| 午夜精品福利在线| 亚洲bdsm女犯bdsm网站| 午夜精品一区在线观看| 日韩黄色小视频| 精品在线播放免费| 高清不卡一区二区| 91丨九色porny丨蝌蚪| 亚洲日本丝袜连裤袜办公室| 欧美最猛性xxxxx直播| 99久久久精品| 在线视频亚洲一区| 欧美精品vⅰdeose4hd| 日韩一级高清毛片| 久久久久久麻豆| 亚洲欧洲av在线| 伊人婷婷欧美激情| 人人爽香蕉精品| 国产在线播精品第三| 99久久精品一区二区| 欧美日韩三级在线| 2020国产精品自拍| 亚洲欧洲av一区二区三区久久| 亚洲成人在线免费| 精品一区二区三区在线观看| 成人久久久精品乱码一区二区三区| 99re亚洲国产精品| 3atv在线一区二区三区| 国产农村妇女毛片精品久久麻豆| 综合婷婷亚洲小说| 日本不卡一二三| 丁香婷婷综合网| 欧美日韩免费高清一区色橹橹 | 国产美女视频一区| 91热门视频在线观看| 4438x成人网最大色成网站| 国产亚洲成aⅴ人片在线观看| 亚洲欧美另类小说视频| 人人狠狠综合久久亚洲| 99视频在线精品| 亚洲成av人影院| 国产盗摄女厕一区二区三区| 色综合天天视频在线观看| 日韩精品中文字幕一区| 亚洲欧美日韩电影| 老司机精品视频导航| 日本韩国欧美在线| 久久人人爽爽爽人久久久| 亚洲一区二区av在线| 国产成人精品一区二区三区网站观看| 欧美亚洲图片小说| 国产人成亚洲第一网站在线播放| 亚洲成人免费在线| av激情综合网| 久久人人97超碰com| 日韩激情一区二区| 91女神在线视频| 国产午夜精品理论片a级大结局| 午夜精品在线看| 91在线国产福利| 欧美国产日本视频| 国产综合久久久久影院| 4438x亚洲最大成人网| 亚洲免费视频成人| 成人激情视频网站| 久久久精品中文字幕麻豆发布| 天天综合天天综合色| 一本一本大道香蕉久在线精品| 久久久久国产精品麻豆| 激情六月婷婷久久| 91精品在线免费观看| 亚洲成人av福利| 在线观看欧美黄色| 亚洲免费在线视频一区 二区| 国产91丝袜在线播放| 欧美精品一区二区在线播放| 日本在线播放一区二区三区| 欧美日韩在线播放三区| 亚洲制服欧美中文字幕中文字幕| 99视频在线观看一区三区| 国产精品免费视频观看| 岛国精品在线观看| 久久久影视传媒| 国产精品99久久久久久久女警 | 成人av在线资源| 中文字幕+乱码+中文字幕一区| 国产一区二区电影| 久久影视一区二区| 国产精品资源网| 中文乱码免费一区二区| 成人av电影免费观看| 国产精品毛片大码女人| 91视频一区二区| 亚洲综合免费观看高清完整版| 色香蕉久久蜜桃| 午夜视频一区二区| 欧美一区二视频| 韩国成人在线视频| 国产欧美精品国产国产专区| 波多野结衣中文一区| 亚洲天天做日日做天天谢日日欢| 91一区二区在线观看| 亚洲一区二区在线观看视频| 欧美日韩精品欧美日韩精品| 免费看欧美美女黄的网站| 精品奇米国产一区二区三区| 国产风韵犹存在线视精品| 国产精品成人免费精品自在线观看 | 日韩欧美不卡在线观看视频| 精品夜夜嗨av一区二区三区| 中文一区二区在线观看| 色94色欧美sute亚洲线路二 | 91浏览器在线视频| 丰满亚洲少妇av| 亚洲国产一区二区在线播放| 日韩欧美一区二区不卡| 国产91丝袜在线播放九色| 一区二区三区不卡视频| 欧美一区二区免费观在线| 国产不卡在线视频|