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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? putseq.c

?? MPEG2編解碼的源代碼.zip
?? C
字號:
/* putseq.c, sequence level routines                                        *//* 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 <string.h>#include "config.h"#include "global.h"void putseq(){  /* this routine assumes (N % M) == 0 */  int i, j, k, f, f0, n, np, nb, sxf, syf, sxb, syb;  int ipflag;  FILE *fd;  char name[256];  unsigned char *neworg[3], *newref[3];  static char ipb[5] = {' ','I','P','B','D'};  rc_init_seq(); /* initialize rate control */  /* sequence header, sequence extension and sequence display extension */  putseqhdr();  if (!mpeg1)  {    putseqext();    putseqdispext();  }  /* optionally output some text data (description, copyright or whatever) */  if (strlen(id_string) > 1)    putuserdata(id_string);  /* loop through all frames in encoding/decoding order */  for (i=0; i<nframes; i++)  {    if (!quiet)    {      fprintf(stderr,"Encoding frame %d ",i);      fflush(stderr);    }    /* f0: lowest frame number in current GOP     *     * first GOP contains N-(M-1) frames,     * all other GOPs contain N frames     */    f0 = N*((i+(M-1))/N) - (M-1);    if (f0<0)      f0=0;    if (i==0 || (i-1)%M==0)    {      /* I or P frame */      for (j=0; j<3; j++)      {        /* shuffle reference frames */        neworg[j] = oldorgframe[j];        newref[j] = oldrefframe[j];        oldorgframe[j] = neworgframe[j];        oldrefframe[j] = newrefframe[j];        neworgframe[j] = neworg[j];        newrefframe[j] = newref[j];      }      /* f: frame number in display order */      f = (i==0) ? 0 : i+M-1;      if (f>=nframes)        f = nframes - 1;      if (i==f0) /* first displayed frame in GOP is I */      {        /* I frame */        pict_type = I_TYPE;        forw_hor_f_code = forw_vert_f_code = 15;        back_hor_f_code = back_vert_f_code = 15;        /* n: number of frames in current GOP         *         * first GOP contains (M-1) less (B) frames         */        n = (i==0) ? N-(M-1) : N;        /* last GOP may contain less frames */        if (n > nframes-f0)          n = nframes-f0;        /* number of P frames */        if (i==0)          np = (n + 2*(M-1))/M - 1; /* first GOP */        else          np = (n + (M-1))/M - 1;        /* number of B frames */        nb = n - np - 1;        rc_init_GOP(np,nb);        putgophdr(f0,i==0); /* set closed_GOP in first GOP only */      }      else      {        /* P frame */        pict_type = P_TYPE;        forw_hor_f_code = motion_data[0].forw_hor_f_code;        forw_vert_f_code = motion_data[0].forw_vert_f_code;        back_hor_f_code = back_vert_f_code = 15;        sxf = motion_data[0].sxf;        syf = motion_data[0].syf;      }    }    else    {      /* B frame */      for (j=0; j<3; j++)      {        neworg[j] = auxorgframe[j];        newref[j] = auxframe[j];      }      /* f: frame number in display order */      f = i - 1;      pict_type = B_TYPE;      n = (i-2)%M + 1; /* first B: n=1, second B: n=2, ... */      forw_hor_f_code = motion_data[n].forw_hor_f_code;      forw_vert_f_code = motion_data[n].forw_vert_f_code;      back_hor_f_code = motion_data[n].back_hor_f_code;      back_vert_f_code = motion_data[n].back_vert_f_code;      sxf = motion_data[n].sxf;      syf = motion_data[n].syf;      sxb = motion_data[n].sxb;      syb = motion_data[n].syb;    }    temp_ref = f - f0;    frame_pred_dct = frame_pred_dct_tab[pict_type-1];    q_scale_type = qscale_tab[pict_type-1];    intravlc = intravlc_tab[pict_type-1];    altscan = altscan_tab[pict_type-1];    fprintf(statfile,"\nFrame %d (#%d in display order):\n",i,f);    fprintf(statfile," picture_type=%c\n",ipb[pict_type]);    fprintf(statfile," temporal_reference=%d\n",temp_ref);    fprintf(statfile," frame_pred_frame_dct=%d\n",frame_pred_dct);    fprintf(statfile," q_scale_type=%d\n",q_scale_type);    fprintf(statfile," intra_vlc_format=%d\n",intravlc);    fprintf(statfile," alternate_scan=%d\n",altscan);    if (pict_type!=I_TYPE)    {      fprintf(statfile," forward search window: %d...%d / %d...%d\n",        -sxf,sxf,-syf,syf);      fprintf(statfile," forward vector range: %d...%d.5 / %d...%d.5\n",        -(4<<forw_hor_f_code),(4<<forw_hor_f_code)-1,        -(4<<forw_vert_f_code),(4<<forw_vert_f_code)-1);    }    if (pict_type==B_TYPE)    {      fprintf(statfile," backward search window: %d...%d / %d...%d\n",        -sxb,sxb,-syb,syb);      fprintf(statfile," backward vector range: %d...%d.5 / %d...%d.5\n",        -(4<<back_hor_f_code),(4<<back_hor_f_code)-1,        -(4<<back_vert_f_code),(4<<back_vert_f_code)-1);    }    sprintf(name,tplorg,f+frame0);    readframe(name,neworg);    if (fieldpic)    {      if (!quiet)      {        fprintf(stderr,"\nfirst field  (%s) ",topfirst ? "top" : "bot");        fflush(stderr);      }      pict_struct = topfirst ? TOP_FIELD : BOTTOM_FIELD;      motion_estimation(oldorgframe[0],neworgframe[0],                        oldrefframe[0],newrefframe[0],                        neworg[0],newref[0],                        sxf,syf,sxb,syb,mbinfo,0,0);      predict(oldrefframe,newrefframe,predframe,0,mbinfo);      dct_type_estimation(predframe[0],neworg[0],mbinfo);      transform(predframe,neworg,mbinfo,blocks);      putpict(neworg[0]);      for (k=0; k<mb_height2*mb_width; k++)      {        if (mbinfo[k].mb_type & MB_INTRA)          for (j=0; j<block_count; j++)            iquant_intra(blocks[k*block_count+j],blocks[k*block_count+j],                         dc_prec,intra_q,mbinfo[k].mquant);        else          for (j=0;j<block_count;j++)            iquant_non_intra(blocks[k*block_count+j],blocks[k*block_count+j],                             inter_q,mbinfo[k].mquant);      }      itransform(predframe,newref,mbinfo,blocks);      calcSNR(neworg,newref);      stats();      if (!quiet)      {        fprintf(stderr,"second field (%s) ",topfirst ? "bot" : "top");        fflush(stderr);      }      pict_struct = topfirst ? BOTTOM_FIELD : TOP_FIELD;      ipflag = (pict_type==I_TYPE);      if (ipflag)      {        /* first field = I, second field = P */        pict_type = P_TYPE;        forw_hor_f_code = motion_data[0].forw_hor_f_code;        forw_vert_f_code = motion_data[0].forw_vert_f_code;        back_hor_f_code = back_vert_f_code = 15;        sxf = motion_data[0].sxf;        syf = motion_data[0].syf;      }      motion_estimation(oldorgframe[0],neworgframe[0],                        oldrefframe[0],newrefframe[0],                        neworg[0],newref[0],                        sxf,syf,sxb,syb,mbinfo,1,ipflag);      predict(oldrefframe,newrefframe,predframe,1,mbinfo);      dct_type_estimation(predframe[0],neworg[0],mbinfo);      transform(predframe,neworg,mbinfo,blocks);      putpict(neworg[0]);      for (k=0; k<mb_height2*mb_width; k++)      {        if (mbinfo[k].mb_type & MB_INTRA)          for (j=0; j<block_count; j++)            iquant_intra(blocks[k*block_count+j],blocks[k*block_count+j],                         dc_prec,intra_q,mbinfo[k].mquant);        else          for (j=0;j<block_count;j++)            iquant_non_intra(blocks[k*block_count+j],blocks[k*block_count+j],                             inter_q,mbinfo[k].mquant);      }      itransform(predframe,newref,mbinfo,blocks);      calcSNR(neworg,newref);      stats();    }    else    {      pict_struct = FRAME_PICTURE;      /* do motion_estimation       *       * uses source frames (...orgframe) for full pel search       * and reconstructed frames (...refframe) for half pel search       */      motion_estimation(oldorgframe[0],neworgframe[0],                        oldrefframe[0],newrefframe[0],                        neworg[0],newref[0],                        sxf,syf,sxb,syb,mbinfo,0,0);      predict(oldrefframe,newrefframe,predframe,0,mbinfo);      dct_type_estimation(predframe[0],neworg[0],mbinfo);      transform(predframe,neworg,mbinfo,blocks);      putpict(neworg[0]);      for (k=0; k<mb_height*mb_width; k++)      {        if (mbinfo[k].mb_type & MB_INTRA)          for (j=0; j<block_count; j++)            iquant_intra(blocks[k*block_count+j],blocks[k*block_count+j],                         dc_prec,intra_q,mbinfo[k].mquant);        else          for (j=0;j<block_count;j++)            iquant_non_intra(blocks[k*block_count+j],blocks[k*block_count+j],                             inter_q,mbinfo[k].mquant);      }      itransform(predframe,newref,mbinfo,blocks);      calcSNR(neworg,newref);      stats();    }    sprintf(name,tplref,f+frame0);    writeframe(name,newref);  }  putseqend();}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区性放荡片| 成人激情小说乱人伦| 国内偷窥港台综合视频在线播放| 黄页视频在线91| 91在线视频官网| 欧美久久久一区| 国产清纯美女被跳蛋高潮一区二区久久w | 日韩午夜激情电影| 久久久不卡网国产精品二区| 亚洲欧美激情插| 另类小说综合欧美亚洲| 精品一区二区三区免费观看| 99精品偷自拍| 欧美性一级生活| 欧美精品一区二区久久久| 国产亚洲污的网站| 午夜天堂影视香蕉久久| 成人黄色软件下载| 欧美一级久久久| 亚洲精品久久久久久国产精华液| 久久成人精品无人区| av网站免费线看精品| 日韩视频中午一区| 亚洲乱码中文字幕| 国产成人在线免费观看| 欧美日韩精品欧美日韩精品| 国产精品情趣视频| 美女视频黄久久| 欧洲精品视频在线观看| 中文无字幕一区二区三区| 日日骚欧美日韩| 99v久久综合狠狠综合久久| 精品久久久久久亚洲综合网| 亚洲h在线观看| 一本到三区不卡视频| 久久婷婷国产综合国色天香| 亚洲大型综合色站| 99免费精品在线| 久久精品一区二区三区不卡| 美腿丝袜亚洲一区| 欧美军同video69gay| 亚洲综合激情另类小说区| www.视频一区| 国产欧美视频在线观看| 久久se这里有精品| 69av一区二区三区| 亚洲成人av中文| 色欧美88888久久久久久影院| 中文一区二区完整视频在线观看| 国内成+人亚洲+欧美+综合在线| 在线观看免费成人| 亚洲色图.com| av成人免费在线| 亚洲国产精品v| 国产伦精品一区二区三区视频青涩| 欧美丰满美乳xxx高潮www| 亚洲日本一区二区| 色婷婷亚洲综合| 亚洲靠逼com| 色综合久久久久综合| 国产精品不卡视频| 成人黄色免费短视频| 国产精品免费人成网站| 成人综合在线视频| 中文字幕不卡在线观看| 成人免费毛片片v| 欧美韩国一区二区| 成人免费va视频| 国产精品久久久久三级| 99久久夜色精品国产网站| 中文字幕一区二区在线播放| 成人小视频在线观看| 国产精品久久免费看| 国产美女主播视频一区| 久久久久国产精品麻豆| 丁香五精品蜜臀久久久久99网站 | 国产精品12区| 国产清纯白嫩初高生在线观看91| 国产成人在线视频网址| 亚洲国产精品99久久久久久久久| 大美女一区二区三区| 亚洲欧洲美洲综合色网| 一本到高清视频免费精品| 亚洲综合精品自拍| 91精品在线一区二区| 蓝色福利精品导航| 国产清纯美女被跳蛋高潮一区二区久久w| 成人性生交大片免费看视频在线| 成人欧美一区二区三区黑人麻豆 | 亚洲影院久久精品| 欧美熟乱第一页| 秋霞午夜av一区二区三区| 日韩女优电影在线观看| 国产成人精品网址| 亚洲日本电影在线| 欧美久久久久久久久久| 国产一区二区免费看| 国产精品电影院| 欧美色成人综合| 极品尤物av久久免费看| 国产精品久久久久久久久快鸭| 91蜜桃在线观看| 天天综合色天天综合| 亚洲精品一区二区三区蜜桃下载 | 亚洲国产日韩精品| 欧美一二三区在线观看| 国产成人午夜精品影院观看视频| 成人欧美一区二区三区在线播放| 欧美精选一区二区| 国产成人免费网站| 亚洲国产另类av| 国产亚洲欧美日韩日本| 欧洲精品视频在线观看| 国内精品伊人久久久久av一坑| 亚洲男女一区二区三区| 欧美一二三区在线观看| www.日本不卡| 免费三级欧美电影| 国产精品久线观看视频| 91精品国产综合久久精品| 粉嫩绯色av一区二区在线观看 | 日韩一区二区三区视频在线观看| 国产精品一区二区久久不卡| 亚洲男人的天堂在线aⅴ视频| 欧美成人精品1314www| 91香蕉视频污在线| 精品在线播放免费| 夜夜精品浪潮av一区二区三区| 精品免费日韩av| 欧美伊人久久大香线蕉综合69| 国产在线不卡视频| 国产欧美日韩三区| 91精品国产麻豆| 91女人视频在线观看| 久久草av在线| 午夜精品久久久久久不卡8050| 中文字幕不卡三区| 欧美大片日本大片免费观看| 91福利国产成人精品照片| 国产成人精品www牛牛影视| 国产精品久久久久一区| 欧美美女黄视频| 色综合天天在线| 久久精品二区亚洲w码| 亚洲在线视频网站| 亚洲精品一线二线三线| 91精品免费观看| caoporn国产精品| 国模冰冰炮一区二区| 亚洲成av人片观看| 一区二区三区产品免费精品久久75| 久久久精品人体av艺术| 日韩欧美国产高清| 欧美日韩mp4| 91国偷自产一区二区三区成为亚洲经典| 国产成人自拍在线| 国产一区二区三区免费在线观看| 日韩影院在线观看| 亚洲国产aⅴ天堂久久| 亚洲桃色在线一区| 国产精品―色哟哟| 欧美高清在线精品一区| 久久久久久久综合日本| 欧美r级电影在线观看| 欧美人伦禁忌dvd放荡欲情| 在线日韩av片| 一本大道av一区二区在线播放| 国产91丝袜在线播放九色| 精彩视频一区二区| 国产在线播放一区| 精品一二三四区| 欧美aaa在线| 日本va欧美va瓶| 日韩国产成人精品| 偷拍一区二区三区四区| 午夜私人影院久久久久| 亚洲v精品v日韩v欧美v专区| 亚洲图片一区二区| 日韩中文字幕麻豆| 日韩av一区二区在线影视| 亚洲成人综合视频| 日本午夜一区二区| 蜜臀精品久久久久久蜜臀| 美国精品在线观看| 九九精品一区二区| 国产老肥熟一区二区三区| 国产精品自拍一区| 成人小视频免费在线观看| 成人aa视频在线观看| 一本色道久久综合亚洲91| 在线观看亚洲精品视频| 欧美精品v国产精品v日韩精品| 宅男噜噜噜66一区二区66| 日韩美女视频一区二区在线观看| 日韩精品一区二区三区视频播放| 久久综合久久综合九色| 欧美激情艳妇裸体舞| 亚洲男人的天堂av| 午夜伦理一区二区| 琪琪一区二区三区|