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

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

?? motion.c

?? MPEG2解編碼程序源代碼
?? C
字號:
/* motion.c, motion vector decoding                                         */

/* Copyright (C) 1996, MPEG Software Simulation Group. All Rights Reserved. */

/*
 * Disclaimer of Warranty
 *
 * These software programs are available to the user without any license fee or
 * royalty on an "as is" basis.  The MPEG Software Simulation Group 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 MPEG Software Simulation Group does not represent or warrant that the
 * programs furnished hereunder are free of infringement of any third-party
 * patents.
 *
 * Commercial implementations of MPEG-1 and MPEG-2 video, 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 <stdio.h>

#include "config.h"
#include "global.h"

/* private prototypes */
static void decode_motion_vector _ANSI_ARGS_((int *pred, int r_size, int motion_code,
  int motion_residualesidual, int full_pel_vector));

/* ISO/IEC 13818-2 sections 6.2.5.2, 6.3.17.2, and 7.6.3: Motion vectors */
void motion_vectors(PMV,dmvector,
  motion_vertical_field_select,s,motion_vector_count,mv_format,h_r_size,v_r_size,dmv,mvscale)
int PMV[2][2][2];
int dmvector[2];
int motion_vertical_field_select[2][2];
int s, motion_vector_count, mv_format, h_r_size, v_r_size, dmv, mvscale;
{
  if (motion_vector_count==1)
  {
    if (mv_format==MV_FIELD && !dmv)
    {
      motion_vertical_field_select[1][s] = motion_vertical_field_select[0][s] = Get_Bits(1);
#ifdef TRACE
      if (Trace_Flag)
      {
        printf("motion_vertical_field_select[][%d] (%d): %d\n",s,
          motion_vertical_field_select[0][s],motion_vertical_field_select[0][s]);
      }
#endif /* TRACE */
    }

    motion_vector(PMV[0][s],dmvector,h_r_size,v_r_size,dmv,mvscale,0);

    /* update other motion vector predictors */
    PMV[1][s][0] = PMV[0][s][0];
    PMV[1][s][1] = PMV[0][s][1];
  }
  else
  {
    motion_vertical_field_select[0][s] = Get_Bits(1);
#ifdef TRACE
    if (Trace_Flag)
    {
      printf("motion_vertical_field_select[0][%d] (%d): %d\n",s,
        motion_vertical_field_select[0][s],motion_vertical_field_select[0][s]);
    }
#endif /* TRACE */
    motion_vector(PMV[0][s],dmvector,h_r_size,v_r_size,dmv,mvscale,0);

    motion_vertical_field_select[1][s] = Get_Bits(1);
#ifdef TRACE
    if (Trace_Flag)
    {
      printf("motion_vertical_field_select[1][%d] (%d): %d\n",s,
        motion_vertical_field_select[1][s],motion_vertical_field_select[1][s]);
    }
#endif /* TRACE */
    motion_vector(PMV[1][s],dmvector,h_r_size,v_r_size,dmv,mvscale,0);
  }
}

/* get and decode motion vector and differential motion vector 
   for one prediction */
void motion_vector(PMV,dmvector,
  h_r_size,v_r_size,dmv,mvscale,full_pel_vector)
int *PMV;
int *dmvector;
int h_r_size;
int v_r_size;
int dmv; /* MPEG-2 only: get differential motion vectors */
int mvscale; /* MPEG-2 only: field vector in frame pic */
int full_pel_vector; /* MPEG-1 only */
{
  int motion_code, motion_residual;

  /* horizontal component */
  /* ISO/IEC 13818-2 Table B-10 */
  motion_code = Get_motion_code();

  motion_residual = (h_r_size!=0 && motion_code!=0) ? Get_Bits(h_r_size) : 0;

#ifdef TRACE
  if (Trace_Flag)
  {
    if (h_r_size!=0 && motion_code!=0)
    {
      printf("motion_residual (");
      Print_Bits(motion_residual,h_r_size,h_r_size);
      printf("): %d\n",motion_residual);
    }
  }
#endif /* TRACE */


  decode_motion_vector(&PMV[0],h_r_size,motion_code,motion_residual,full_pel_vector);

  if (dmv)
    dmvector[0] = Get_dmvector();


  /* vertical component */
  motion_code     = Get_motion_code();
  motion_residual = (v_r_size!=0 && motion_code!=0) ? Get_Bits(v_r_size) : 0;

#ifdef TRACE
  if (Trace_Flag)
  {
    if (v_r_size!=0 && motion_code!=0)
    {
      printf("motion_residual (");
      Print_Bits(motion_residual,v_r_size,v_r_size);
      printf("): %d\n",motion_residual);
    }
  }
#endif /* TRACE */

  if (mvscale)
    PMV[1] >>= 1; /* DIV 2 */

  decode_motion_vector(&PMV[1],v_r_size,motion_code,motion_residual,full_pel_vector);

  if (mvscale)
    PMV[1] <<= 1;

  if (dmv)
    dmvector[1] = Get_dmvector();

#ifdef TRACE
  if (Trace_Flag)
    printf("PMV = %d,%d\n",PMV[0],PMV[1]);
#endif /* TRACE */
}

/* calculate motion vector component */
/* ISO/IEC 13818-2 section 7.6.3.1: Decoding the motion vectors */
/* Note: the arithmetic here is more elegant than that which is shown 
   in 7.6.3.1.  The end results (PMV[][][]) should, however, be the same.  */

static void decode_motion_vector(pred,r_size,motion_code,motion_residual,full_pel_vector)
int *pred;
int r_size, motion_code, motion_residual;
int full_pel_vector; /* MPEG-1 (ISO/IEC 11172-1) support */
{
  int lim, vec;

  lim = 16<<r_size;
  vec = full_pel_vector ? (*pred >> 1) : (*pred);

  if (motion_code>0)
  {
    vec+= ((motion_code-1)<<r_size) + motion_residual + 1;
    if (vec>=lim)
      vec-= lim + lim;
  }
  else if (motion_code<0)
  {
    vec-= ((-motion_code-1)<<r_size) + motion_residual + 1;
    if (vec<-lim)
      vec+= lim + lim;
  }
  *pred = full_pel_vector ? (vec<<1) : vec;
}


/* ISO/IEC 13818-2 section 7.6.3.6: Dual prime additional arithmetic */
void Dual_Prime_Arithmetic(DMV,dmvector,mvx,mvy)
int DMV[][2];
int *dmvector; /* differential motion vector */
int mvx, mvy;  /* decoded mv components (always in field format) */
{
  if (picture_structure==FRAME_PICTURE)
  {
    if (top_field_first)
    {
      /* vector for prediction of top field from bottom field */
      DMV[0][0] = ((mvx  +(mvx>0))>>1) + dmvector[0];
      DMV[0][1] = ((mvy  +(mvy>0))>>1) + dmvector[1] - 1;

      /* vector for prediction of bottom field from top field */
      DMV[1][0] = ((3*mvx+(mvx>0))>>1) + dmvector[0];
      DMV[1][1] = ((3*mvy+(mvy>0))>>1) + dmvector[1] + 1;
    }
    else
    {
      /* vector for prediction of top field from bottom field */
      DMV[0][0] = ((3*mvx+(mvx>0))>>1) + dmvector[0];
      DMV[0][1] = ((3*mvy+(mvy>0))>>1) + dmvector[1] - 1;

      /* vector for prediction of bottom field from top field */
      DMV[1][0] = ((mvx  +(mvx>0))>>1) + dmvector[0];
      DMV[1][1] = ((mvy  +(mvy>0))>>1) + dmvector[1] + 1;
    }
  }
  else
  {
    /* vector for prediction from field of opposite 'parity' */
    DMV[0][0] = ((mvx+(mvx>0))>>1) + dmvector[0];
    DMV[0][1] = ((mvy+(mvy>0))>>1) + dmvector[1];

    /* correct for vertical field shift */
    if (picture_structure==TOP_FIELD)
      DMV[0][1]--;
    else
      DMV[0][1]++;
  }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜精品久久久久久孕妇| 久久夜色精品一区| 26uuuu精品一区二区| 一二三四社区欧美黄| 久久99国内精品| 在线视频国产一区| 欧美高清在线精品一区| 午夜精品福利一区二区蜜股av| 国产91精品入口| 欧美r级在线观看| 图片区日韩欧美亚洲| youjizz久久| 久久人人爽人人爽| 日本亚洲电影天堂| 91高清视频在线| 亚洲人成7777| 99精品视频在线观看免费| xfplay精品久久| 久久精品久久综合| 欧美一区午夜视频在线观看| 一区二区理论电影在线观看| 91在线观看美女| 国产精品久久久久影视| 粉嫩aⅴ一区二区三区四区五区 | 婷婷开心激情综合| 在线精品视频免费播放| 亚洲精品国产a| 色婷婷综合久色| 亚洲欧美另类小说视频| 91色porny| 一卡二卡三卡日韩欧美| 欧洲精品在线观看| 亚洲一区二区三区自拍| 91丨porny丨中文| 一区二区三区在线视频观看58| 99久久精品情趣| 亚洲另类在线一区| 欧美曰成人黄网| 亚洲va韩国va欧美va精品| 欧美三日本三级三级在线播放| 亚洲已满18点击进入久久| 欧美偷拍一区二区| 婷婷国产在线综合| 精品国产乱码久久久久久1区2区 | 99久久综合精品| 亚洲成av人在线观看| 欧美在线色视频| 午夜精品福利一区二区三区蜜桃| 制服丝袜亚洲色图| 精品一区二区免费| 国产精品素人视频| 欧美午夜精品免费| 国内成人免费视频| 亚洲欧美日韩国产另类专区| 欧美日本在线看| 国产综合色精品一区二区三区| 久久精品视频一区二区三区| 99精品黄色片免费大全| 婷婷久久综合九色综合绿巨人| 精品免费日韩av| 91蜜桃在线免费视频| 奇米综合一区二区三区精品视频| 久久久美女毛片| 欧美日韩一区二区三区免费看| 美女视频黄免费的久久| 国产精品视频一区二区三区不卡| 日本韩国欧美一区| 国产原创一区二区三区| 亚洲综合一二区| 久久久久亚洲蜜桃| 欧美美女一区二区| 不卡在线观看av| 亚洲成人综合网站| 国产喂奶挤奶一区二区三区| 欧美亚洲国产一区在线观看网站| 视频精品一区二区| 亚洲欧洲www| 日韩午夜在线影院| 99视频在线精品| 久久成人免费网| 亚洲成av人片观看| 亚洲四区在线观看| 久久久久9999亚洲精品| 欧美区在线观看| 日本高清不卡在线观看| 国产成人亚洲综合色影视| 日韩精品免费专区| 亚洲国产精品一区二区久久恐怖片 | 久久一二三国产| 欧美日本高清视频在线观看| 高清国产一区二区| 日本亚洲视频在线| 亚洲成a人片在线不卡一二三区 | 在线亚洲一区观看| 成人黄色在线看| 国产精品自拍网站| 久久精品久久精品| 蜜臀久久99精品久久久久久9| 一卡二卡三卡日韩欧美| 亚洲人一二三区| 中文字幕在线不卡| 国产欧美一区二区精品性| 精品国产乱码久久| 欧美成人国产一区二区| 欧美一级日韩一级| 欧美一级黄色片| 欧美一区二区视频观看视频 | 日韩电影一区二区三区四区| 亚洲久草在线视频| 综合中文字幕亚洲| 18欧美亚洲精品| 亚洲日本青草视频在线怡红院 | 精品国产123| 久久婷婷久久一区二区三区| 日韩免费成人网| 精品少妇一区二区三区免费观看| 日韩一区二区免费在线电影| 欧美精品欧美精品系列| 666欧美在线视频| 欧美一区二区三区视频| 日韩欧美资源站| 久久综合色8888| 欧美高清在线精品一区| 亚洲少妇屁股交4| 亚洲一二三级电影| 日本亚洲三级在线| 国产美女一区二区| 成年人网站91| 欧美色综合久久| 日韩欧美一区二区不卡| 久久综合久久综合久久| 国产精品传媒入口麻豆| 亚洲自拍偷拍网站| 日本91福利区| 国产成人夜色高潮福利影视| www.日韩在线| 欧美色手机在线观看| 欧美成人三级电影在线| 国产欧美久久久精品影院| 亚洲狼人国产精品| 久久精品国产精品亚洲红杏| 成人综合婷婷国产精品久久| 日本精品一区二区三区四区的功能| 欧美视频你懂的| 久久精品视频免费观看| 亚洲香肠在线观看| 国产另类ts人妖一区二区| 色婷婷国产精品久久包臀| 欧美一区日本一区韩国一区| 亚洲国产精品成人综合色在线婷婷| 亚洲精品中文在线观看| 六月丁香综合在线视频| 91偷拍与自偷拍精品| 日韩一区二区三区四区| 一区在线观看视频| 捆绑调教美女网站视频一区| 99精品视频中文字幕| 精品女同一区二区| 亚洲一区二区三区四区的| 国产综合色视频| 欧美日韩国产高清一区二区三区| 久久久激情视频| 日韩国产一二三区| 色综合久久综合网97色综合| 精品999在线播放| 香蕉久久夜色精品国产使用方法 | 最新热久久免费视频| 欧美a级理论片| 91久久线看在观草草青青| 26uuu久久综合| 日韩精品电影在线观看| 色又黄又爽网站www久久| 国产欧美日韩在线看| 日本va欧美va精品发布| 色激情天天射综合网| 国产三区在线成人av| 日本亚洲三级在线| 欧美色图在线观看| 亚洲天堂a在线| av网站免费线看精品| 久久综合九色综合久久久精品综合| 天堂蜜桃91精品| 欧美丝袜丝交足nylons图片| 亚洲日本电影在线| 91尤物视频在线观看| 国产蜜臀97一区二区三区| 国产呦萝稀缺另类资源| 日韩精品最新网址| 免费人成在线不卡| 欧美精品九九99久久| 亚洲va国产天堂va久久en| 91国产视频在线观看| 亚洲人成亚洲人成在线观看图片 | 国产一区二区精品在线观看| 91精品国产欧美一区二区18| 亚洲123区在线观看| 777午夜精品视频在线播放| 亚洲成人一二三| 欧美日韩欧美一区二区| 日韩精品电影一区亚洲|