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

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

?? image.c

?? h264標準的VC實現
?? C
?? 第 1 頁 / 共 4 頁
字號:

/*!
 ***********************************************************************
 * \file image.c
 *
 * \brief
 *    Decode a Slice
 *
 * \author
 *    Main contributors (see contributors.h for copyright, address and affiliation details)
 *    - Inge Lille-Lang鴜               <inge.lille-langoy@telenor.com>
 *    - Rickard Sjoberg                 <rickard.sjoberg@era.ericsson.se>
 *    - Jani Lainema                    <jani.lainema@nokia.com>
 *    - Sebastian Purreiter             <sebastian.purreiter@mch.siemens.de>
 *    - Byeong-Moon Jeon                <jeonbm@lge.com>
 *    - Thomas Wedi                     <wedi@tnt.uni-hannover.de>
 *    - Gabi Blaettermann               <blaetter@hhi.de>
 *    - Ye-Kui Wang                     <wyk@ieee.org>
 *    - Antti Hallapuro                 <antti.hallapuro@nokia.com>
 *    - Alexis Tourapis                 <alexismt@ieee.org>
 ***********************************************************************
 */

#include "contributors.h"

#include <math.h>
#include <limits.h>
#include <stdlib.h>
#include <string.h>
#include <assert.h>

#ifdef WIN32
#include <io.h>
#else
#include <unistd.h>
#endif

#include "global.h"
#include "errorconcealment.h"
#include "image.h"
#include "mbuffer.h"
#include "fmo.h"
#include "nalu.h"
#include "parsetcommon.h"
#include "parset.h"
#include "header.h"
#include "rtp.h"
#include "sei.h"
#include "output.h"
#include "biaridecod.h"
#include "mb_access.h"
#include "memalloc.h"
#include "annexb.h"

#include "context_ini.h"
#include "cabac.h"
#include "loopfilter.h"

#include "vlc.h"

#include "erc_api.h"
extern objectBuffer_t *erc_object_list;
extern ercVariables_t *erc_errorVar;
extern frame erc_recfr;
extern int erc_mvperMB;
extern struct img_par *erc_img;

//extern FILE *p_out2;

extern StorablePicture **listX[6];
extern ColocatedParams *Co_located;

StorablePicture *dec_picture;

OldSliceParams old_slice;

void MbAffPostProc()
{
  imgpel temp[16][32];

  imgpel ** imgY  = dec_picture->imgY;
  imgpel ***imgUV = dec_picture->imgUV;

  int i, x, y, x0, y0, uv;
  for (i=0; i<(int)dec_picture->PicSizeInMbs; i+=2)
  {
    if (dec_picture->mb_field[i])
    {
      get_mb_pos(i, &x0, &y0);
      for (y=0; y<(2*MB_BLOCK_SIZE);y++)
        for (x=0; x<MB_BLOCK_SIZE; x++)
          temp[x][y] = imgY[y0+y][x0+x];

      for (y=0; y<MB_BLOCK_SIZE;y++)
        for (x=0; x<MB_BLOCK_SIZE; x++)
        {
          imgY[y0+(2*y)][x0+x]   = temp[x][y];
          imgY[y0+(2*y+1)][x0+x] = temp[x][y+MB_BLOCK_SIZE];
        }

      if (img->yuv_format != YUV400)
      {
        x0 = x0 / (16/img->mb_cr_size_x);
        y0 = y0 / (16/img->mb_cr_size_y);

        for (uv=0; uv<2; uv++)
        {
          for (y=0; y<(2*img->mb_cr_size_y);y++)
            for (x=0; x<img->mb_cr_size_x; x++)
              temp[x][y] = imgUV[uv][y0+y][x0+x];
          
          for (y=0; y<img->mb_cr_size_y;y++)
            for (x=0; x<img->mb_cr_size_x; x++)
            {
              imgUV[uv][y0+(2*y)][x0+x]   = temp[x][y];
              imgUV[uv][y0+(2*y+1)][x0+x] = temp[x][y+img->mb_cr_size_y];
            }
        }
      }
    }
  }
}

/*!
 ***********************************************************************
 * \brief
 *    decodes one I- or P-frame
 *
 ***********************************************************************
 */

int decode_one_frame(struct img_par *img,struct inp_par *inp, struct snr_par *snr)
{
  int current_header;
  Slice *currSlice = img->currentSlice;

  img->current_slice_nr = 0;
  img->current_mb_nr = -4711;     // initialized to an impossible value for debugging -- correct value is taken from slice header
  currSlice->next_header = -8888; // initialized to an impossible value for debugging -- correct value is taken from slice header
  img->num_dec_mb = 0;
  img->newframe = 1;

  while ((currSlice->next_header != EOS && currSlice->next_header != SOP))
  {
    current_header = read_new_slice();

    if (current_header == EOS)
    {
      exit_picture();
      return EOS;
    }

    decode_slice(img, inp, current_header);

    img->newframe = 0;
    img->current_slice_nr++;
  }

  exit_picture();

  return (SOP);
}


/*!
************************************************************************
* \brief
*    Find PSNR for all three components.Compare decoded frame with
*    the original sequence. Read inp->jumpd frames to reflect frame skipping.
************************************************************************
*/
void find_snr(
              struct snr_par  *snr,   //!< pointer to snr parameters
              StorablePicture *p,     //!< picture to be compared
              int p_ref)              //!< open reference YUV file
{
  int i,j;
  int64 diff_y,diff_u,diff_v;
  int uv;
  int64  status;
  int symbol_size_in_bytes = img->pic_unit_bitsize_on_disk/8;
  int64 framesize_in_bytes = (((int64)p->size_y*p->size_x) + ((int64)p->size_y_cr*p->size_x_cr)*2) * symbol_size_in_bytes;
  unsigned int max_pix_value_sqd = img->max_imgpel_value * img->max_imgpel_value;
  unsigned int max_pix_value_sqd_uv = img->max_imgpel_value_uv * img->max_imgpel_value_uv;
  Boolean rgb_output = (active_sps->vui_seq_parameters.matrix_coefficients==0);
  
  char *buf;

// calculate frame number
  int  psnrPOC = active_sps->mb_adaptive_frame_field_flag ? p->poc /(input->poc_scale) : p->poc/(3-input->poc_scale);
  

  if (psnrPOC==0 && img->psnr_number)
    img->idr_psnr_number=img->psnr_number + 1;
  img->psnr_number=max(img->psnr_number,img->idr_psnr_number+psnrPOC);

  frame_no = img->idr_psnr_number+psnrPOC;

  // KS: this buffer should actually be allocated only once, but this is still much faster than the previous version
  buf = malloc (p->size_y*p->size_x*symbol_size_in_bytes);

  if (NULL == buf)
  {
    no_mem_exit("find_snr: buf");
  }

  status = lseek (p_ref, framesize_in_bytes*frame_no, SEEK_SET);
  if (status == -1)
  {
    fprintf(stderr, "Error in seeking frame number: %d\n", frame_no);
    free (buf);
    return;
  }

  if(rgb_output)
    lseek (p_ref, framesize_in_bytes/3, SEEK_CUR);

  read(p_ref, buf, p->size_y*p->size_x*symbol_size_in_bytes);

  for (j=0; j < p->size_y; j++)
    for (i=0; i < p->size_x; i++)
    {
      imgY_ref[j][i]=0;
      memcpy(&(imgY_ref[j][i]), buf +((j*p->size_x+i)*symbol_size_in_bytes), symbol_size_in_bytes);
    }

  if (img->yuv_format != YUV400)
  {
    for (uv=0; uv < 2; uv++)
    {
      if(rgb_output && uv==1)
        lseek (p_ref, -framesize_in_bytes, SEEK_CUR);
    
      read(p_ref, buf, p->size_y_cr*p->size_x_cr*symbol_size_in_bytes);
    
      for (j=0; j < p->size_y_cr ; j++)
        for (i=0; i < p->size_x_cr; i++)
          memcpy(&(imgUV_ref[uv][j][i]), buf +((j*p->size_x_cr+i)*symbol_size_in_bytes), symbol_size_in_bytes);
    }
  }

   if(rgb_output) 
     lseek (p_ref, framesize_in_bytes*2/3, SEEK_CUR);
  
  free (buf);

  img->quad[0]=0;
  diff_y=0;
  for (j=0; j < p->size_y; ++j)
  {
    for (i=0; i < p->size_x; ++i)
    {
      diff_y += img->quad[abs(p->imgY[j][i]-imgY_ref[j][i])];
    }
  }

  // Chroma
  diff_u=0;
  diff_v=0;
  
  if (img->yuv_format != YUV400)
  {
    for (j=0; j < p->size_y_cr; ++j)
    {
      for (i=0; i < p->size_x_cr; ++i)
      {
        diff_u += img->quad[abs(imgUV_ref[0][j][i]-p->imgUV[0][j][i])];
        diff_v += img->quad[abs(imgUV_ref[1][j][i]-p->imgUV[1][j][i])];
      }
    }
  }

/*  if (diff_y == 0)
      diff_y = 1;
  if (diff_u == 0)
      diff_u = 1;
  if (diff_v == 0)
      diff_v = 1; */

  // Collecting SNR statistics
  if (diff_y != 0)
    snr->snr_y=(float)(10*log10(max_pix_value_sqd*(double)((double)(img->width)*(img->height) / diff_y)));        // luma snr for current frame
  else
    snr->snr_y=0;
  if (diff_u != 0)
    snr->snr_u=(float)(10*log10(max_pix_value_sqd_uv*(double)((double)(img->width_cr)*(img->height_cr) / (diff_u))));    //  chroma snr for current frame
  else
    snr->snr_u=0;
  if (diff_v != 0)
    snr->snr_v=(float)(10*log10(max_pix_value_sqd_uv*(double)((double)(img->width_cr)*(img->height_cr) / (diff_v))));    //  chroma snr for current frame
  else
    snr->snr_v=0;

  if (img->number == 0) // first
  {
    snr->snr_ya=snr->snr_y1=snr->snr_y;                                                        // keep luma snr for first frame
    snr->snr_ua=snr->snr_u1=snr->snr_u;                                                        // keep chroma snr for first frame
    snr->snr_va=snr->snr_v1=snr->snr_v;                                                        // keep chroma snr for first frame
  
  }
  else
  {
    snr->snr_ya=(float)(snr->snr_ya*(img->number+Bframe_ctr)+snr->snr_y)/(img->number+Bframe_ctr+1); // average snr chroma for all frames
    snr->snr_ua=(float)(snr->snr_ua*(img->number+Bframe_ctr)+snr->snr_u)/(img->number+Bframe_ctr+1); // average snr luma for all frames
    snr->snr_va=(float)(snr->snr_va*(img->number+Bframe_ctr)+snr->snr_v)/(img->number+Bframe_ctr+1); // average snr luma for all frames
  } 
}


/*!
 ************************************************************************
 * \brief
 *    Interpolation of 1/4 subpixel
 ************************************************************************
 */
void get_block(int ref_frame, StorablePicture **list, int x_pos, int y_pos, struct img_par *img, int block[BLOCK_SIZE][BLOCK_SIZE])
{

  int dx, dy;
  int x, y;
  int i, j;
  int maxold_x,maxold_y;
  int result;
  int pres_x;
  int pres_y; 
  int tmp_res[4][9];
  static const int COEF[6] = {    1, -5, 20, 20, -5, 1  };

  dx = x_pos&3;
  dy = y_pos&3;
  x_pos = (x_pos-dx)/4;
  y_pos = (y_pos-dy)/4;

  maxold_x = dec_picture->size_x-1;
  maxold_y = dec_picture->size_y-1;

  if (dec_picture->mb_field[img->current_mb_nr])
    maxold_y = dec_picture->size_y/2 - 1;

  if (dx == 0 && dy == 0) {  /* fullpel position */
    for (j = 0; j < BLOCK_SIZE; j++)
      for (i = 0; i < BLOCK_SIZE; i++)
        block[i][j] = list[ref_frame]->imgY[max(0,min(maxold_y,y_pos+j))][max(0,min(maxold_x,x_pos+i))];
  }
  else { /* other positions */

    if (dy == 0) { /* No vertical interpolation */

      for (j = 0; j < BLOCK_SIZE; j++) {
        for (i = 0; i < BLOCK_SIZE; i++) {
          for (result = 0, x = -2; x < 4; x++)
            result += list[ref_frame]->imgY[max(0,min(maxold_y,y_pos+j))][max(0,min(maxold_x,x_pos+i+x))]*COEF[x+2];
          block[i][j] = max(0, min(img->max_imgpel_value, (result+16)/32));
        }
      }

      if ((dx&1) == 1) {
        for (j = 0; j < BLOCK_SIZE; j++)
          for (i = 0; i < BLOCK_SIZE; i++)
            block[i][j] = (block[i][j] + list[ref_frame]->imgY[max(0,min(maxold_y,y_pos+j))][max(0,min(maxold_x,x_pos+i+dx/2))] +1 )/2;
      }
    }
    else if (dx == 0) {  /* No horizontal interpolation */

      for (j = 0; j < BLOCK_SIZE; j++) {
        for (i = 0; i < BLOCK_SIZE; i++) {
          for (result = 0, y = -2; y < 4; y++)
            result += list[ref_frame]->imgY[max(0,min(maxold_y,y_pos+j+y))][max(0,min(maxold_x,x_pos+i))]*COEF[y+2];
          block[i][j] = max(0, min(img->max_imgpel_value, (result+16)/32));
        }
      }

      if ((dy&1) == 1) {
        for (j = 0; j < BLOCK_SIZE; j++)
          for (i = 0; i < BLOCK_SIZE; i++)
           block[i][j] = (block[i][j] + list[ref_frame]->imgY[max(0,min(maxold_y,y_pos+j+dy/2))][max(0,min(maxold_x,x_pos+i))] +1 )/2;
      }
    }
    else if (dx == 2) {  /* Vertical & horizontal interpolation */

      for (j = -2; j < BLOCK_SIZE+3; j++) {
        for (i = 0; i < BLOCK_SIZE; i++)
          for (tmp_res[i][j+2] = 0, x = -2; x < 4; x++)
            tmp_res[i][j+2] += list[ref_frame]->imgY[max(0,min(maxold_y,y_pos+j))][max(0,min(maxold_x,x_pos+i+x))]*COEF[x+2];
      }

      for (j = 0; j < BLOCK_SIZE; j++) {
        for (i = 0; i < BLOCK_SIZE; i++) {
          for (result = 0, y = -2; y < 4; y++)
            result += tmp_res[i][j+y+2]*COEF[y+2];
          block[i][j] = max(0, min(img->max_imgpel_value, (result+512)/1024));
        } 
      }

      if ((dy&1) == 1) {
        for (j = 0; j < BLOCK_SIZE; j++)
          for (i = 0; i < BLOCK_SIZE; i++)
            block[i][j] = (block[i][j] + max(0, min(img->max_imgpel_value, (tmp_res[i][j+2+dy/2]+16)/32)) +1 )/2;
      }
    }
    else if (dy == 2) {  /* Horizontal & vertical interpolation */

      for (j = 0; j < BLOCK_SIZE; j++) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲图片欧美视频| 欧美经典一区二区| 日韩电影免费在线| 欧美猛男gaygay网站| 日韩av网站在线观看| 欧美草草影院在线视频| 国产成人日日夜夜| 欧美激情一区二区| 欧美视频一区二区在线观看| 日日夜夜一区二区| 久久久久国产精品人| 成人黄色av电影| 午夜精品一区二区三区电影天堂 | 天天亚洲美女在线视频| 日韩三级av在线播放| 国产精品羞羞答答xxdd | 亚洲第一av色| 欧美一级理论片| 成人晚上爱看视频| 亚洲福利国产精品| 国产性天天综合网| 色天天综合色天天久久| 另类成人小视频在线| 中文字幕一区二区三中文字幕| 在线观看成人免费视频| 久久99精品久久久久久国产越南| 国产精品美女视频| 7777女厕盗摄久久久| 国产91对白在线观看九色| 亚洲一二三区在线观看| 久久综合一区二区| 欧美日韩在线播放三区| 国产成人日日夜夜| 日本vs亚洲vs韩国一区三区二区| 国产欧美一区视频| 日韩一区二区免费电影| 91视视频在线观看入口直接观看www | 色婷婷综合视频在线观看| 免费成人小视频| 亚洲人成精品久久久久| 亚洲精品在线免费播放| 欧美系列日韩一区| av网站一区二区三区| 久久精品999| 亚洲成人精品在线观看| 国产精品免费看片| 欧美大肚乱孕交hd孕妇| 色88888久久久久久影院按摩 | 成人蜜臀av电影| 麻豆专区一区二区三区四区五区| 亚洲免费三区一区二区| 亚洲国产高清不卡| 精品国内片67194| 欧美男男青年gay1069videost | 午夜精品久久久久| 亚洲天堂2016| 国产精品高清亚洲| 亚洲高清在线视频| 亚洲欧美偷拍三级| 国产精品久线在线观看| 久久久精品国产免大香伊 | 蜜桃传媒麻豆第一区在线观看| 亚洲香肠在线观看| 亚洲精品视频免费观看| 中文字幕制服丝袜成人av| 欧美激情在线一区二区三区| 91精品午夜视频| 欧美一区二区三区在线观看视频| 色欧美日韩亚洲| 色丁香久综合在线久综合在线观看 | 国产精品女上位| 国产欧美日韩另类一区| 欧美精彩视频一区二区三区| 久久精品日产第一区二区三区高清版 | 欧日韩精品视频| 欧美在线观看视频一区二区三区 | 成人一道本在线| 国产91清纯白嫩初高中在线观看| 国产一区二区91| 国产精品自产自拍| 成人综合在线视频| 91年精品国产| 在线一区二区三区四区五区| 91九色最新地址| 在线播放视频一区| 欧美一卡二卡三卡四卡| 日韩欧美资源站| 久久久www成人免费毛片麻豆| 久久久久久久网| 中文字幕一区二区三区四区不卡| 国产精品少妇自拍| 亚洲小说欧美激情另类| 蜜芽一区二区三区| 国产一区二区三区在线观看免费视频| 国产精品 欧美精品| a亚洲天堂av| 欧美高清性hdvideosex| 精品免费国产二区三区| 欧美国产精品一区二区| 亚洲视频一区二区在线| 亚洲成年人网站在线观看| 蜜臂av日日欢夜夜爽一区| 国产传媒欧美日韩成人| 国产女人aaa级久久久级| 国产精品水嫩水嫩| 亚洲成人av一区| 国产一区二区三区国产| 91精品1区2区| 日韩美女在线视频| 日韩一区欧美小说| 日韩高清一区二区| 高清beeg欧美| 欧美精选在线播放| 欧美高清在线视频| 亚洲成va人在线观看| 国产精品亚洲第一区在线暖暖韩国| 97成人超碰视| 91麻豆精品国产无毒不卡在线观看 | 午夜精品一区二区三区电影天堂 | 亚洲一区电影777| 韩国毛片一区二区三区| 99久久精品久久久久久清纯| 欧美美女网站色| 国产精品毛片无遮挡高清| 亚洲小少妇裸体bbw| 国产成人免费9x9x人网站视频| 欧美性猛交xxxxxxxx| 国产日产欧美一区| 日韩国产欧美在线播放| 成人h动漫精品一区二区| 欧美一区二区在线免费观看| 1000精品久久久久久久久| 久久99精品久久久久婷婷| 欧美在线播放高清精品| 中文字幕电影一区| 久久精品国产网站| 欧美人动与zoxxxx乱| 国产精品二三区| 国产美女在线观看一区| 欧美日韩1区2区| 亚洲美女偷拍久久| 国产成人精品免费| 久久综合久久鬼色| 麻豆精品在线视频| 在线成人免费视频| 亚洲第一狼人社区| 91美女福利视频| 国产精品久久看| 成人一区二区三区在线观看| 精品国免费一区二区三区| 日韩精品亚洲专区| 欧美三级欧美一级| 亚洲欧美欧美一区二区三区| 国产aⅴ综合色| 久久久久久久久久久久电影| 老司机午夜精品| 欧美成人精品1314www| 蜜臀99久久精品久久久久久软件| 欧美精品一二三区| 爽好多水快深点欧美视频| 欧美亚洲尤物久久| 亚洲va欧美va国产va天堂影院| 91蜜桃免费观看视频| 亚洲精品福利视频网站| 色综合欧美在线| 亚洲一区二区三区在线看| 91搞黄在线观看| 亚洲一区中文日韩| 欧美日韩精品一区视频| 婷婷国产在线综合| 欧美一级在线观看| 久久精品99久久久| 国产亚洲va综合人人澡精品 | 99久久99久久精品免费看蜜桃| 国产欧美1区2区3区| 成人av电影在线网| 综合自拍亚洲综合图不卡区| 99国内精品久久| 亚洲成人av电影在线| 日韩视频免费直播| 欧美日韩激情在线| 奇米色777欧美一区二区| 欧美成人video| 国产成人av一区二区三区在线| 国产女同性恋一区二区| 91视频www| 日韩av网站在线观看| 国产亚洲一区二区三区在线观看| 成人动漫中文字幕| 亚洲图片有声小说| 精品久久国产字幕高潮| k8久久久一区二区三区| 亚洲一区在线看| 精品久久久久久久久久久久久久久 | 7777精品伊人久久久大香线蕉超级流畅 | 国产69精品一区二区亚洲孕妇 | 香蕉久久夜色精品国产使用方法 | 自拍偷在线精品自拍偷无码专区| 欧美三电影在线| 国产精一品亚洲二区在线视频|