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

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

?? recon.c

?? G729、h263、h264、MPEG4四種最流行的音頻和視頻標準的壓縮和解壓算法的源代碼.rar
?? C
?? 第 1 頁 / 共 2 頁
字號:
unsigned char *s, *d;
int lx,lx2,h;
{
  unsigned char *dp,*sp,*sp2;
  int j;

  sp = s;
  sp2 = s+lx2;
  dp = d;
  for (j=0; j<h; j++)
  {
    dp[0] = (unsigned int)(sp[0]+sp2[0]+1)>>1;
    dp[1] = (unsigned int)(sp[1]+sp2[1]+1)>>1;
    dp[2] = (unsigned int)(sp[2]+sp2[2]+1)>>1;
    dp[3] = (unsigned int)(sp[3]+sp2[3]+1)>>1;
    dp[4] = (unsigned int)(sp[4]+sp2[4]+1)>>1;
    dp[5] = (unsigned int)(sp[5]+sp2[5]+1)>>1;
    dp[6] = (unsigned int)(sp[6]+sp2[6]+1)>>1;
    dp[7] = (unsigned int)(sp[7]+sp2[7]+1)>>1;
    dp[8] = (unsigned int)(sp[8]+sp2[8]+1)>>1;
    dp[9] = (unsigned int)(sp[9]+sp2[9]+1)>>1;
    dp[10] = (unsigned int)(sp[10]+sp2[10]+1)>>1;
    dp[11] = (unsigned int)(sp[11]+sp2[11]+1)>>1;
    dp[12] = (unsigned int)(sp[12]+sp2[12]+1)>>1;
    dp[13] = (unsigned int)(sp[13]+sp2[13]+1)>>1;
    dp[14] = (unsigned int)(sp[14]+sp2[14]+1)>>1;
    dp[15] = (unsigned int)(sp[15]+sp2[15]+1)>>1;
    sp+= lx2;
    sp2+= lx2;
    dp+= lx;
  }
}

static void recvc(s,d,lx,lx2,h)
unsigned char *s, *d;
int lx,lx2,h;
{
  unsigned char *dp,*sp,*sp2;
  int j;

  sp = s;
  sp2 = s+lx2;
  dp = d;

  for (j=0; j<h; j++)
  {
    dp[0] = (unsigned int)(sp[0]+sp2[0]+1)>>1;
    dp[1] = (unsigned int)(sp[1]+sp2[1]+1)>>1;
    dp[2] = (unsigned int)(sp[2]+sp2[2]+1)>>1;
    dp[3] = (unsigned int)(sp[3]+sp2[3]+1)>>1;
    dp[4] = (unsigned int)(sp[4]+sp2[4]+1)>>1;
    dp[5] = (unsigned int)(sp[5]+sp2[5]+1)>>1;
    dp[6] = (unsigned int)(sp[6]+sp2[6]+1)>>1;
    dp[7] = (unsigned int)(sp[7]+sp2[7]+1)>>1;
    sp+= lx2;
    sp2+= lx2;
    dp+= lx;
  }
}

static void recvo(s,d,lx,lx2,addflag,c,xa,xb,ya,yb)
unsigned char *s;
int *d;
int lx,lx2,addflag,c,xa,xb,ya,yb;
{
  int *dp,*om;
  unsigned char *sp,*sp2;
  int i,j;

  sp = s;
  sp2 = s+lx2;
  dp = d;
  om = &OM[c][ya][0];

  if (!addflag) 
  {
    for (j = ya; j < yb; j++)
	{
      for (i = xa; i < xb; i++) 
	  {
        dp[i] = (((unsigned int)(sp[i] + sp2[i]+1))>>1)*om[i];
      }
      sp+= lx2;
      sp2+= lx2;
      dp+= lx;
      om+= 8;
    }
  }
  else 
  {
    for (j = ya; j < yb; j++) 
	{
      for (i = xa; i < xb; i++) 
	  {
        dp[i] += (((unsigned int)(sp[i] + sp2[i]+1))>>1)*om[i];
      }
      sp+= lx2;
      sp2+= lx2;
      dp+= lx;
      om+= 8;
    }
  }
}

static void rec4(s,d,lx,lx2,h)
unsigned char *s, *d;
int lx,lx2,h;
{
  unsigned char *dp,*sp,*sp2;
  int j;
  unsigned int s1,s2,s3,s4;

  sp = s;
  sp2 = s+lx2;
  dp = d;
  for (j=0; j<h; j++)
  {
    s1=sp[0]; s3=sp2[0];
    dp[0] = (unsigned int)(s1+(s2=sp[1])+s3+(s4=sp2[1])+2)>>2;
    dp[1] = (unsigned int)(s2+(s1=sp[2])+s4+(s3=sp2[2])+2)>>2;
    dp[2] = (unsigned int)(s1+(s2=sp[3])+s3+(s4=sp2[3])+2)>>2;
    dp[3] = (unsigned int)(s2+(s1=sp[4])+s4+(s3=sp2[4])+2)>>2;
    dp[4] = (unsigned int)(s1+(s2=sp[5])+s3+(s4=sp2[5])+2)>>2;
    dp[5] = (unsigned int)(s2+(s1=sp[6])+s4+(s3=sp2[6])+2)>>2;
    dp[6] = (unsigned int)(s1+(s2=sp[7])+s3+(s4=sp2[7])+2)>>2;
    dp[7] = (unsigned int)(s2+(s1=sp[8])+s4+(s3=sp2[8])+2)>>2;
    dp[8] = (unsigned int)(s1+(s2=sp[9])+s3+(s4=sp2[9])+2)>>2;
    dp[9] = (unsigned int)(s2+(s1=sp[10])+s4+(s3=sp2[10])+2)>>2;
    dp[10] = (unsigned int)(s1+(s2=sp[11])+s3+(s4=sp2[11])+2)>>2;
    dp[11] = (unsigned int)(s2+(s1=sp[12])+s4+(s3=sp2[12])+2)>>2;
    dp[12] = (unsigned int)(s1+(s2=sp[13])+s3+(s4=sp2[13])+2)>>2;
    dp[13] = (unsigned int)(s2+(s1=sp[14])+s4+(s3=sp2[14])+2)>>2;
    dp[14] = (unsigned int)(s1+(s2=sp[15])+s3+(s4=sp2[15])+2)>>2;
    dp[15] = (unsigned int)(s2+sp[16]+s4+sp2[16]+2)>>2;
    sp+= lx2;
    sp2+= lx2;
    dp+= lx;
  }
}

static void rec4c(s,d,lx,lx2,h)
unsigned char *s, *d;
int lx,lx2,h;
{
  unsigned char *dp,*sp,*sp2;
  int j;
  unsigned int s1,s2,s3,s4;

  sp = s;
  sp2 = s+lx2;
  dp = d;
  for (j=0; j<h; j++)
  {
    s1=sp[0]; s3=sp2[0];
    dp[0] = (unsigned int)(s1+(s2=sp[1])+s3+(s4=sp2[1])+2)>>2;
    dp[1] = (unsigned int)(s2+(s1=sp[2])+s4+(s3=sp2[2])+2)>>2;
    dp[2] = (unsigned int)(s1+(s2=sp[3])+s3+(s4=sp2[3])+2)>>2;
    dp[3] = (unsigned int)(s2+(s1=sp[4])+s4+(s3=sp2[4])+2)>>2;
    dp[4] = (unsigned int)(s1+(s2=sp[5])+s3+(s4=sp2[5])+2)>>2;
    dp[5] = (unsigned int)(s2+(s1=sp[6])+s4+(s3=sp2[6])+2)>>2;
    dp[6] = (unsigned int)(s1+(s2=sp[7])+s3+(s4=sp2[7])+2)>>2;
    dp[7] = (unsigned int)(s2+sp[8]+s4+sp2[8]+2)>>2;
    sp+= lx2;
    sp2+= lx2;
    dp+= lx;
  }
}

static void rec4o(s,d,lx,lx2,addflag,c,xa,xb,ya,yb)
unsigned char *s;
int *d;
int lx,lx2,addflag,c,xa,xb,ya,yb;
{
  int *dp,*om;
  unsigned char *sp,*sp2;
  int i,j;

  sp = s;
  sp2 = s+lx2;
  dp = d;
  om = &OM[c][ya][0];

  if (!addflag) 
  {
    for (j = ya; j < yb; j++) 
	{
      for (i = xa; i < xb; i++) 
	  {
        dp[i] = (((unsigned int)(sp[i]+sp2[i]+sp[i+1]+sp2[i+1]+2))>>2)*om[i];
      }
      sp+= lx2;
      sp2+= lx2;
      dp+= lx;
      om+= 8;
    }
  }
  else 
  {
    for (j = ya; j < yb; j++)
	{
      for (i = xa; i < xb; i++)
	  {
        dp[i] += (((unsigned int)(sp[i]+sp2[i]+sp[i+1]+sp2[i+1]+2))>>2)*om[i];
      }
      sp+= lx2;
      sp2+= lx2;
      dp+= lx;
      om += 8;
    }
  }
}

static void recon_comp_obmc(src,dst,lx,lx2,comp,w,h,x,y)
unsigned char *src;
unsigned char *dst;
int lx,lx2,comp;
int w,h;
int x,y;
{
  int j,k;
  int xmb,ymb;
  int c8,t8,l8,r8;
  int ti8,li8,ri8;
  int xit=0,xib=0,xir=0,xil=0;
  int yit=0,yib=0,yir=0,yil=0;
  int vect=0,vecb=0,vecr=0,vecl=0;
  int nx[5],ny[5],xint[5],yint[5],xh[5],yh[5];
  int p[64],*pd;
  unsigned char *d,*s[5];

  xmb = (x>>4)+1;
  ymb = (y>>4)+1;

  c8  = (modemap[ymb][xmb] == MODE_INTER4V ? 1 : 0);

  t8  = (modemap[ymb-1][xmb] == MODE_INTER4V ? 1 : 0);
  ti8 = (modemap[ymb-1][xmb] == MODE_INTRA ? 1 : 0);
  ti8 = (modemap[ymb-1][xmb] == MODE_INTRA_Q ? 1 : ti8);

  l8  = (modemap[ymb][xmb-1] == MODE_INTER4V ? 1 : 0);
  li8 = (modemap[ymb][xmb-1] == MODE_INTRA ? 1 : 0);
  li8 = (modemap[ymb][xmb-1] == MODE_INTRA_Q ? 1 : li8);
  
  r8  = (modemap[ymb][xmb+1] == MODE_INTER4V ? 1 : 0);
  ri8 = (modemap[ymb][xmb+1] == MODE_INTRA ? 1 : 0);
  ri8 = (modemap[ymb][xmb+1] == MODE_INTRA_Q ? 1 : ri8);

  if (pb_frame) 
  {
    ti8 = li8 = ri8 = 0;
  }

  switch (comp+1) 
  {
  case 1:
    vect = (ti8 ? (c8 ? 1 : 0) : (t8 ? 3 : 0)); 
    yit  = (ti8 ? ymb : ymb - 1); 
    xit = xmb;

    vecb = (c8 ? 3 : 0) ; yib = ymb; xib = xmb;

    vecl = (li8 ? (c8 ? 1 : 0) : (l8 ? 2 : 0)); 
    yil = ymb; 
    xil = (li8 ? xmb : xmb-1);

    vecr = (c8 ? 2 : 0) ; yir = ymb; xir = xmb;

    /* edge handling */
    if (ymb == 1) 
	{
      yit = ymb;
      vect = (c8 ? 1 : 0);
    }
    if (xmb == 1) 
	{
      xil = xmb;
      vecl = (c8 ? 1 : 0);
    }
    break;
  
  case 2:
    vect = (ti8 ? (c8 ? 2 : 0) : (t8 ? 4 : 0)); 
    yit = (ti8 ? ymb : ymb-1); 
    xit = xmb;

    vecb = (c8 ? 4 : 0) ; yib = ymb; xib = xmb;
    vecl = (c8 ? 1 : 0) ; yil = ymb; xil = xmb;

    vecr = (ri8 ? (c8 ? 2 : 0) : (r8 ? 1 : 0)); 
    yir = ymb; 
    xir = (ri8 ? xmb : xmb+1);

    /* edge handling */
    if (ymb == 1) 
	{
      yit = ymb;
      vect = (c8 ? 2 : 0);
    }
    if (xmb == mb_width) 
	{
      xir = xmb;
      vecr = (c8 ? 2 : 0);
    }
    break;

  case 3:
    vect = (c8 ? 1 : 0) ; yit = ymb  ; xit = xmb;
    vecb = (c8 ? 3 : 0) ; yib = ymb  ; xib = xmb;
      
    vecl = (li8 ? (c8 ? 3 : 0) : (l8 ? 4 : 0)); 
    yil = ymb;  
    xil = (li8 ? xmb : xmb-1);
    
    vecr = (c8 ? 4 : 0) ; yir = ymb  ; xir = xmb;

    /* edge handling */
    if (xmb == 1) 
	{
      xil = xmb;
      vecl = (c8 ? 3 : 0);
    }
    break;

  case 4:
    vect = (c8 ? 2 : 0) ; yit = ymb  ; xit = xmb;
    vecb = (c8 ? 4 : 0) ; yib = ymb  ; xib = xmb;
    vecl = (c8 ? 3 : 0) ; yil = ymb  ; xil = xmb;

    vecr = (ri8 ? (c8 ? 4 : 0) : (r8 ? 3 : 0)); 
    yir = ymb; 
    xir = (ri8 ? xmb : xmb+1);

    /* edge handling */
    if (xmb == mb_width) 
	{
      xir = xmb;
      vecr = (c8 ? 4 : 0);
    }
    break;

  default:
    fprintf(stderr,"Illegal block number in recon_comp_obmc (recon.c)\n");
    exit(1);
    break;
  }

  nx[0] = MV[0][c8 ? comp + 1 : 0][ymb][xmb];
  ny[0] = MV[1][c8 ? comp + 1 : 0][ymb][xmb];
  
  nx[1] = MV[0][vect][yit][xit]; ny[1] = MV[1][vect][yit][xit];
  nx[2] = MV[0][vecb][yib][xib]; ny[2] = MV[1][vecb][yib][xib];
  nx[3] = MV[0][vecr][yir][xir]; ny[3] = MV[1][vecr][yir][xir];
  nx[4] = MV[0][vecl][yil][xil]; ny[4] = MV[1][vecl][yil][xil];

  for (k = 0; k < 5; k++) 
  {
    xint[k] = nx[k]>>1;
    xh[k] = nx[k] & 1;
    yint[k] = ny[k]>>1;
    yh[k] = ny[k] & 1;
    s[k] = src + lx2*(y+yint[k]) + x + xint[k];
  }
  
  d = dst + lx*y + x;

  if (!xh[0] && !yh[0])
    reco(s[0],&p[0],8,lx2,0,0,0,8,0,8);
  else if (!xh[0] && yh[0])
    recvo(s[0],&p[0],8,lx2,0,0,0,8,0,8);
  else if (xh[0] && !yh[0])
    recho(s[0],&p[0],8,lx2,0,0,0,8,0,8);
  else /* if (xh[] && yh[]) */
    rec4o(s[0],&p[0],8,lx2,0,0,0,8,0,8);

  if (!xh[1] && !yh[1])
    reco(s[1],&p[0],8,lx2,1,1,0,8,0,4);
  else if (!xh[1] && yh[1])
    recvo(s[1],&p[0],8,lx2,1,1,0,8,0,4);
  else if (xh[1] && !yh[1])
    recho(s[1],&p[0],8,lx2,1,1,0,8,0,4);
  else /* if (xh[] && yh[]) */
    rec4o(s[1],&p[0],8,lx2,1,1,0,8,0,4);

  if (!xh[2] && !yh[2])
    reco(s[2]+(lx2<<2),&p[32],8,lx2,1,2,0,8,4,8);
  else if (!xh[2] && yh[2])
    recvo(s[2]+(lx2<<2),&p[32],8,lx2,1,2,0,8,4,8);
  else if (xh[2] && !yh[2])
    recho(s[2]+(lx2<<2),&p[32],8,lx2,1,2,0,8,4,8);
  else /* if (xh[] && yh[]) */
    rec4o(s[2]+(lx2<<2),&p[32],8,lx2,1,2,0,8,4,8);

  if (!xh[3] && !yh[3])
    reco(s[3],&p[0],8,lx2,1,3,4,8,0,8);
  else if (!xh[3] && yh[3])
    recvo(s[3],&p[0],8,lx2,1,3,4,8,0,8);
  else if (xh[3] && !yh[3])
    recho(s[3],&p[0],8,lx2,1,3,4,8,0,8);
  else /* if (xh[] && yh[]) */
    rec4o(s[3],&p[0],8,lx2,1,3,4,8,0,8);

  if (!xh[4] && !yh[4])
    reco(s[4],&p[0],8,lx2,1,4,0,4,0,8);
  else if (!xh[4] && yh[4])
    recvo(s[4],&p[0],8,lx2,1,4,0,4,0,8);
  else if (xh[4] && !yh[4])
    recho(s[4],&p[0],8,lx2,1,4,0,4,0,8);
  else /* if (xh[] && yh[]) */
    rec4o(s[4],&p[0],8,lx2,1,4,0,4,0,8);

  pd = &p[0];
  for (j = 0; j < 8; j++) 
  {
    d[0] = (pd[0] + 4 )>>3;	
    d[1] = (pd[1] + 4 )>>3;	
    d[2] = (pd[2] + 4 )>>3;	
    d[3] = (pd[3] + 4 )>>3;	
    d[4] = (pd[4] + 4 )>>3;	
    d[5] = (pd[5] + 4 )>>3;	
    d[6] = (pd[6] + 4 )>>3;	
    d[7] = (pd[7] + 4 )>>3;	
    d += lx;
    pd += 8;
  }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产寡妇亲子伦一区二区| 亚洲另类在线制服丝袜| 久久国内精品自在自线400部| 欧美精品第1页| 日本最新不卡在线| 精品国产乱码久久久久久蜜臀 | 亚洲色图在线播放| 色婷婷av一区二区三区软件| 亚洲国产成人porn| 欧美一二三区精品| 国产成人免费视频网站| 最近中文字幕一区二区三区| 欧美午夜电影网| 麻豆精品新av中文字幕| 国产亚洲精久久久久久| 91欧美激情一区二区三区成人| 自拍偷拍国产精品| 777欧美精品| 国产乱人伦偷精品视频不卡| 亚洲色图清纯唯美| 欧美一区二区精品| av在线一区二区三区| 五月天激情综合| 久久久久久免费| 欧美无砖砖区免费| 国产在线一区观看| 亚洲综合免费观看高清完整版在线 | 色婷婷综合久久久中文一区二区 | 国产精品美女久久久久久久久久久| 波多野洁衣一区| 日韩精品久久理论片| 亚洲国产精品t66y| 欧美大度的电影原声| 国产91精品在线观看| 亚洲成年人影院| 亚洲欧洲日韩在线| 日韩欧美国产成人一区二区| 色偷偷久久人人79超碰人人澡| 蜜臂av日日欢夜夜爽一区| 亚洲啪啪综合av一区二区三区| 7777女厕盗摄久久久| 99久久久免费精品国产一区二区| 首页国产丝袜综合| 亚洲免费在线电影| 国产精品久久免费看| 日韩精品一区二区三区视频| 欧美在线不卡视频| 懂色av中文一区二区三区| 日韩av在线发布| 亚洲夂夂婷婷色拍ww47| 国产精品理论片在线观看| 日韩你懂的电影在线观看| 在线观看网站黄不卡| 成人网在线播放| 精品一区二区免费看| 午夜欧美2019年伦理| 亚洲欧洲成人av每日更新| 久久综合五月天婷婷伊人| 欧美一级黄色大片| 欧美肥妇毛茸茸| 欧美性猛交xxxx黑人交| 一本大道av伊人久久综合| 成人开心网精品视频| 国产精一品亚洲二区在线视频| 免费成人av在线| 亚洲午夜免费电影| 一区二区三区在线观看视频| 国产精品久久久久久久久搜平片| 国产亚洲精品福利| www精品美女久久久tv| 欧美白人最猛性xxxxx69交| 欧美精品第1页| 91.xcao| 69堂国产成人免费视频| 制服丝袜国产精品| 911精品产国品一二三产区| 欧美精品v日韩精品v韩国精品v| 欧美在线免费播放| 欧美日韩国产综合一区二区| 欧美精品久久一区二区三区| 欧美日韩成人综合天天影院| 欧美日韩黄色一区二区| 欧美狂野另类xxxxoooo| 制服丝袜成人动漫| 日韩精品一区二区在线| 精品国产三级电影在线观看| 久久新电视剧免费观看| 26uuu精品一区二区在线观看| 久久久久国产精品免费免费搜索| 日本一区二区免费在线| 亚洲欧美怡红院| 亚洲成a人片在线观看中文| 午夜欧美2019年伦理| 精品一区二区三区香蕉蜜桃| 国产精品自拍在线| 床上的激情91.| 欧美三级资源在线| 日韩欧美一区电影| 国产欧美一区二区精品忘忧草 | xvideos.蜜桃一区二区| 欧美激情在线一区二区三区| 中文字幕亚洲区| 视频一区中文字幕国产| 韩国毛片一区二区三区| 99久久99精品久久久久久| 欧美系列日韩一区| 精品久久久久久久一区二区蜜臀| 国产精品乱子久久久久| 亚洲高清视频在线| 激情都市一区二区| 色爱区综合激月婷婷| 欧美一区二区福利视频| 中文av一区二区| 亚洲大尺度视频在线观看| 激情偷乱视频一区二区三区| 色网站国产精品| 精品福利一区二区三区免费视频| 亚洲欧洲www| 狠狠色狠狠色合久久伊人| 欧美人伦禁忌dvd放荡欲情| 久久综合色鬼综合色| 综合久久给合久久狠狠狠97色| 午夜精品国产更新| 成人午夜视频在线观看| 9191久久久久久久久久久| 国产欧美日韩精品a在线观看| 一区二区激情小说| 成人一区在线看| 欧美一区二区三区在线观看视频| 国产精品蜜臀av| 狠狠色伊人亚洲综合成人| 精品视频1区2区| 亚洲国产精品激情在线观看 | 亚洲h在线观看| 成人免费毛片高清视频| 欧美成人午夜电影| 日韩中文欧美在线| 99精品久久只有精品| 亚洲精品一区二区三区在线观看 | 亚洲欧美日韩系列| 国产福利一区二区三区视频在线| 欧美日韩第一区日日骚| 亚洲精品日产精品乱码不卡| 国产精品18久久久久久久久久久久| 欧美色偷偷大香| 亚洲欧美日韩中文播放 | 亚洲一区二区三区国产| 高清久久久久久| 精品国一区二区三区| 日韩黄色免费网站| 欧美性受xxxx| 亚洲一区二区视频在线| 91福利视频网站| 亚洲视频一区二区在线观看| 国产成人精品一区二区三区四区 | 日韩国产在线一| 欧美色综合影院| 玉米视频成人免费看| 色婷婷av一区二区三区gif | 久久精品视频一区二区| 六月丁香综合在线视频| 日韩三级视频中文字幕| 毛片一区二区三区| 欧美一区二区三区四区视频| 日本欧美大码aⅴ在线播放| 欧美日韩国产一二三| 日韩在线一区二区| 欧美裸体一区二区三区| 日韩在线播放一区二区| 日韩三级视频在线看| 精品在线你懂的| 国产亚洲精品久| 99国产精品久| 一区二区日韩av| 欧美一级艳片视频免费观看| 蜜桃一区二区三区四区| 久久综合久久99| av一区二区三区| 洋洋av久久久久久久一区| 精品视频999| 精品制服美女丁香| 亚洲国产精品传媒在线观看| av一二三不卡影片| 亚洲国产乱码最新视频| 日韩一区二区三区四区| 国产成人精品在线看| 亚洲精品免费在线| 在线综合视频播放| 国内成人精品2018免费看| 欧美激情一区二区三区四区 | 欧美日韩在线三级| 免费成人av资源网| 国产精品国产三级国产普通话99 | 久久久久久久国产精品影院| 成人午夜激情视频| 亚洲一区在线观看网站| 日韩视频在线一区二区| 成人福利视频在线看| 一区二区三区精品在线| 欧美电视剧在线观看完整版|