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

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

?? mbcoder.cpp

?? JMVM MPEG MVC/3DAV 測試平臺 國際通用標(biāo)準(zhǔn)
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
/*
********************************************************************************

NOTE - One of the two copyright statements below may be chosen
       that applies for the software.

********************************************************************************

This software module was originally developed by

Heiko Schwarz    (Fraunhofer HHI),
Tobias Hinz      (Fraunhofer HHI),
Karsten Suehring (Fraunhofer HHI)

in the course of development of the ISO/IEC 14496-10:2005 Amd.1 (Scalable Video
Coding) for reference purposes and its performance may not have been optimized.
This software module is an implementation of one or more tools as specified by
the ISO/IEC 14496-10:2005 Amd.1 (Scalable Video Coding).

Those intending to use this software module in products are advised that its
use may infringe existing patents. ISO/IEC have no liability for use of this
software module or modifications thereof.

Assurance that the originally developed software module can be used
(1) in the ISO/IEC 14496-10:2005 Amd.1 (Scalable Video Coding) once the
ISO/IEC 14496-10:2005 Amd.1 (Scalable Video Coding) has been adopted; and
(2) to develop the ISO/IEC 14496-10:2005 Amd.1 (Scalable Video Coding): 

To the extent that Fraunhofer HHI owns patent rights that would be required to
make, use, or sell the originally developed software module or portions thereof
included in the ISO/IEC 14496-10:2005 Amd.1 (Scalable Video Coding) in a
conforming product, Fraunhofer HHI will assure the ISO/IEC that it is willing
to negotiate licenses under reasonable and non-discriminatory terms and
conditions with applicants throughout the world.

Fraunhofer HHI retains full right to modify and use the code for its own
purpose, assign or donate the code to a third party and to inhibit third
parties from using the code for products that do not conform to MPEG-related
ITU Recommendations and/or ISO/IEC International Standards. 

This copyright notice must be included in all copies or derivative works.
Copyright (c) ISO/IEC 2005. 

********************************************************************************

COPYRIGHT AND WARRANTY INFORMATION

Copyright 2005, International Telecommunications Union, Geneva

The Fraunhofer HHI hereby donate this source code to the ITU, with the following
understanding:
    1. Fraunhofer HHI retain the right to do whatever they wish with the
       contributed source code, without limit.
    2. Fraunhofer HHI retain full patent rights (if any exist) in the technical
       content of techniques and algorithms herein.
    3. The ITU shall make this code available to anyone, free of license or
       royalty fees.

DISCLAIMER OF WARRANTY

These software programs are available to the user without any license fee or
royalty on an "as is" basis. The ITU disclaims any and all warranties, whether
express, implied, or statutory, including any implied warranties of
merchantability or of fitness for a particular purpose. In no event shall the
contributor or the ITU 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 ITU does not represent or warrant that the programs furnished hereunder are
free of infringement of any third-party patents. Commercial implementations of
ITU-T Recommendations, including shareware, may be subject to royalty fees to
patent holders. Information regarding the ITU-T patent policy is available from 
the ITU Web site at http://www.itu.int.

THIS IS NOT A GRANT OF PATENT RIGHTS - SEE THE ITU-T PATENT POLICY.

********************************************************************************
*/




#include "H264AVCEncoderLib.h"
#include "MbCoder.h"
#include "H264AVCCommonLib/Tables.h"



H264AVC_NAMESPACE_BEGIN


MbCoder::MbCoder():
  m_pcMbSymbolWriteIf( NULL ),
  m_pcRateDistortionIf( NULL ),
  m_bInitDone( false ),
  m_bCabac( false ),
  m_bPrevIsSkipped( false )
{
}


MbCoder::~MbCoder()
{
}


ErrVal MbCoder::create( MbCoder*& rpcMbCoder )
{
  rpcMbCoder = new MbCoder;

  ROT( NULL == rpcMbCoder );

  return Err::m_nOK;
}

ErrVal MbCoder::destroy()
{
  delete this;
  return Err::m_nOK;
}

ErrVal MbCoder::initSlice(  const SliceHeader& rcSH,
                            MbSymbolWriteIf*   pcMbSymbolWriteIf,
                            RateDistortionIf*  pcRateDistortionIf )
{
  ROT( NULL == pcMbSymbolWriteIf );
  ROT( NULL == pcRateDistortionIf );

  m_pcMbSymbolWriteIf = pcMbSymbolWriteIf;
  m_pcRateDistortionIf = pcRateDistortionIf;

  m_bCabac          = rcSH.getPPS().getEntropyCodingModeFlag();
  m_bPrevIsSkipped  = false;

  m_bInitDone = true;

  return Err::m_nOK;
}


ErrVal MbCoder::uninit()
{
  m_pcMbSymbolWriteIf = NULL;
  m_pcRateDistortionIf = NULL;

  m_bInitDone = false;
  return Err::m_nOK;
}






ErrVal MbCoder::encode( MbDataAccess& rcMbDataAccess,
                        MbDataAccess* pcMbDataAccessBase,
                        Int           iSpatialScalabilityType,
                        Bool          bTerminateSlice )
{
  ROF( m_bInitDone );

  //===== skip flag =====
  Bool  bIsCoded  = ! rcMbDataAccess.isSkippedMb();

  RNOK( m_pcMbSymbolWriteIf->skipFlag( rcMbDataAccess, false ) );

  if( bIsCoded )
  {
    //===== base layer mode flag and base layer refinement flag =====
    if( rcMbDataAccess.getSH().getBaseLayerId() != MSYS_UINT_MAX )
    {
      if ( pcMbDataAccessBase->getMbData().getInCropWindowFlag() == true )// TMM_ESS
      {
				if( rcMbDataAccess.getSH().getAdaptivePredictionFlag() )
				{
					RNOK  ( m_pcMbSymbolWriteIf->BLSkipFlag( rcMbDataAccess ) );
				}
				else
				{
					ROF( rcMbDataAccess.getMbData().getBLSkipFlag () );
				}
// TMM_ESS {
      }
      else  // of if ( rcMbDataAccess.getMbData().getInCropWindowFlag() == true )
      {
          ROT  ( rcMbDataAccess.getMbData().getBLSkipFlag () );
      }
// TMM_ESS }
    }
    else
    {
      ROT  ( rcMbDataAccess.getMbData().getBLSkipFlag () );
    }

#if JMVM_ONLY  // JVT-W081
    if ( !rcMbDataAccess.getSH().getAVCFlag() && rcMbDataAccess.getSH().getMotionSkip() )
    {
      if ( !rcMbDataAccess.getSH().getSPS().getSpsMVC()->getSingleLoopDecoding() ) // JVT-Y042
      {
          RNOK  ( m_pcMbSymbolWriteIf->MotionSkipFlag( rcMbDataAccess ) ); 
#if JMVM_ONLY //JVT-Z021
		  if(rcMbDataAccess.getMbData().getMotionSkipFlag())
			  RNOK(MbCoder::xWriteImsm(rcMbDataAccess));
#endif  //JVT-Z021
      }
      else
      {
          RNOK  ( m_pcMbSymbolWriteIf->MotionSkipFlag( rcMbDataAccess ) );
#if JMVM_ONLY //JVT-Z021
		  if(rcMbDataAccess.getMbData().getMotionSkipFlag())
			  RNOK(MbCoder::xWriteImsm(rcMbDataAccess));
#endif
      }
    }
#endif  // JVT-W081   

    //===== macroblock mode =====
    if( ! rcMbDataAccess.getMbData().getBLSkipFlag()
#if JMVM_ONLY  // JVT-W081
		&& ! rcMbDataAccess.getMbData().getMotionSkipFlag()
#endif  // JVT-W081	
		)
    {
      MbMode  eMbModeOrg = rcMbDataAccess.getMbData().getMbMode();
      MbMode  eMbModeSet = ( eMbModeOrg == INTRA_BL ? INTRA_4X4 : eMbModeOrg );
      rcMbDataAccess.getMbData().setMbMode( eMbModeSet );
      RNOK( m_pcMbSymbolWriteIf->mbMode( rcMbDataAccess ) );
      rcMbDataAccess.getMbData().setMbMode( eMbModeOrg );
    }

    //--- reset motion pred flags ---
    if( rcMbDataAccess.getMbData().getBLSkipFlag() 
#if JMVM_ONLY  // JVT-W081
		|| rcMbDataAccess.getMbData().getMotionSkipFlag()
#endif  // JVT-W081
		|| rcMbDataAccess.getMbData().isIntra() || rcMbDataAccess.getMbData().getMbMode() == MODE_SKIP )
    {
      rcMbDataAccess.getMbMotionData( LIST_0 ).setMotPredFlag( false );
      rcMbDataAccess.getMbMotionData( LIST_1 ).setMotPredFlag( false );
    }
    else if( rcMbDataAccess.getSH().isInterB() )
    {
      for( B8x8Idx c8x8Idx; c8x8Idx.isLegal(); c8x8Idx++ )
      {
        if( BLK_SKIP == rcMbDataAccess.getMbData().getBlkMode   ( c8x8Idx.b8x8Index() ) ||
            !rcMbDataAccess            .getMbData().isBlockFwdBwd( c8x8Idx.b8x8Index(), LIST_0 ) )
        {
          rcMbDataAccess.getMbMotionData( LIST_0 ).setMotPredFlag( false, c8x8Idx );
        }
        if( BLK_SKIP == rcMbDataAccess.getMbData().getBlkMode   ( c8x8Idx.b8x8Index() ) ||
            !rcMbDataAccess            .getMbData().isBlockFwdBwd( c8x8Idx.b8x8Index(), LIST_1 ) )
        {
          rcMbDataAccess.getMbMotionData( LIST_1 ).setMotPredFlag( false, c8x8Idx );
        }
      }
    }

    //===== prediction info =====
    if( ! rcMbDataAccess.getMbData().getBLSkipFlag()
#if JMVM_ONLY  // JVT-W081
		&& ! rcMbDataAccess.getMbData().getMotionSkipFlag()
#endif  // JVT-W081
		)
    {
      //===== BLOCK MODES =====
      if( rcMbDataAccess.getMbData().isInter8x8() )
      {
        RNOK( m_pcMbSymbolWriteIf->blockModes( rcMbDataAccess ) );
      }

      if( rcMbDataAccess.getMbData().isPCM() )
      {
        //===== PCM SAMPLES =====
        RNOK( m_pcMbSymbolWriteIf->samplesPCM( rcMbDataAccess ) );
      }
      else if( rcMbDataAccess.getMbData().isIntra() )
      {
        //===== INTRA PREDICTION MODES =====
        RNOK( xWriteIntraPredModes( rcMbDataAccess ) );
      }
      else
      {
        //===== MOTION INFORMATION =====
        MbMode eMbMode = rcMbDataAccess.getMbData().getMbMode();
        if( rcMbDataAccess.getSH().isInterB() )
        {
          RNOK( xWriteMotionPredFlags( rcMbDataAccess, eMbMode, LIST_0 ) );
          RNOK( xWriteMotionPredFlags( rcMbDataAccess, eMbMode, LIST_1 ) );
          RNOK( xWriteReferenceFrames( rcMbDataAccess, eMbMode, LIST_0 ) );
          RNOK( xWriteReferenceFrames( rcMbDataAccess, eMbMode, LIST_1 ) );
          RNOK( xWriteMotionVectors  ( rcMbDataAccess, eMbMode, LIST_0 ) );
          RNOK( xWriteMotionVectors  ( rcMbDataAccess, eMbMode, LIST_1 ) );
        }
        else
        {
          RNOK( xWriteMotionPredFlags( rcMbDataAccess, eMbMode, LIST_0 ) );
          RNOK( xWriteReferenceFrames( rcMbDataAccess, eMbMode, LIST_0 ) );
          RNOK( xWriteMotionVectors  ( rcMbDataAccess, eMbMode, LIST_0 ) );
        }

#if JMVM_ONLY  // JVT-U052
        if( rcMbDataAccess.getSH().getIcEnable() )
        {
          RNOK( xWriteIcp( rcMbDataAccess, eMbMode ) );
        }
#endif
      }
    }


    //===== TEXTURE =====
    if( ! rcMbDataAccess.getMbData().isPCM() )
    {
      Bool bTrafo8x8Flag = ( rcMbDataAccess.getSH().getPPS().getTransform8x8ModeFlag() &&
                           ( rcMbDataAccess.getMbData().getBLSkipFlag() ||
#if JMVM_ONLY  // JVT-W081
						     rcMbDataAccess.getMbData().getMotionSkipFlag() ||
#endif  // JVT-W081
						   ( rcMbDataAccess.getMbData().is8x8TrafoFlagPresent() &&
                              !rcMbDataAccess.getMbData().isIntra4x4() ) ) );
 			//-- JVT-R091
			RNOK( xWriteTextureInfo( rcMbDataAccess, pcMbDataAccessBase, rcMbDataAccess.getMbTCoeffs(), bTrafo8x8Flag ) );
			//--
    }
  }

#if JMVM_ONLY  // JVT-W081
  if ( rcMbDataAccess.getMbData().getMotionSkipFlag() )
  {
	  rcMbDataAccess.getMbData().setMbMode( MODE_SKIP );
	  if( rcMbDataAccess.getSH().isInterB() )
	  {
		  rcMbDataAccess.getMbData().setFwdBwd( 0x3333 );          
	  }
	  else
	  {
		  rcMbDataAccess.getMbData().setFwdBwd( 0x1111 );
	  }
  }
#endif  // JVT-W081

  //--- write terminating bit ---
  RNOK( m_pcMbSymbolWriteIf->terminatingBit ( bTerminateSlice ? 1:0 ) );

  if( bTerminateSlice )

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩国产精品自在自线| 成人av电影免费在线播放| 欧美日韩国产另类一区| 婷婷久久综合九色国产成人| 欧美三级在线看| 日本不卡视频在线| 精品欧美一区二区在线观看| 国产激情一区二区三区| 国产精品人人做人人爽人人添| 91视频免费看| 视频一区视频二区在线观看| 337p粉嫩大胆色噜噜噜噜亚洲| 成人美女视频在线观看| 亚洲一区在线观看免费 | 男男视频亚洲欧美| 久久蜜臀中文字幕| 色婷婷综合久久久久中文| 三级影片在线观看欧美日韩一区二区| 日韩一级黄色大片| 成年人国产精品| 亚洲成在人线在线播放| 久久婷婷国产综合国色天香| 成人91在线观看| 日韩二区三区四区| 国产精品全国免费观看高清| 91精品国产综合久久香蕉的特点| 国产在线精品一区二区不卡了| ●精品国产综合乱码久久久久| 欧美精品久久天天躁| 国产福利一区二区| 秋霞电影网一区二区| 国产精品久久久久影院老司| 8x8x8国产精品| 99久久精品免费看国产免费软件| 午夜精品视频在线观看| 国产精品国产自产拍在线| 日韩限制级电影在线观看| 99久免费精品视频在线观看 | 一区二区日韩av| 精品国产一区二区三区久久影院| 91视频精品在这里| 国产激情一区二区三区桃花岛亚洲| 亚洲一区在线观看网站| 国产精品欧美精品| 欧美videos中文字幕| 欧美三级日韩三级国产三级| 成人国产精品免费观看动漫| 国内欧美视频一区二区| 午夜在线电影亚洲一区| 亚洲精品乱码久久久久久黑人 | 日本va欧美va精品发布| 亚洲午夜视频在线观看| 国产精品久久久一区麻豆最新章节| 欧美电视剧在线看免费| 91精品国产综合久久精品app| 一本色道a无线码一区v| 成人黄色777网| 国产成人丝袜美腿| 国产真实乱对白精彩久久| 日日夜夜精品视频免费| 亚洲综合免费观看高清在线观看| 国产精品久久久久aaaa| 国产午夜精品久久久久久免费视| 精品国产成人在线影院| 日韩一区二区三区在线视频| 欧美精品一二三四| 欧美日韩大陆一区二区| 欧美少妇性性性| 欧美日韩在线观看一区二区 | 国产一区二区在线观看视频| 日本美女一区二区三区视频| 天天免费综合色| 婷婷六月综合网| 日韩精品电影一区亚洲| 人人精品人人爱| 麻豆一区二区在线| 久久成人免费网站| 精品中文字幕一区二区小辣椒 | 亚瑟在线精品视频| 亚洲成av人**亚洲成av**| 亚洲国产精品综合小说图片区| 亚洲一区二区成人在线观看| 亚洲成人精品一区| 美女视频一区在线观看| 国内精品伊人久久久久av一坑| 极品美女销魂一区二区三区| 国产九色sp调教91| 成人av在线播放网站| 色香色香欲天天天影视综合网| 日本道免费精品一区二区三区| 在线视频欧美精品| 欧美精品少妇一区二区三区| 日韩欧美另类在线| 久久久久久久网| 中文字幕一区二区三区四区不卡| 亚洲精品国产一区二区三区四区在线| 亚洲已满18点击进入久久| 日本91福利区| 不卡欧美aaaaa| 欧美色图12p| 欧美成人一区二区三区| 国产婷婷精品av在线| 夜夜爽夜夜爽精品视频| 久久精品国产精品亚洲综合| 国产91精品一区二区麻豆亚洲| 91免费国产在线| 日韩一区二区精品在线观看| 欧美高清在线精品一区| 亚洲国产日韩av| 狠狠色狠狠色综合| 色八戒一区二区三区| 日韩欧美国产系列| 国产精品成人免费| 久久精品av麻豆的观看方式| www.亚洲人| 日韩精品中文字幕一区二区三区| 中文字幕免费不卡| 蜜臀av性久久久久蜜臀aⅴ四虎| 国产精品18久久久久久久网站| 欧美色精品在线视频| 国产欧美日韩精品a在线观看| 亚洲一区二区av在线| 国产一区二区调教| 欧美日韩国产首页在线观看| 久久久av毛片精品| 午夜精品aaa| 成人深夜在线观看| 精品久久国产字幕高潮| 亚洲人xxxx| 高清国产一区二区三区| 91精品国产色综合久久| 亚洲欧洲日韩综合一区二区| 久久99精品久久久| 欧美日韩精品一区二区三区蜜桃| 欧美国产日本韩| 国模娜娜一区二区三区| 欧美日韩一本到| 1024成人网色www| 成人自拍视频在线| 亚洲精品一区二区三区香蕉| 亚洲国产精品久久艾草纯爱| 99精品视频一区二区| 久久久99久久精品欧美| 久久国产精品第一页| 欧美日韩三级在线| 亚洲美女精品一区| av一区二区三区四区| 精品电影一区二区三区| 美女一区二区久久| 91精品国产aⅴ一区二区| 夜夜操天天操亚洲| 一本大道久久a久久综合| 国产精品美女久久久久高潮| 国产激情91久久精品导航| 精品久久久久久久久久久久久久久久久 | 亚洲一本大道在线| 不卡的av中国片| 国产精品久久久久久久久免费桃花 | 色婷婷国产精品| 亚洲男人电影天堂| 91一区二区三区在线播放| 国产精品欧美久久久久一区二区 | 国产在线国偷精品产拍免费yy| 日韩一级免费一区| 一区二区三区在线免费视频| 99久久er热在这里只有精品15| 国产精品免费视频一区| 成人网在线播放| 国产精品不卡视频| 99re亚洲国产精品| 亚洲女人****多毛耸耸8| 色成人在线视频| 亚洲一区二区三区三| 欧美在线观看18| 香蕉成人伊视频在线观看| 欧美一区二区三区男人的天堂| 日本美女一区二区三区| 精品国一区二区三区| 国产精品一二三在| 国产精品初高中害羞小美女文| 色综合久久久久综合99| 午夜私人影院久久久久| 日韩天堂在线观看| 国产一区二区三区观看| 国产精品欧美久久久久无广告 | 成人av午夜电影| 亚洲自拍与偷拍| 日韩一区二区免费高清| 国产a视频精品免费观看| 亚洲免费av在线| 91麻豆精品国产自产在线观看一区| 久久国产剧场电影| 中文字幕一区不卡| 欧美日韩国产一级| 国产一区二区导航在线播放| 亚洲欧洲综合另类在线| 精品欧美一区二区在线观看 | 激情图区综合网| 国产精品每日更新在线播放网址 | 91精品在线免费观看|