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

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

?? image.c

?? H264解碼器,本解碼器實(shí)現(xiàn)了圖像的264解碼
?? C
?? 第 1 頁(yè) / 共 4 頁(yè)
字號(hào):

/*!
 ***********************************************************************
 * \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>


#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 "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()
{
  byte temp[16][32];

  byte ** imgY  = dec_picture->imgY;
  byte ***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];
        }

      x0 = x0/2;
      y0 = y0/2;

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

/*!
 ***********************************************************************
 * \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
  FILE *p_ref)            //!< open reference YUV file
{
  int i,j;
  int diff_y,diff_u,diff_v;
  int uv;
  int  status;

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

  // KS: Code below might work better if you have fields and a large (>1) poc offset between them
//  int  poc_diff=max(1,(p->bottom_poc - p->top_poc));
//  int  psnrPOC = active_sps->mb_adaptive_frame_field_flag ? p->poc /(input->poc_scale*poc_diff) : p->poc/((3-input->poc_scale)*poc_diff);

  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;


  rewind(p_ref);

  for (i=0; i<frame_no; i++)
  {
    status = fseek (p_ref, (long) p->size_y* (long) (p->size_x*3/2), SEEK_CUR);
    if (status != 0)
    {
      snprintf(errortext, ET_SIZE, "Error in seeking frame number: %d", frame_no);
      fprintf(stderr, "%s", errortext);
      return;
//      snprintf(errortext, ET_SIZE, "Error in seeking frame number: %d", frame_no);
//      error(errortext, 500);
    }
  }

  for (j=0; j < p->size_y; j++)
    for (i=0; i < p->size_x; i++)
      imgY_ref[j][i]=fgetc(p_ref);

  for (uv=0; uv < 2; uv++)
    for (j=0; j < p->size_y_cr ; j++)
      for (i=0; i < p->size_x_cr; i++)
        imgUV_ref[uv][j][i]=fgetc(p_ref);

  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;

  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(65025*(float)(p->size_x)*(p->size_y)/(float)diff_y));        // luma snr for current frame
  else
    snr->snr_y=0;
  if (diff_u != 0)
    snr->snr_u=(float)(10*log10(65025*(float)(p->size_x)*(p->size_y)/(float)(4*diff_u)));    //  chroma snr for current frame
  else
    snr->snr_u=0;
  if (diff_v != 0)
    snr->snr_v=(float)(10*log10(65025*(float)(p->size_x)*(p->size_y)/(float)(4*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(255, (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(255, (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(255, (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(255, (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++) {
        for (i = -2; i < BLOCK_SIZE+3; i++)
          for (tmp_res[j][i+2] = 0, y = -2; y < 4; y++)
            tmp_res[j][i+2] += list[ref_frame]->imgY[max(0,min(maxold_y,y_pos+j+y))][max(0,min(maxold_x,x_pos+i))]*COEF[y+2];
      }

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

      if ((dx&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(255, (tmp_res[j][i+2+dx/2]+16)/32))+1)/2;
      }
    }
    else {  /* Diagonal interpolation */

      for (j = 0; j < BLOCK_SIZE; j++) {
        for (i = 0; i < BLOCK_SIZE; i++) {
          pres_y = dy == 1 ? y_pos+j : y_pos+j+1;
          pres_y = max(0,min(maxold_y,pres_y));

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产综合久久蜜臀| 99久久国产综合精品色伊| 欧美久久久久久久久久| 五月激情六月综合| 日韩精品一区二区三区四区视频| 蜜臀av国产精品久久久久| 精品国产免费久久| 成人精品视频网站| 亚洲乱码国产乱码精品精98午夜| 欧美视频精品在线观看| 免费国产亚洲视频| 国产欧美日韩亚州综合| 欧美在线免费观看亚洲| 日韩高清在线一区| 国产三区在线成人av| 色激情天天射综合网| 美女国产一区二区| 中日韩免费视频中文字幕| 欧洲视频一区二区| 国产精品一区二区久激情瑜伽| 国产精品日韩精品欧美在线| 欧美午夜不卡在线观看免费| 久久精品国产亚洲一区二区三区| 国产精品拍天天在线| 欧美色倩网站大全免费| 狠狠色丁香婷综合久久| 亚洲精品欧美激情| 久久一区二区三区四区| 91久久人澡人人添人人爽欧美| 久久成人免费网| 亚洲免费av观看| 欧美成人精品高清在线播放 | 国产精品高潮呻吟久久| 欧美日韩精品欧美日韩精品一 | 在线成人av网站| 国产精一区二区三区| 亚洲制服丝袜一区| 国产亚洲精品中文字幕| 欧美精品在线一区二区| 成人免费毛片a| 蜜桃一区二区三区在线观看| 一区二区三区精品视频在线| 久久九九国产精品| 日韩精品一区二区三区在线观看| 91丝袜呻吟高潮美腿白嫩在线观看| 日韩av中文字幕一区二区三区 | 一区二区久久久| 久久久久久久久岛国免费| 欧美三区在线视频| 北条麻妃国产九九精品视频| 久久精品二区亚洲w码| 五月综合激情婷婷六月色窝| 亚洲女爱视频在线| 亚洲欧洲性图库| 国产日韩欧美精品综合| 欧美mv日韩mv| 欧美一级一级性生活免费录像| 欧美亚洲动漫精品| av午夜精品一区二区三区| 国产69精品久久久久毛片| 久久国产麻豆精品| 美女尤物国产一区| 日韩综合小视频| 亚洲1区2区3区视频| 亚洲精品写真福利| 亚洲男人天堂av| 亚洲精品视频免费观看| 亚洲特级片在线| 日韩理论片网站| 亚洲欧美影音先锋| 亚洲欧洲制服丝袜| 一区二区三区精品久久久| 一区二区三区在线观看国产| 亚洲精品成a人| 一区二区在线电影| 亚洲一区二区三区激情| 亚洲国产精品麻豆| 婷婷成人综合网| 麻豆专区一区二区三区四区五区| 日韩专区中文字幕一区二区| 天堂蜜桃91精品| 精品一区二区三区免费视频| 极品美女销魂一区二区三区| 国产精品一级黄| 成人av综合在线| 91福利在线免费观看| 欧美亚洲国产bt| 在线观看91av| 精品国产91洋老外米糕| 日本一区免费视频| 亚洲视频一区二区免费在线观看| 亚洲你懂的在线视频| 视频一区欧美精品| 精品一区二区三区蜜桃| 国产不卡高清在线观看视频| 成人美女视频在线观看18| 色哟哟一区二区在线观看| 中文字幕在线观看一区| 亚洲愉拍自拍另类高清精品| 丝袜美腿亚洲色图| 国产精品影视在线| 97se亚洲国产综合自在线| 欧美日韩一区三区四区| 日韩精品最新网址| 日韩毛片高清在线播放| 日韩精品成人一区二区三区| 国产在线精品一区二区不卡了 | 激情综合色丁香一区二区| 国产成人av电影在线| 日本久久一区二区| 精品三级在线看| 亚洲免费资源在线播放| 欧美aaaaa成人免费观看视频| 粉嫩13p一区二区三区| 91成人免费网站| 精品国产123| 亚洲综合一区二区| 激情另类小说区图片区视频区| 99re热视频精品| 欧美videos大乳护士334| 亚洲欧美日韩国产另类专区| 久久成人羞羞网站| 在线观看免费亚洲| 国产亚洲一区二区三区四区 | 一区二区三区四区乱视频| 青青草精品视频| 色婷婷综合久久久久中文一区二区 | 欧美va在线播放| 夜夜嗨av一区二区三区四季av| 国产一区999| 91.xcao| 亚洲手机成人高清视频| 国产一区视频网站| 欧美日韩国产免费一区二区 | 久久一夜天堂av一区二区三区| 亚洲一区二区五区| 91丝袜国产在线播放| 26uuu国产电影一区二区| 午夜视频在线观看一区| 91丨九色丨蝌蚪富婆spa| 亚洲精品一区二区三区香蕉| 五月综合激情日本mⅴ| 色欧美日韩亚洲| 综合网在线视频| 福利一区在线观看| 337p日本欧洲亚洲大胆精品| 人妖欧美一区二区| 欧美理论片在线| 亚洲国产欧美在线| 日本久久一区二区三区| 亚洲图片欧美激情| 成人精品视频一区二区三区| 久久久91精品国产一区二区精品| 欧美aaaaaa午夜精品| 6080国产精品一区二区| 亚洲成人7777| 欧美天堂亚洲电影院在线播放| 亚洲色图视频免费播放| 97久久人人超碰| 亚洲人精品午夜| 欧美激情在线一区二区三区| 国产在线不卡一区| 久久婷婷国产综合精品青草| 精品亚洲成a人| 精品久久久久香蕉网| 国产乱妇无码大片在线观看| 2020国产精品| 成人妖精视频yjsp地址| 国产精品乱码一区二区三区软件 | 99久久精品99国产精品| 日韩美女视频一区二区| 日本韩国精品在线| 亚洲一线二线三线久久久| 欧美日韩精品一区二区| 日本大胆欧美人术艺术动态| 日韩欧美一区二区不卡| 国产一区久久久| 国产婷婷一区二区| 99精品视频一区二区| 亚洲黄色小说网站| 欧美精品久久99久久在免费线| 五月天一区二区| 日韩一区二区三区免费观看| 九一九一国产精品| 国产精品国产三级国产aⅴ原创 | 欧美日韩亚洲综合一区二区三区 | 国产一区二区精品在线观看| 中文字幕乱码久久午夜不卡 | 成人性视频免费网站| 国产精品传媒视频| 欧美性色综合网| 蜜桃久久久久久| 欧美激情一区在线观看| 91国内精品野花午夜精品| 免费成人在线影院| 国产精品剧情在线亚洲| 欧美日韩国产首页在线观看| 狠狠狠色丁香婷婷综合久久五月| 国产精品电影院| 欧美精品一级二级三级|