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

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

?? stats.c

?? mpeg2編解標(biāo)準(zhǔn)源
?? C
字號:
/* stats.c, coding statistics                                               *//* 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 <math.h>#include "config.h"#include "global.h"/* private prototypes */static void calcSNR1 _ANSI_ARGS_((unsigned char *org, unsigned char *rec,  int lx, int w, int h, double *pv, double *pe));void calcSNR(org,rec)unsigned char *org[3];unsigned char *rec[3];{  int w,h,offs;  double v,e;  w = horizontal_size;  h = (pict_struct==FRAME_PICTURE) ? vertical_size : (vertical_size>>1);  offs = (pict_struct==BOTTOM_FIELD) ? width : 0;  calcSNR1(org[0]+offs,rec[0]+offs,width2,w,h,&v,&e);  fprintf(statfile,"Y: variance=%4.4g, MSE=%3.3g (%3.3g dB), SNR=%3.3g dB\n",    v, e, 10.0*log10(255.0*255.0/e), 10.0*log10(v/e));  if (chroma_format!=CHROMA444)  {    w >>= 1;    offs >>= 1;  }  if (chroma_format==CHROMA420)    h >>= 1;  calcSNR1(org[1]+offs,rec[1]+offs,chrom_width2,w,h,&v,&e);  fprintf(statfile,"U: variance=%4.4g, MSE=%3.3g (%3.3g dB), SNR=%3.3g dB\n",    v, e, 10.0*log10(255.0*255.0/e), 10.0*log10(v/e));  calcSNR1(org[2]+offs,rec[2]+offs,chrom_width2,w,h,&v,&e);  fprintf(statfile,"V: variance=%4.4g, MSE=%3.3g (%3.3g dB), SNR=%3.3g dB\n",    v, e, 10.0*log10(255.0*255.0/e), 10.0*log10(v/e));}static void calcSNR1(org,rec,lx,w,h,pv,pe)unsigned char *org;unsigned char *rec;int lx,w,h;double *pv,*pe;{  int i, j;  double v1, s1, s2, e2;  s1 = s2 = e2 = 0.0;  for (j=0; j<h; j++)  {    for (i=0; i<w; i++)    {      v1 = org[i];      s1+= v1;      s2+= v1*v1;      v1-= rec[i];      e2+= v1*v1;    }    org += lx;    rec += lx;  }  s1 /= w*h;  s2 /= w*h;  e2 /= w*h;  /* prevent division by zero in calcSNR() */  if(e2==0.0)    e2 = 0.00001;  *pv = s2 - s1*s1; /* variance */  *pe = e2;         /* MSE */}void stats(){  int i, j, k, nmb, mb_type;  int n_skipped, n_intra, n_ncoded, n_blocks, n_interp, n_forward, n_backward;  struct mbinfo *mbi;  nmb = mb_width*mb_height2;  n_skipped=n_intra=n_ncoded=n_blocks=n_interp=n_forward=n_backward=0;  for (k=0; k<nmb; k++)  {    mbi = mbinfo+k;    if (mbi->skipped)      n_skipped++;    else if (mbi->mb_type & MB_INTRA)      n_intra++;    else if (!(mbi->mb_type & MB_PATTERN))      n_ncoded++;    for (i=0; i<block_count; i++)      if (mbi->cbp & (1<<i))        n_blocks++;    if (mbi->mb_type & MB_FORWARD)    {      if (mbi->mb_type & MB_BACKWARD)        n_interp++;      else        n_forward++;    }    else if (mbi->mb_type & MB_BACKWARD)      n_backward++;  }  fprintf(statfile,"\npicture statistics:\n");  fprintf(statfile," # of intra coded macroblocks:  %4d (%.1f%%)\n",    n_intra,100.0*(double)n_intra/nmb);  fprintf(statfile," # of coded blocks:             %4d (%.1f%%)\n",    n_blocks,100.0*(double)n_blocks/(block_count*nmb));  fprintf(statfile," # of not coded macroblocks:    %4d (%.1f%%)\n",    n_ncoded,100.0*(double)n_ncoded/nmb);  fprintf(statfile," # of skipped macroblocks:      %4d (%.1f%%)\n",    n_skipped,100.0*(double)n_skipped/nmb);  fprintf(statfile," # of forw. pred. macroblocks:  %4d (%.1f%%)\n",    n_forward,100.0*(double)n_forward/nmb);  fprintf(statfile," # of backw. pred. macroblocks: %4d (%.1f%%)\n",    n_backward,100.0*(double)n_backward/nmb);  fprintf(statfile," # of interpolated macroblocks: %4d (%.1f%%)\n",    n_interp,100.0*(double)n_interp/nmb);  fprintf(statfile,"\nmacroblock_type map:\n");  k = 0;  for (j=0; j<mb_height2; j++)  {    for (i=0; i<mb_width; i++)    {      mbi = mbinfo + k;      mb_type = mbi->mb_type;      if (mbi->skipped)        putc('S',statfile);      else if (mb_type & MB_INTRA)        putc('I',statfile);      else switch (mb_type & (MB_FORWARD|MB_BACKWARD))      {      case MB_FORWARD:        putc(mbi->motion_type==MC_FIELD ? 'f' :             mbi->motion_type==MC_DMV   ? 'p' :                                          'F',statfile); break;      case MB_BACKWARD:        putc(mbi->motion_type==MC_FIELD ? 'b' :                                          'B',statfile); break;      case MB_FORWARD|MB_BACKWARD:        putc(mbi->motion_type==MC_FIELD ? 'd' :                                          'D',statfile); break;      default:        putc('0',statfile); break;      }      if (mb_type & MB_QUANT)        putc('Q',statfile);      else if (mb_type & (MB_PATTERN|MB_INTRA))        putc(' ',statfile);      else        putc('N',statfile);      putc(' ',statfile);      k++;    }    putc('\n',statfile);  }  fprintf(statfile,"\nmquant map:\n");  k=0;  for (j=0; j<mb_height2; j++)  {    for (i=0; i<mb_width; i++)    {      if (i==0 || mbinfo[k].mquant!=mbinfo[k-1].mquant)        fprintf(statfile,"%3d",mbinfo[k].mquant);      else        fprintf(statfile,"   ");      k++;    }    putc('\n',statfile);  }#if 0  fprintf(statfile,"\ncbp map:\n");  k=0;  for (j=0; j<mb_height2; j++)  {    for (i=0; i<mb_width; i++)    {      fprintf(statfile,"%02x ",mbinfo[k].cbp);      k++;    }    putc('\n',statfile);  }  if (pict_struct==FRAME_PICTURE && !frame_pred_dct)  {    fprintf(statfile,"\ndct_type map:\n");    k=0;    for (j=0; j<mb_height2; j++)    {      for (i=0; i<mb_width; i++)      {        if (mbinfo[k].mb_type & (MB_PATTERN|MB_INTRA))          fprintf(statfile,"%d  ",mbinfo[k].dct_type);        else          fprintf(statfile,"   ");          k++;      }      putc('\n',statfile);    }  }  if (pict_type!=I_TYPE)  {    fprintf(statfile,"\nforward motion vectors (first vector, horizontal):\n");    k=0;    for (j=0; j<mb_height2; j++)    {      for (i=0; i<mb_width; i++)      {        if (mbinfo[k].mb_type & MB_FORWARD)          fprintf(statfile,"%4d",mbinfo[k].MV[0][0][0]);        else          fprintf(statfile,"   .");          k++;      }      putc('\n',statfile);    }    fprintf(statfile,"\nforward motion vectors (first vector, vertical):\n");    k=0;    for (j=0; j<mb_height2; j++)    {      for (i=0; i<mb_width; i++)      {        if (mbinfo[k].mb_type & MB_FORWARD)          fprintf(statfile,"%4d",mbinfo[k].MV[0][0][1]);        else          fprintf(statfile,"   .");          k++;      }      putc('\n',statfile);    }    fprintf(statfile,"\nforward motion vectors (second vector, horizontal):\n");    k=0;    for (j=0; j<mb_height2; j++)    {      for (i=0; i<mb_width; i++)      {        if (mbinfo[k].mb_type & MB_FORWARD            && ((pict_struct==FRAME_PICTURE && mbinfo[k].motion_type==MC_FIELD) ||                (pict_struct!=FRAME_PICTURE && mbinfo[k].motion_type==MC_16X8)))          fprintf(statfile,"%4d",mbinfo[k].MV[1][0][0]);        else          fprintf(statfile,"   .");          k++;      }      putc('\n',statfile);    }    fprintf(statfile,"\nforward motion vectors (second vector, vertical):\n");    k=0;    for (j=0; j<mb_height2; j++)    {      for (i=0; i<mb_width; i++)      {        if (mbinfo[k].mb_type & MB_FORWARD            && ((pict_struct==FRAME_PICTURE && mbinfo[k].motion_type==MC_FIELD) ||                (pict_struct!=FRAME_PICTURE && mbinfo[k].motion_type==MC_16X8)))          fprintf(statfile,"%4d",mbinfo[k].MV[1][0][1]);        else          fprintf(statfile,"   .");          k++;      }      putc('\n',statfile);    }  }      if (pict_type==B_TYPE)  {    fprintf(statfile,"\nbackward motion vectors (first vector, horizontal):\n");    k=0;    for (j=0; j<mb_height2; j++)    {      for (i=0; i<mb_width; i++)      {        if (mbinfo[k].mb_type & MB_BACKWARD)          fprintf(statfile,"%4d",mbinfo[k].MV[0][1][0]);        else          fprintf(statfile,"   .");          k++;      }      putc('\n',statfile);    }    fprintf(statfile,"\nbackward motion vectors (first vector, vertical):\n");    k=0;    for (j=0; j<mb_height2; j++)    {      for (i=0; i<mb_width; i++)      {        if (mbinfo[k].mb_type & MB_BACKWARD)          fprintf(statfile,"%4d",mbinfo[k].MV[0][1][1]);        else          fprintf(statfile,"   .");          k++;      }      putc('\n',statfile);    }    fprintf(statfile,"\nbackward motion vectors (second vector, horizontal):\n");    k=0;    for (j=0; j<mb_height2; j++)    {      for (i=0; i<mb_width; i++)      {        if (mbinfo[k].mb_type & MB_BACKWARD            && ((pict_struct==FRAME_PICTURE && mbinfo[k].motion_type==MC_FIELD) ||                (pict_struct!=FRAME_PICTURE && mbinfo[k].motion_type==MC_16X8)))          fprintf(statfile,"%4d",mbinfo[k].MV[1][1][0]);        else          fprintf(statfile,"   .");          k++;      }      putc('\n',statfile);    }    fprintf(statfile,"\nbackward motion vectors (second vector, vertical):\n");    k=0;    for (j=0; j<mb_height2; j++)    {      for (i=0; i<mb_width; i++)      {        if (mbinfo[k].mb_type & MB_BACKWARD            && ((pict_struct==FRAME_PICTURE && mbinfo[k].motion_type==MC_FIELD) ||                (pict_struct!=FRAME_PICTURE && mbinfo[k].motion_type==MC_16X8)))          fprintf(statfile,"%4d",mbinfo[k].MV[1][1][1]);        else          fprintf(statfile,"   .");          k++;      }      putc('\n',statfile);    }  }#endif    #if 0  /* useful for debugging */  fprintf(statfile,"\nmacroblock info dump:\n");  k=0;  for (j=0; j<mb_height2; j++)  {    for (i=0; i<mb_width; i++)    {      fprintf(statfile,"%d: %d %d %d %d %d %d %d %d %d %d %d %d %d %d %d %d %d %d\n",      k,      mbinfo[k].mb_type,      mbinfo[k].motion_type,      mbinfo[k].dct_type,      mbinfo[k].mquant,      mbinfo[k].cbp,      mbinfo[k].skipped,      mbinfo[k].MV[0][0][0],      mbinfo[k].MV[0][0][1],      mbinfo[k].MV[0][1][0],      mbinfo[k].MV[0][1][1],      mbinfo[k].MV[1][0][0],      mbinfo[k].MV[1][0][1],      mbinfo[k].MV[1][1][0],      mbinfo[k].MV[1][1][1],      mbinfo[k].mv_field_sel[0][0],      mbinfo[k].mv_field_sel[0][1],      mbinfo[k].mv_field_sel[1][0],      mbinfo[k].mv_field_sel[1][1]);      k++;    }  }#endif}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
bt7086福利一区国产| 欧美伊人久久久久久久久影院 | 成人午夜大片免费观看| 亚洲精品国产第一综合99久久| 欧美一区二区在线免费观看| 99久久精品免费看国产| 激情六月婷婷久久| 亚洲最新视频在线播放| 日本一区二区免费在线观看视频 | 91网上在线视频| 激情综合色播激情啊| 亚洲一区二区三区免费视频| 久久久久久9999| 欧美一级一级性生活免费录像| 成人免费毛片aaaaa**| 久久99在线观看| 午夜影院久久久| 日韩一区在线免费观看| 国产欧美精品一区aⅴ影院| 91精品国产综合久久久久久漫画 | 91精品黄色片免费大全| 色av一区二区| 丁香婷婷综合色啪| 美女网站在线免费欧美精品| 亚洲成人动漫精品| 亚洲一二三区在线观看| 亚洲人妖av一区二区| 欧美激情一区在线观看| 欧美精品一区二区三区蜜桃视频| 欧美日免费三级在线| 色噜噜狠狠一区二区三区果冻| 国产激情精品久久久第一区二区| 久久国产精品99精品国产| 婷婷开心久久网| 亚洲一线二线三线久久久| 一区二区欧美在线观看| 亚洲精选免费视频| 亚洲精品中文在线影院| 日韩美女视频一区| 亚洲日本在线天堂| 一区二区三区在线观看欧美| 亚洲另类春色国产| 亚洲免费av在线| 亚洲影院免费观看| 亚洲国产成人91porn| 一区二区三区精品视频在线| 亚洲免费电影在线| 亚洲大尺度视频在线观看| 亚洲一区二区五区| 午夜国产精品影院在线观看| 香蕉成人啪国产精品视频综合网| 日韩1区2区日韩1区2区| 久久精品噜噜噜成人av农村| 久久精工是国产品牌吗| 激情综合亚洲精品| 国产91精品一区二区| 91蜜桃在线免费视频| 欧美亚洲另类激情小说| 欧美乱妇20p| 欧美成人精精品一区二区频| 久久精品综合网| 国产精品福利av| 一区二区三区欧美在线观看| 亚洲福利一区二区三区| 久久国产精品99久久久久久老狼 | 9191精品国产综合久久久久久| 欧美精品久久久久久久多人混战| 宅男噜噜噜66一区二区66| 精品国产人成亚洲区| 国产精品麻豆99久久久久久| 亚洲美女精品一区| 奇米影视在线99精品| 国产在线精品免费| 色狠狠一区二区| 日韩视频免费观看高清在线视频| 2014亚洲片线观看视频免费| 中文字幕一区免费在线观看 | 韩国欧美国产1区| a美女胸又www黄视频久久| 欧美巨大另类极品videosbest| 日韩精品一区二区三区在线观看 | 精品国产麻豆免费人成网站| 中文字幕免费不卡在线| 天天综合色天天| 国产精品一线二线三线| 欧美亚一区二区| 久久久欧美精品sm网站| 亚洲综合清纯丝袜自拍| 韩国成人在线视频| 欧美午夜一区二区三区| www国产精品av| 亚洲国产日韩一区二区| 国产麻豆精品在线观看| 欧美乱熟臀69xxxxxx| 国产日韩欧美不卡| 性感美女久久精品| av在线不卡免费看| 欧美一区日韩一区| 中文字幕一区二区三区精华液 | 欧美经典一区二区| 日产国产欧美视频一区精品| 国产成人午夜99999| 欧美日韩国产大片| 国产精品天干天干在线综合| 蜜臀av性久久久久蜜臀aⅴ四虎| 99综合影院在线| 精品久久久三级丝袜| 亚洲一区在线免费观看| 北条麻妃国产九九精品视频| 欧美一区二区三级| 亚洲地区一二三色| 91麻豆成人久久精品二区三区| 日韩一区二区精品葵司在线| 亚洲成av人片| a美女胸又www黄视频久久| 制服.丝袜.亚洲.中文.综合| 亚洲综合色婷婷| 白白色亚洲国产精品| 国产视频一区二区在线观看| 蜜桃精品在线观看| 在线电影一区二区三区| 亚洲一级不卡视频| 91蜜桃免费观看视频| 欧美国产欧美综合| 成人中文字幕电影| 久久精品视频一区二区三区| 男男gaygay亚洲| 欧美一级在线观看| 日韩一区欧美二区| 4hu四虎永久在线影院成人| 亚洲在线观看免费| 在线观看亚洲精品| 亚洲裸体在线观看| 色综合久久久久| 一区二区三区四区乱视频| av色综合久久天堂av综合| 国产精品乱人伦中文| 不卡av在线免费观看| 欧美国产丝袜视频| k8久久久一区二区三区| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 日韩午夜在线观看视频| 日本va欧美va欧美va精品| 欧美电影免费观看高清完整版在线 | 91精品国产色综合久久不卡电影| 亚洲亚洲精品在线观看| 欧美久久久久久久久久| 日韩电影免费一区| 日韩免费福利电影在线观看| 国内精品嫩模私拍在线| 久久久www成人免费毛片麻豆 | 99vv1com这只有精品| 最新日韩av在线| 欧美影院精品一区| 日本女优在线视频一区二区| 久久久蜜桃精品| 972aa.com艺术欧美| 亚洲精品乱码久久久久久日本蜜臀 | 99视频精品在线| 亚洲综合在线免费观看| 欧美日韩国产一级二级| 免费人成黄页网站在线一区二区 | 亚洲国产日日夜夜| 日韩一区二区精品| 成人性生交大片免费看在线播放| 国产精品麻豆视频| 欧美精品久久一区| 久久不见久久见中文字幕免费| 国产三级一区二区| 色综合婷婷久久| 视频一区视频二区中文| ww久久中文字幕| 色一区在线观看| 久久成人免费日本黄色| 国产精品家庭影院| 欧美电影在哪看比较好| 国产精品一区二区久久不卡| 亚洲免费资源在线播放| 91精品国产色综合久久不卡蜜臀| 国产成都精品91一区二区三| 一区二区免费在线| 精品999久久久| 色哟哟一区二区在线观看| 狠狠色伊人亚洲综合成人| 亚洲免费在线视频| 久久久不卡网国产精品二区 | 91精品欧美一区二区三区综合在| 国产99久久久久| 午夜精品久久久久久久久| 久久亚洲影视婷婷| 欧美三级中文字| 国产成人精品免费一区二区| 亚洲国产成人av好男人在线观看| 久久人人97超碰com| 欧美日韩中字一区| 成人做爰69片免费看网站| 蜜臀久久久久久久| 亚洲欧美一区二区三区孕妇| 久久五月婷婷丁香社区| 欧美日韩精品系列|