亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
日韩欧美国产一区二区在线播放| 国产蜜臀av在线一区二区三区| 日韩区在线观看| 国产精品国产三级国产aⅴ中文| 亚洲影视在线播放| 精品一区二区日韩| 欧美天堂一区二区三区| 国产欧美精品一区二区色综合朱莉| 一个色妞综合视频在线观看| 大尺度一区二区| 欧美久久久久免费| 亚洲啪啪综合av一区二区三区| 狠狠色综合播放一区二区| 欧美日韩一区三区四区| 国产精品美女www爽爽爽| 久久99久久精品欧美| 欧美日韩你懂的| 亚洲免费高清视频在线| 成人免费av网站| 久久久久高清精品| 精品一区二区三区在线视频| 欧美日本在线播放| 亚洲国产欧美在线| 色综合色综合色综合色综合色综合| 精品国产91乱码一区二区三区 | 欧洲色大大久久| 国产精品女主播在线观看| 国产一区二区视频在线播放| 欧美一区二区不卡视频| 五月婷婷另类国产| 欧美日韩三级视频| 肉色丝袜一区二区| 欧美精品视频www在线观看 | 欧美r级电影在线观看| 婷婷久久综合九色国产成人| 欧美日韩一区不卡| 天堂一区二区在线免费观看| 欧美蜜桃一区二区三区| 视频一区国产视频| 日韩视频在线你懂得| 久国产精品韩国三级视频| 日韩欧美亚洲另类制服综合在线| 全部av―极品视觉盛宴亚洲| 日韩三区在线观看| 精品一区二区三区在线观看国产 | 日本色综合中文字幕| 9191精品国产综合久久久久久| 天天做天天摸天天爽国产一区| 欧美性做爰猛烈叫床潮| 日韩精品一级中文字幕精品视频免费观看| 欧美最新大片在线看| 视频在线在亚洲| 欧美电视剧在线看免费| 国产精品一区二区在线播放| 国产日本欧洲亚洲| 在线一区二区视频| 人人精品人人爱| 国产欧美日韩麻豆91| 91理论电影在线观看| 午夜免费欧美电影| 久久久亚洲精华液精华液精华液| 成人av先锋影音| 日韩在线播放一区二区| 久久久久国产精品麻豆| 91福利视频网站| 麻豆国产一区二区| 亚洲欧洲日产国码二区| 在线播放一区二区三区| 国产91在线看| 午夜精品久久久久久久久久| 久久精品视频一区二区| 色婷婷国产精品综合在线观看| 日韩中文欧美在线| 国产精品视频一区二区三区不卡| 欧美日韩亚洲综合在线| 国产乱码精品一区二区三区av| 亚洲激情五月婷婷| www国产成人免费观看视频 深夜成人网 | 国产精品亲子乱子伦xxxx裸| 欧美精品自拍偷拍动漫精品| 成人免费的视频| 七七婷婷婷婷精品国产| 亚洲色图.com| www一区二区| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲欧美激情在线| 欧美精品一区二区久久久| 欧美在线free| av中文字幕不卡| 久久99这里只有精品| 亚洲国产精品一区二区www在线| 久久女同性恋中文字幕| 91麻豆精品国产91久久久久| 色偷偷成人一区二区三区91| 春色校园综合激情亚洲| 久久精品国产第一区二区三区| 亚洲视频在线一区观看| 久久久久久久性| 日韩欧美的一区| 欧美日本一道本| 欧美怡红院视频| 91丨porny丨最新| 不卡av在线网| 国产98色在线|日韩| 国产精品1区2区3区| 久久 天天综合| 久久er99热精品一区二区| 亚洲国产成人av| 亚洲国产另类av| 亚洲一级不卡视频| 亚洲最大成人网4388xx| 亚洲少妇最新在线视频| 成人欧美一区二区三区视频网页| 欧美激情一区二区三区在线| 久久女同精品一区二区| 2021久久国产精品不只是精品| 日韩免费性生活视频播放| 日韩一区和二区| 欧美v国产在线一区二区三区| 日韩三级中文字幕| 亚洲精品在线网站| 国产午夜三级一区二区三| 国产日韩综合av| 国产精品免费视频观看| 中文字幕不卡一区| 亚洲女人****多毛耸耸8| 自拍偷拍亚洲欧美日韩| 亚洲激情图片qvod| 亚洲国产三级在线| 日本不卡视频在线| 国产一区在线精品| 国产91对白在线观看九色| av一区二区三区在线| 国产成人av影院| 正在播放亚洲一区| 欧美日本国产视频| 欧美日韩国产精选| 日韩精品一区二区在线观看| 亚洲一区日韩精品中文字幕| 欧美日韩高清一区二区三区| 欧美一级欧美三级在线观看| 国产精品18久久久久久久久 | 亚洲福利视频三区| 成人午夜精品在线| 欧美大片在线观看一区二区| 亚洲国产综合视频在线观看| 国产成人精品影视| 欧美成人高清电影在线| 亚洲第一狼人社区| 色狠狠色狠狠综合| **欧美大码日韩| 国产999精品久久久久久绿帽| 日韩女优毛片在线| 无吗不卡中文字幕| 在线欧美小视频| 亚洲视频一区二区在线观看| 成人永久免费视频| 欧美精品一区在线观看| 蜜臀国产一区二区三区在线播放 | 欧洲色大大久久| 亚洲欧美日韩中文播放| 成人黄色小视频| 国产欧美日韩视频在线观看| 国内不卡的二区三区中文字幕 | 视频一区国产视频| 欧美老女人第四色| 亚洲.国产.中文慕字在线| 91久久精品日日躁夜夜躁欧美| 亚洲情趣在线观看| 国产成人av电影在线| 久久蜜桃av一区精品变态类天堂 | 日本伊人色综合网| 欧美精品乱码久久久久久按摩| 亚洲一区二区av在线| 欧美日韩视频在线第一区 | 国产成人综合视频| 久久久精品黄色| 国产精品91一区二区| 国产欧美日韩精品一区| 成人福利视频在线看| 亚洲人成亚洲人成在线观看图片| 成人av资源下载| 豆国产96在线|亚洲| 国产精品久久久久影院| 99久久精品免费看| 亚洲伊人色欲综合网| 宅男在线国产精品| 国内精品久久久久影院色| 欧美激情资源网| 一本色道**综合亚洲精品蜜桃冫| 亚洲乱码国产乱码精品精的特点| 欧美亚洲国产一区二区三区va| 亚洲va国产va欧美va观看| 欧美一区二区精品| 国产精品一区二区久久精品爱涩 | 欧美一区二区视频观看视频| 久久精品国产第一区二区三区| 国产日韩欧美麻豆| 在线视频欧美区| 麻豆91免费观看|