⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 esram.c

📁 MP3的代码很实用 MP3的代码很实用
💻 C
📖 第 1 页 / 共 4 页
字号:
	count = max;
    if(gr_info->mixed_block_flag) {
      /*max[3] = -1;
      max[0] = max[1] = max[2] = 2;*/   
      *count = 2; count++;
      *count = 2; count++;
      *count = 2; count++;
      *count = -1;
      m = map[sfreq][0];
      me = mapend[sfreq][0];
    }
    else {
      /*max[0] = max[1] = max[2] = max[3] = -1;*/
      *count = -1; count++;
      *count = -1; count++;
      *count = -1; count++;
      *count = -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 = ht+gr_info->table_select[i];
      for(;lp;lp--,mc--) {
        register int x,y;
        if( (!mc) ) {
          mc = *m++;
          xrpnt = ((real *) xr) + (*m++);
          lwin = *m++;
          cb = *m++;
          if(lwin == 3) {
            v = gr_info->pow2gain + ((*scf++) << shift);
            step = 1;
          }
          else {
            v = gr_info->full_gain[lwin] + ((*scf++) << shift);
            step = 3;
          }
        }
        {
          register short *val = h->table;
          while((y=*val++)<0) {
	     GET1BIT();
            if (rval)
              val -= y;
            part2remain--;
          }
          x = y >> 4;
          y &= 0xf;
        }
        if(x == 15) {
          max[lwin] = cb;
          part2remain -= h->linbits+1;
          x += getbits(h->linbits);
          deq_pow(x, v);			// ispow[x] * v;
          GET1BIT();
          if(rval)
            *xrpnt = -deq;
          else
            *xrpnt = deq;
        }
        else if(x) {
          max[lwin] = cb;
          deq_pow(x, v);			// ispow[x] * v;
          GET1BIT();
          if(rval)
            *xrpnt = -deq;
          else
            *xrpnt = deq;
          part2remain--;
        }
        else
          *xrpnt = 0;
        xrpnt += step;
        if(y == 15) {
          max[lwin] = cb;
          part2remain -= h->linbits+1;
          y += getbits(h->linbits);
          deq_pow(y, v);			// ispow[y] * v;
          GET1BIT();
          if(rval)
            *xrpnt = -deq;
          else
            *xrpnt = deq;
        }
        else if(y) {
          max[lwin] = cb;
          deq_pow(y, v);			// ispow[y] * v;
          GET1BIT();
          if(rval)
            *xrpnt = -deq;
          else
            *xrpnt = deq;
          part2remain--;
        }
        else
          *xrpnt = 0;
        xrpnt += step;
      }
    }
    for(;l3 && (part2remain > 0);l3--) {
      struct newhuff *h = htc+gr_info->count1table_select;
      register short *val = h->table;
      register short a;

      while((a=*val++)<0) {
        part2remain--;
        if(part2remain < 0) {
          part2remain++;
          a = 0;
          break;
        }
	GET1BIT();
        if (rval)
          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_info->pow2gain + ((*scf++) << shift);
              step = 1;
            }
            else {
              v = gr_info->full_gain[lwin] + ((*scf++) << shift);
              step = 3;
            }
          }
          mc--;
        }
        if( (a & (0x8>>i)) ) {
          max[lwin] = cb;
          part2remain--;
          if(part2remain < 0) {
            part2remain++;
            break;
          }
	   GET1BIT();
          if(rval) 
            *xrpnt = -gainpow2[(-v) & 3]>>(v >> 2);			// -v;
          else
            *xrpnt =  gainpow2[(-v) & 3]>>(v >> 2);			// v
        }
        else
          *xrpnt = 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;
      xrpnt += step;
      *xrpnt = 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_info->maxband[0] = max[0]+1;
    gr_info->maxband[1] = max[1]+1;
    gr_info->maxband[2] = max[2]+1;
    gr_info->maxbandl = max[3]+1;

    {
      int rmax = max[0] > max[1] ? max[0] : max[1];
      rmax = (rmax > max[2] ? rmax : max[2]) + 1;
      gr_info->maxb = rmax ? shortLimit[sfreq][rmax] : longLimit[sfreq][max[3]+1];
    }

  }
  else {
	/*
     * decoding with 'long' BandIndex table (block_type != 2)
     */
    int *pretab = gr_info->preflag ? pretab1 : pretab2;
    int i,max = -1;
    int cb = 0;
    register int *m = map[sfreq][2];
    register real v = 0;
    register int mc = 0;

	/*
     * long hash table values
     */
    for(i=0;i<3;i++) {
      int lp = l[i];
      struct newhuff *h = ht+gr_info->table_select[i];

      for(;lp;lp--,mc--) {
        int x,y;

        if(!mc) {
          mc = *m++;
          v = gr_info->pow2gain + (((*scf++) + (*pretab++)) << shift);
          cb = *m++;
        }
        {
          register short *val = h->table;
          while((y=*val++)<0) {
	     GET1BIT();
            if (rval)
              val -= y;
            part2remain--;
          }
          x = y >> 4;
          y &= 0xf;
        }
        if (x == 15) {
          max = cb;
          part2remain -= h->linbits+1;
          x += getbits(h->linbits);
          deq_pow(x, v);			// ispow[x] * v;
          GET1BIT();
          if(rval)
            *xrpnt++ = -deq;
          else
            *xrpnt++ = deq;
        }
        else if(x) {
          max = cb;
          deq_pow(x, v);			// ispow[x] * v;
          GET1BIT();
          if(rval)
            *xrpnt++ = -deq;
          else
            *xrpnt++ = deq;
          part2remain--;
        }
        else
          *xrpnt++ = 0;

        if (y == 15) {
          max = cb;
          part2remain -= h->linbits+1;
          y += getbits(h->linbits);
          deq_pow(y, v);			// ispow[y] * v;
	   GET1BIT();
          if(rval)
            *xrpnt++ = -deq;
          else
            *xrpnt++ = deq;
        }
        else if(y) {
          max = cb;
          deq_pow(y, v);			// ispow[y] * v;
          GET1BIT();
          if(rval)
            *xrpnt++ = -deq;
          else
            *xrpnt++ = deq;
          part2remain--;
        }
        else
          *xrpnt++ = 0;
      }
    }

	/*
     * short (count1table) values
     */
    for(;l3 && (part2remain > 0);l3--) {
      struct newhuff *h = htc+gr_info->count1table_select;
      register short *val = h->table;
      register short a;

      while((a=*val++)<0) {
        part2remain--;
        if(part2remain < 0) {
          part2remain++;
          a = 0;
          break;
        }
	GET1BIT();
        if (rval)
          val -= a;
      }

      for(i=0;i<4;i++) {
        if(!(i & 1)) {
          if(!mc) {
            mc = *m++;
            cb = *m++;
            v = gr_info->pow2gain + (((*scf++) + (*pretab++)) << shift);
          }
          mc--;
        }
        if ( (a & (0x8>>i)) ) {
          max = cb;
          part2remain--;
          if(part2remain < 0) {
            part2remain++;
            break;
          }
	   GET1BIT();	  
          if(rval)
            *xrpnt++ = -gainpow2[(-v) & 3]>>(v >> 2);			// -v;
          else
            *xrpnt++ =  gainpow2[(-v) & 3]>>(v >> 2);			// v;
        }
        else
          *xrpnt++ = 0;
      }
    }

	/* 
     * zero part
     */
    for(i=(&xr[SBLIMIT][0]-xrpnt)>>1;i;i--) {
      *xrpnt++ = 0;
      *xrpnt++ = 0;
    }

    gr_info->maxbandl = max+1;
    gr_info->maxb = longLimit[sfreq][gr_info->maxbandl];
  }

  while( part2remain > 16 ) {
    getbits(16); /* Dismiss stuffing Bits */
    part2remain -= 16;
  }
  if(part2remain > 0)
    getbits(part2remain);
  else if(part2remain < 0) {
//    fprintf(stderr,"mpg123: Can't rewind stream by %d bits!\n",-part2remain);
    return 1; /* -> error */
  }
  return 0;
}


void III_antialias(real xr[SBLIMIT][SSLIMIT],struct gr_info_s *gr_info)
{
   int sblim;

   if(gr_info->block_type == 2)
   {
      if(!gr_info->mixed_block_flag) 
        return;
      sblim = 1; 
   }
   else {
     sblim = gr_info->maxb-1;
   }

   /* 31 alias-reduction operations between each pair of sub-bands */
   /* with 8 butterflies between each pair                         */

   {
     int sb;
     real *xr1=(real *) xr[1];

     for(sb=sblim;sb;sb--,xr1+=10)
     {
       int ss;
       real *cs=aa_cs,*ca=aa_ca;
       real *xr2 = xr1;

       for(ss=7;ss>=0;ss--)
       {       /* upper and lower butterfly inputs */
         register real bu = *--xr2,bd = *xr1;
         *xr2   = MUL24(bu, *cs  ) - MUL24(bd, *ca  );
         *xr1++ = MUL24(bd, *cs++) + MUL24(bu, *ca++);
       }
     }
  }
}


/*
 * read scalefactors
 */
 #if 0
int III_get_scale_factors_1(int *scf,struct gr_info_s *gr_info)
{
   static 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_info->scalefac_compress];
   int num1 = slen[1][gr_info->scalefac_compress];

    if (gr_info->block_type == 2) 
    {
      int i=18;
      numbits = (num0 + num1) * 18;

      if (gr_info->mixed_block_flag) {
//         for (i=8;i;i--)
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
         i = 9;
         numbits -= num0; /* num0 * 17 + num1 * 18 */
      }

      for (;i;i--)
        *scf++ = getbits_fast(num0);
//      for (i = 18; i; i--)
        *scf++ = getbits_fast(num1);
        *scf++ = getbits_fast(num1);
        *scf++ = getbits_fast(num1);
        *scf++ = getbits_fast(num1);
        *scf++ = getbits_fast(num1);
        *scf++ = getbits_fast(num1);
        *scf++ = getbits_fast(num1);
        *scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);
		*scf++ = getbits_fast(num1);

      *scf++ = 0; *scf++ = 0; *scf++ = 0; /* short[13][0..2] = 0 */
    }
    else 
    {
      int i;
      int scfsi = gr_info->scfsi;

      if(scfsi < 0) { /* scfsi < 0 => granule == 0 */
//         for(i=11;i;i--)
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
           *scf++ = getbits_fast(num0);
		   *scf++ = getbits_fast(num0);
		   *scf++ = getbits_fast(num0);
		   *scf++ = getbits_fast(num0);
		   *scf++ = getbits_fast(num0);
		   *scf++ = getbits_fast(num0);
//         for(i=10;i;i--)
           *scf++ = getbits_fast(num1);
           *scf++ = getbits_fast(num1);
           *scf++ = getbits_fast(num1);
           *scf++ = getbits_fast(num1);
           *scf++ = getbits_fast(num1);
           *scf++ = getbits_fast(num1);
           *scf++ = getbits_fast(num1);
           *scf++ = getbits_fast(num1);
           *scf++ = getbits_fast(num1);
           *scf++ = getbits_fast(num1);
         numbits = (num0 + num1) * 10 + num0;
      }
      else {
        numbits = 0;
        if(!(scfsi & 0x8)) {
//          for (i=6;i;i--)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -