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

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

?? layer3.c

?? 音頻編碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
         gr_infos->pow2gain += 2;       gr_infos->scalefac_compress = getbits(mp,9);/* window-switching flag == 1 for block_Type != 0 .. and block-type == 0 -> win-sw-flag = 0 */       if(get1bit(mp))        {         int i;         gr_infos->block_type = getbits_fast(mp,2);         gr_infos->mixed_block_flag = get1bit(mp);         gr_infos->table_select[0] = getbits_fast(mp,5);         gr_infos->table_select[1] = getbits_fast(mp,5);         /*          * table_select[2] not needed, because there is no region2,          * but to satisfy some verifications tools we set it either.          */         gr_infos->table_select[2] = 0;         for(i=0;i<3;i++) {	   unsigned int sbg = (getbits_fast(mp,3)<<3);           gr_infos->full_gain[i] = gr_infos->pow2gain + sbg;#ifndef NOANALYSIS	   if (mpg123_pinfo!=NULL)	     mpg123_pinfo->sub_gain[0][ch][i]=sbg/8;#endif	 }         if(gr_infos->block_type == 0) {           fprintf(stderr,"Blocktype == 0 and window-switching == 1 not allowed.\n");		   /* error seems to be very good recoverable, so don't exit */           /* exit(1); */         }         /* region_count/start parameters are implicit in this case. */       /* check this again! */         if(gr_infos->block_type == 2) {            if (sfreq == 8)                gr_infos->region1start = 36;            else                gr_infos->region1start = 36>>1;         }         else if(sfreq == 8)/* check this for 2.5 and sfreq=8 */           gr_infos->region1start = 108>>1;         else           gr_infos->region1start = 54>>1;         gr_infos->region2start = 576>>1;       }       else        {         int i,r0c,r1c;         for (i=0; i<3; i++)           gr_infos->table_select[i] = getbits_fast(mp,5);         r0c = getbits_fast(mp,4);         r1c = getbits_fast(mp,3);         gr_infos->region1start = bandInfo[sfreq].longIdx[r0c+1] >> 1 ;         gr_infos->region2start = bandInfo[sfreq].longIdx[r0c+1+r1c+1] >> 1;         gr_infos->block_type = 0;         gr_infos->mixed_block_flag = 0;       }       gr_infos->scalefac_scale = get1bit(mp);       gr_infos->count1table_select = get1bit(mp);   }}/* * read scalefactors */static intIII_get_scale_factors_1(PMPSTR mp, int *scf,struct gr_info_s *gr_infos){   static const unsigned char slen[2][16] = {     {0, 0, 0, 0, 3, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4},     {0, 1, 2, 3, 0, 1, 2, 3, 1, 2, 3, 1, 2, 3, 2, 3}   };   int numbits;   int num0 = slen[0][gr_infos->scalefac_compress];   int num1 = slen[1][gr_infos->scalefac_compress];    if (gr_infos->block_type == 2)     {      int i=18;      numbits = (num0 + num1) * 18;      if (gr_infos->mixed_block_flag) {         for (i=8;i;i--)           *scf++ = getbits_fast(mp,num0);         i = 9;         numbits -= num0; /* num0 * 17 + num1 * 18 */      }      for (;i;i--)        *scf++ = getbits_fast(mp,num0);      for (i = 18; i; i--)        *scf++ = getbits_fast(mp,num1);      *scf++ = 0; *scf++ = 0; *scf++ = 0; /* short[13][0..2] = 0 */    }    else     {      int i;      int scfsi = gr_infos->scfsi;      if(scfsi < 0) { /* scfsi < 0 => granule == 0 */         for(i=11;i;i--)           *scf++ = getbits_fast(mp,num0);         for(i=10;i;i--)           *scf++ = getbits_fast(mp,num1);         numbits = (num0 + num1) * 10 + num0;      }      else {        numbits = 0;        if(!(scfsi & 0x8)) {          for (i=6;i;i--)            *scf++ = getbits_fast(mp,num0);          numbits += num0 * 6;        }        else {          scf += 6;        }        if(!(scfsi & 0x4)) {          for (i=5;i;i--)            *scf++ = getbits_fast(mp,num0);          numbits += num0 * 5;        }        else {          scf += 5;        }        if(!(scfsi & 0x2)) {          for(i=5;i;i--)            *scf++ = getbits_fast(mp,num1);          numbits += num1 * 5;        }        else {          scf += 5;        }        if(!(scfsi & 0x1)) {          for (i=5;i;i--)            *scf++ = getbits_fast(mp,num1);          numbits += num1 * 5;        }        else {          scf += 5;        }      }      *scf++ = 0;  /* no l[21] in original sources */    }    return numbits;}static intIII_get_scale_factors_2(PMPSTR mp, int *scf,struct gr_info_s *gr_infos,int i_stereo){  unsigned char *pnt;  int i,j;  unsigned int slen;  int n = 0;  int numbits = 0;  static const unsigned char stab[3][6][4] = {   { { 6, 5, 5,5 } , { 6, 5, 7,3 } , { 11,10,0,0} ,     { 7, 7, 7,0 } , { 6, 6, 6,3 } , {  8, 8,5,0} } ,   { { 9, 9, 9,9 } , { 9, 9,12,6 } , { 18,18,0,0} ,     {12,12,12,0 } , {12, 9, 9,6 } , { 15,12,9,0} } ,   { { 6, 9, 9,9 } , { 6, 9,12,6 } , { 15,18,0,0} ,     { 6,15,12,0 } , { 6,12, 9,6 } , {  6,18,9,0} } };   if(i_stereo) /* i_stereo AND second channel -> do_layer3() checks this */    slen = i_slen2[gr_infos->scalefac_compress>>1];  else    slen = n_slen2[gr_infos->scalefac_compress];  gr_infos->preflag = (slen>>15) & 0x1;  n = 0;    if( gr_infos->block_type == 2 ) {    n++;    if(gr_infos->mixed_block_flag)      n++;  }  pnt = (unsigned char *)stab[n][(slen>>12)&0x7];  for(i=0;i<4;i++) {    int num = slen & 0x7;    slen >>= 3;    if(num) {      for(j=0;j<(int)(pnt[i]);j++)        *scf++ = getbits_fast(mp,num);      numbits += pnt[i] * num;    }    else {      for(j=0;j<(int)(pnt[i]);j++)        *scf++ = 0;    }  }    n = (n << 1) + 1;  for(i=0;i<n;i++)    *scf++ = 0;  return numbits;}static const int pretab1 [22] = {0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,2,2,3,3,3,2,0}; /* char enough ? */static const int pretab2 [22] = {0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};/* * don't forget to apply the same changes to III_dequantize_sample_ms() !!!  */static int III_dequantize_sample(PMPSTR mp, real xr[SBLIMIT][SSLIMIT],int *scf,   struct gr_info_s *gr_infos,int sfreq,int part2bits){  int shift = 1 + gr_infos->scalefac_scale;  real *xrpnt = (real *) xr;  int l[3],l3;  int part2remain = gr_infos->part2_3_length - part2bits;  int *me;  {    int i;        for(i=(&xr[SBLIMIT][0]-xrpnt)>>1;i>0;i--) {      *xrpnt++ = 0.0;      *xrpnt++ = 0.0;    }    xrpnt = (real *) xr;  }  {    int bv       = gr_infos->big_values;    int region1  = gr_infos->region1start;    int region2  = gr_infos->region2start;    l3 = ((576>>1)-bv)>>1;   /* * we may lose the 'odd' bit here !!  * check this later again  */    if(bv <= region1) {      l[0] = bv; l[1] = 0; l[2] = 0;    }    else {      l[0] = region1;      if(bv <= region2) {        l[1] = bv - l[0];  l[2] = 0;      }      else {        l[1] = region2 - l[0]; l[2] = bv - region2;      }    }  }  /* MDH crash fix */  {      int i;      for (i = 0; i < 3; i++) {	  if (l[i] < 0) {	      fprintf(stderr, "mpg123: Bogus region length (%d)\n", l[i]);	      l[i] = 0;	  }      }  }  /* end MDH crash fix */  if(gr_infos->block_type == 2) {    /*     * decoding with short or mixed mode BandIndex table      */    int i,max[4];    int step=0,lwin=0,cb=0;    real v = 0.0;    int *m,mc;    if(gr_infos->mixed_block_flag) {      max[3] = -1;      max[0] = max[1] = max[2] = 2;      m = map[sfreq][0];      me = mapend[sfreq][0];    }    else {      max[0] = max[1] = max[2] = max[3] = -1;      /* max[3] not really needed in this case */      m = map[sfreq][1];      me = mapend[sfreq][1];    }    mc = 0;    for(i=0;i<2;i++) {      int lp = l[i];      struct newhuff *h = (struct newhuff *)(ht+gr_infos->table_select[i]);      for(;lp;lp--,mc--) {        int x,y;        if( (!mc) ) {          mc = *m++;          xrpnt = ((real *) xr) + (*m++);          lwin = *m++;          cb = *m++;          if(lwin == 3) {            v = gr_infos->pow2gain[(*scf++) << shift];            step = 1;          }          else {            v = gr_infos->full_gain[lwin][(*scf++) << shift];            step = 3;          }        }        {          short *val = (short *)h->table;          while((y=*val++)<0) {            if (get1bit(mp))              val -= y;            part2remain--;          }          x = y >> 4;          y &= 0xf;        }        if(x == 15) {          max[lwin] = cb;          part2remain -= h->linbits+1;          x += getbits(mp,(int)h->linbits);          if(get1bit(mp))            *xrpnt = -ispow[x] * v;          else            *xrpnt =  ispow[x] * v;        }        else if(x) {          max[lwin] = cb;          if(get1bit(mp))            *xrpnt = -ispow[x] * v;          else            *xrpnt =  ispow[x] * v;          part2remain--;        }        else          *xrpnt = 0.0;        xrpnt += step;        if(y == 15) {          max[lwin] = cb;          part2remain -= h->linbits+1;          y += getbits(mp,(int)h->linbits);          if(get1bit(mp))            *xrpnt = -ispow[y] * v;          else            *xrpnt =  ispow[y] * v;        }        else if(y) {          max[lwin] = cb;          if(get1bit(mp))            *xrpnt = -ispow[y] * v;          else            *xrpnt =  ispow[y] * v;          part2remain--;        }        else          *xrpnt = 0.0;        xrpnt += step;      }    }    for(;l3 && (part2remain > 0);l3--) {      struct newhuff *h = (struct newhuff *)(htc+gr_infos->count1table_select);      short *val = (short *)h->table,a;      while((a=*val++)<0) {        part2remain--;        if(part2remain < 0) {          part2remain++;          a = 0;          break;        }        if (get1bit(mp))          val -= a;      }      for(i=0;i<4;i++) {        if(!(i & 1)) {          if(!mc) {            mc = *m++;            xrpnt = ((real *) xr) + (*m++);            lwin = *m++;            cb = *m++;            if(lwin == 3) {              v = gr_infos->pow2gain[(*scf++) << shift];              step = 1;            }            else {              v = gr_infos->full_gain[lwin][(*scf++) << shift];              step = 3;            }          }          mc--;        }        if( (a & (0x8>>i)) ) {          max[lwin] = cb;          part2remain--;          if(part2remain < 0) {            part2remain++;            break;          }          if(get1bit(mp))             *xrpnt = -v;          else            *xrpnt = v;        }        else          *xrpnt = 0.0;        xrpnt += step;      }    }     while( m < me ) {      if(!mc) {        mc = *m++;        xrpnt = ((real *) xr) + *m++;        if( (*m++) == 3)          step = 1;        else          step = 3;        m++; /* cb */      }      mc--;      *xrpnt = 0.0;      xrpnt += step;      *xrpnt = 0.0;      xrpnt += step;/* we could add a little opt. here: * if we finished a band for window 3 or a long band * further bands could copied in a simple loop without a * special 'map' decoding */    }    gr_infos->maxband[0] = max[0]+1;    gr_infos->maxband[1] = max[1]+1;    gr_infos->maxband[2] = max[2]+1;    gr_infos->maxbandl = max[3]+1;    {      int rmax = max[0] > max[1] ? max[0] : max[1];      rmax = (rmax > max[2] ? rmax : max[2]) + 1;      gr_infos->maxb = rmax ? shortLimit[sfreq][rmax] : longLimit[sfreq][max[3]+1];    }  }  else {	/*     * decoding with 'long' BandIndex table (block_type != 2)     */    int *pretab = (int *)(gr_infos->preflag ? pretab1 : pretab2);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区和二区| 成人18视频日本| 91精品国产综合久久精品麻豆| 一区二区三区四区乱视频| 欧美亚一区二区| 丝袜美腿高跟呻吟高潮一区| 日韩欧美一区在线观看| 狠狠色狠狠色综合系列| 久久久www成人免费无遮挡大片| 国产精品 日产精品 欧美精品| 国产日韩欧美精品电影三级在线| 成人a区在线观看| 亚洲精品一二三| 91麻豆精品国产91久久久使用方法| 日韩高清中文字幕一区| 久久亚洲一区二区三区明星换脸| 北岛玲一区二区三区四区| 一区二区三区高清不卡| 欧美videos中文字幕| 国产91富婆露脸刺激对白| 亚洲人123区| 日韩精品最新网址| av资源网一区| 五月婷婷激情综合网| ww亚洲ww在线观看国产| 一本到高清视频免费精品| 91在线观看美女| 欧美一区二区视频网站| 国产成人av电影在线| 亚洲国产美国国产综合一区二区| 日韩欧美亚洲另类制服综合在线| 国产成人精品www牛牛影视| 一区二区三区中文免费| 欧美成人精品福利| 日本道色综合久久| 韩国毛片一区二区三区| 亚洲制服丝袜在线| 日本一区二区三区久久久久久久久不| 色偷偷成人一区二区三区91| 久久99精品久久久久久动态图| 亚洲女女做受ⅹxx高潮| 久久精品水蜜桃av综合天堂| 欧美日韩中文字幕一区| 成人黄页在线观看| 久久99久久久欧美国产| 亚洲主播在线播放| 中文字幕亚洲欧美在线不卡| 欧美一区二区在线视频| 91福利视频在线| 不卡一区二区三区四区| 精品一区二区三区在线观看国产| 一区二区三区在线观看动漫| 亚洲国产精品精华液ab| 欧美成人高清电影在线| 在线成人免费视频| 91精品办公室少妇高潮对白| 丁香激情综合国产| 黑人巨大精品欧美黑白配亚洲| 日韩和欧美的一区| 亚洲va天堂va国产va久| 亚洲欧美日韩国产成人精品影院 | 三级一区在线视频先锋| 一区二区在线观看视频| 亚洲国产精品二十页| 日韩欧美亚洲另类制服综合在线 | 99久久精品免费看| 国产精品一区二区果冻传媒| 精品一二三四在线| 九九九久久久精品| 久久99久久久久| 日韩中文字幕亚洲一区二区va在线 | 中文字幕亚洲在| 国产精品乱子久久久久| 日本一二三四高清不卡| 国产精品免费观看视频| 国产欧美日韩在线| 亚洲国产精品成人久久综合一区| 久久久www成人免费无遮挡大片| 久久久久久麻豆| 久久久久久久久久电影| 欧美国产国产综合| 国产精品卡一卡二| 国产精品少妇自拍| 一色屋精品亚洲香蕉网站| 国产精品久久久久久福利一牛影视 | 国产精品成人在线观看| 亚洲欧洲在线观看av| 一区二区三区美女| 亚洲福利视频三区| 五月天欧美精品| 精品在线一区二区| 国产精品一区在线观看你懂的| 国产精品一区免费在线观看| 懂色av一区二区夜夜嗨| 99精品黄色片免费大全| 欧美无砖砖区免费| 日韩精品一区二区三区四区| 久久天堂av综合合色蜜桃网| 国产精品网曝门| 亚洲愉拍自拍另类高清精品| 日产欧产美韩系列久久99| 国产一区视频网站| 91麻豆123| 日韩欧美在线不卡| 国产精品―色哟哟| 亚洲综合色噜噜狠狠| 日韩国产在线观看一区| 国内精品在线播放| 91网上在线视频| 欧美久久久久久蜜桃| 精品国偷自产国产一区| 日韩理论片一区二区| 亚洲成人1区2区| 国产一区二区三区国产| 色哟哟国产精品| 欧美成人一区二区三区| 国产精品久久久久久久久动漫| 亚洲国产日韩a在线播放| 捆绑紧缚一区二区三区视频 | 日本道色综合久久| 欧美精品一区二区三区在线| 亚洲人成网站精品片在线观看| 男女男精品视频| 成人动漫中文字幕| 欧美一区二区精品| 综合色中文字幕| 精久久久久久久久久久| 日本精品一级二级| 久久久国产精华| 免费成人深夜小野草| 91小视频在线免费看| 久久久影视传媒| 日本亚洲天堂网| 色妞www精品视频| wwwwww.欧美系列| 日本亚洲最大的色成网站www| 91网上在线视频| 亚洲国产精品ⅴa在线观看| 免费美女久久99| 欧美日韩在线三区| 亚洲日本在线视频观看| 国产精品自在在线| 日韩欧美精品在线视频| 午夜精品一区二区三区电影天堂| 成人av综合在线| 国产免费成人在线视频| 狠狠色狠狠色综合系列| 欧美一区二区三区男人的天堂| 亚洲激情第一区| 91一区一区三区| 中文字幕第一区综合| 国产一区二区电影| 欧美成人精品福利| 久久精品国产**网站演员| 欧美福利视频一区| 亚洲午夜电影网| 欧美在线免费播放| 一区二区在线观看视频 | 成人在线视频一区二区| 精品蜜桃在线看| 久久国产欧美日韩精品| 日韩免费福利电影在线观看| 天天综合天天做天天综合| 欧美日韩久久一区| 亚洲一区在线视频| 欧美视频日韩视频| 亚洲成人av一区| 欧美一区二区观看视频| 男女性色大片免费观看一区二区| 欧美精品123区| 日韩中文字幕不卡| 欧美一区二区在线不卡| 免费在线观看不卡| 欧美成人乱码一区二区三区| 国产在线视频不卡二| 国产清纯白嫩初高生在线观看91| 国产91丝袜在线播放0| 国产精品久久久久久一区二区三区| 99久久夜色精品国产网站| 亚洲欧美区自拍先锋| 色欧美乱欧美15图片| 亚洲成av人片一区二区梦乃| 欧美精品三级日韩久久| 久久电影网站中文字幕| 国产欧美日韩精品一区| 91尤物视频在线观看| 亚洲国产综合91精品麻豆| 欧美一级黄色大片| 国产成人在线免费观看| 亚洲欧美日韩久久| 日韩一级片在线播放| 国产经典欧美精品| 一区二区三区中文字幕在线观看| 欧美狂野另类xxxxoooo| 黑人精品欧美一区二区蜜桃 | 午夜成人在线视频| 精品久久久久久综合日本欧美| 国产91精品一区二区| 亚洲一区二区3| 精品对白一区国产伦|