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

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

?? fixedqpencoder.cpp

?? JMVM MPEG MVC/3DAV 測試平臺 國際通用標準
?? CPP
字號:
/*
********************************************************************************

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 <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <string>


#define MAX_LAYERS  10
#define USAGE(X)    {if(X) print_usage();}
#define MIN_QP       0.0
#define MAX_QP      80.0
#define DELTA_QP     3.0


#define AVC_HACK     1
#define CLOSED_LOOP  1


void
print_usage()
{
  printf("\nusage:\n\n");
  printf("FixedQPEncoder <ConfigFile>\n");
  printf("\n");
  exit(1);
}



typedef struct
{
  double        dTargetRate;                      // set from config file (never changed)
  double        dMinMismatch;                     // set from config file (never changed)
  double        dMaxMismatch;                     // set from config file (never changed)
  double        dStartQP;                         // set from config file (never changed)

  double        dResidualQP;                      // needed for encode
  unsigned int  uiMotionFileMode;                 // needed for encode
  std::string   cMotionFile;                      // needed for encode

  double        dRate;
}
LayerParameters;



typedef struct
{
  std::string     cLabel;                         //                   (never changed) - config file
  std::string     cEncoderBinary;                 // needed for encode (never changed) - config file
  std::string     cParameterFile;                 // needed for encode (never changed) - config file
  std::string     cBitStreamFile;                 // needed for encode (never changed) - config file
  std::string     cMotionFolder;                  // needed for encode (never changed) - config file
  unsigned int    uiNumberOfLayers;               // needed for encode                 - config file
  unsigned int    uiNumberOfFrames;               //                   (never changed) - config file
  double          dFramesPerSecond;               //                   (never changed) - config file
  unsigned int    uiConstrainedIntraBL;
  LayerParameters acLayerParameters[MAX_LAYERS];  // needed for encode                 - config file
}
EncoderParameters;







//////////////////////////////////////////////////////////////////////////
//
//   encode once and return the file size
//
//////////////////////////////////////////////////////////////////////////
unsigned int
encode( EncoderParameters& rcEncoderParameters )
{
  char        acTempString[1024];
  std::string cCommandLineString;

  //----- general settings -----
  cCommandLineString    += rcEncoderParameters.cEncoderBinary;
  cCommandLineString    += " -pf ";
  cCommandLineString    += rcEncoderParameters.cParameterFile;
  cCommandLineString    += " -bf ";
  cCommandLineString    += rcEncoderParameters.cBitStreamFile;
  cCommandLineString    += " -numl ";
  sprintf( acTempString, "%d", rcEncoderParameters.uiNumberOfLayers );
  cCommandLineString    += acTempString;
  if( rcEncoderParameters.uiConstrainedIntraBL )
  {
    cCommandLineString  += " -bcip";
  }

  //----- layer settings -----
  for( unsigned int uiLayer = 0; uiLayer < rcEncoderParameters.uiNumberOfLayers; uiLayer++ )
  {
    LayerParameters& rcLayer = rcEncoderParameters.acLayerParameters[uiLayer];

    sprintf( acTempString, " -rqp %d %lf -mfile %d %d %s ",
      uiLayer, rcLayer.dResidualQP,
      uiLayer, rcLayer.uiMotionFileMode, rcLayer.cMotionFile.c_str() );
    cCommandLineString  += acTempString;
  }

  //----- run encoder -----
  int iResult = system( cCommandLineString.c_str() );
  if( iResult )
  {
    printf("\n\nERROR while executing \"...\"\n\n%s\n\n", cCommandLineString.c_str() );
    exit(2);
  }

  //----- get file size -----
  unsigned int uiFileSize = 0;
  FILE* pFile = fopen( rcEncoderParameters.cBitStreamFile.c_str(), "rb" );
  if( ! pFile )
  {
    printf( "\n\nUNEXPECTED ERROR: Cannot open file\"%s\"\n\n", rcEncoderParameters.cBitStreamFile.c_str() );
    exit(1);
  }
  fseek( pFile, 0, SEEK_END );
  uiFileSize += ftell( pFile );
  fclose( pFile );

  return uiFileSize;
}






//////////////////////////////////////////////////////////////////////////
//
//   encode layer until rate is reached and return file size
//
//////////////////////////////////////////////////////////////////////////
void
encode_layer( EncoderParameters& rcEncoderParameters )
{
  //----- initialize -----
  char              acTempString[1024];
  unsigned int      uiLayer          = rcEncoderParameters.uiNumberOfLayers - 1;
  LayerParameters&  rcLayer          = rcEncoderParameters.acLayerParameters[uiLayer];
  double            dSeqLength       = (double)rcEncoderParameters.uiNumberOfFrames / rcEncoderParameters.dFramesPerSecond;
  double            dTargetSize      = 1000.0 / 8.0 * rcLayer.dTargetRate * dSeqLength;
  unsigned int      uiMinTarget      = (unsigned int)(int)ceil ( (100.0 - rcLayer.dMinMismatch) / 100.0 * dTargetSize );
  unsigned int      uiMaxTarget      = (unsigned int)(int)floor( (100.0 + rcLayer.dMaxMismatch) / 100.0 * dTargetSize );
  unsigned int      uiTargetSize     = ( uiMinTarget + uiMaxTarget + 1 ) / 2;
  unsigned int      uiMinSize        = 0;
  unsigned int      uiMaxSize        = (unsigned int)-1;
  double            dMinSizeQP       =  1000;
  double            dMaxSizeQP       = -1000;
  int               iMinSizeQP       =  1000;
  int               iMaxSizeQP       = -1000;
  double            dCurrQP          = rcLayer.dStartQP;
  int               numitermot       = 0;
  bool              motionestimation = true;

 
  //----- run until rate matches -----
  while( true )
  {
    //----- set parameters -----
    unsigned int iCurrQP        = (int)floor( dCurrQP + 0.5 );
    rcLayer.dResidualQP         = dCurrQP;
    sprintf( acTempString, "%s\\%s_Layer%d.mot",
      rcEncoderParameters.cMotionFolder.c_str(),
      rcEncoderParameters.cLabel.c_str(),
      uiLayer );
    rcLayer.cMotionFile         = acTempString;
    rcLayer.uiMotionFileMode    = ( motionestimation ? 2 : 1 );
    if( rcLayer.uiMotionFileMode == 1 )
    {
      numitermot++;
    }
#if AVC_HACK
    if( uiLayer == 0 )
    {
      rcLayer.uiMotionFileMode = 2;
    }
#endif
#if CLOSED_LOOP
    rcLayer.uiMotionFileMode = 2;
#endif

    //--- run ---
    unsigned int uiCurrSize = encode( rcEncoderParameters );
	  motionestimation        = false;

    //--- check ---
    if( ( uiCurrSize >= uiMinTarget && uiCurrSize <= uiMaxTarget ) || dCurrQP >= MAX_QP || dCurrQP <= MIN_QP || numitermot > 10 )
    {
      rcLayer.uiMotionFileMode  = 1;
      rcLayer.dRate             = (double)uiCurrSize / dSeqLength * 8.0 / 1000.0;
      return;
    }

    //--- update intervall borders ---
    if( uiCurrSize < uiTargetSize )
    {
      //--- lower border ---
      uiMinSize   = uiCurrSize;
      dMinSizeQP  = dCurrQP;
      iMinSizeQP  = iCurrQP;
    }
    else
    {
      //--- upper border ---
      uiMaxSize   = uiCurrSize;
      dMaxSizeQP  = dCurrQP;
      iMaxSizeQP  = iCurrQP;
    }

    //--- get new QP ---
    if( dMinSizeQP != 1000.0 && dMaxSizeQP != -1000.0 )
    {
      //--- two borders ---
      dCurrQP  = dMinSizeQP - dMaxSizeQP;
      dCurrQP *= log( (double)uiMaxSize / (double)uiTargetSize );
      dCurrQP /= log( (double)uiMaxSize / (double)uiMinSize    );
      dCurrQP += dMaxSizeQP;
    }
    else if( dMinSizeQP != 1000.0 )
    {
      //--- lower border: decrease QP ---
      double dDQP = dCurrQP - ( dMinSizeQP + 6.0 * log( (double)uiMinSize / (double)uiTargetSize ) );
      dDQP        = ( dDQP < 1.0 ? 1.0 : dDQP );
      dCurrQP    -= dDQP;
      if( dCurrQP < MIN_QP )
      {
        dCurrQP   = MIN_QP;
      }
    }
    else
    {
      //--- upper border: increase QP ---
      double dDQP = ( dMaxSizeQP + 6.0 * log( (double)uiMaxSize / (double)uiTargetSize ) ) - dCurrQP;
      dDQP        = ( dDQP < 1.0 ? 1.0 : dDQP );
      dCurrQP    += dDQP;
      if( dCurrQP > MAX_QP )
      {
        dCurrQP   = MAX_QP;
      }
    }
  }
}



#define ROT(x)  {if(x) return 1;}
#define ROF(x)  {if(!x)return 1;}

int
read_line( FILE* pFile, char* pcFormat, void* pPar )
{
  if( pPar )
  {
    int  result = fscanf( pFile, pcFormat, pPar );
    ROF( result );
  }

  for( int n = 0; n < 1024; n++ )
  {
    if( '\n' == fgetc( pFile ) )
    {
      return 0;
    }
  }
  return 1;
}




int
read_config_file( EncoderParameters& cEncoderParameters, FILE* pFile )
{
  char acTempString[1024];
  ROF( pFile );

  ROT( read_line( pFile, "",    NULL ) );
  ROT( read_line( pFile, "",    NULL ) );
  ROT( read_line( pFile, "%s",  acTempString ) );
  cEncoderParameters.cLabel         = acTempString;
  ROT( read_line( pFile, "%s",  acTempString ) );
  cEncoderParameters.cEncoderBinary = acTempString;
  ROT( read_line( pFile, "%s",  acTempString ) );
  cEncoderParameters.cParameterFile = acTempString;
  ROT( read_line( pFile, "%s",  acTempString ) );
  cEncoderParameters.cBitStreamFile = acTempString;
  ROT( read_line( pFile, "%s",  acTempString ) );
  cEncoderParameters.cMotionFolder  = acTempString;
  ROT( read_line( pFile, "%d",  &cEncoderParameters.uiNumberOfFrames ) );
  ROT( read_line( pFile, "%lf", &cEncoderParameters.dFramesPerSecond ) );
  ROT( read_line( pFile, "%d",  &cEncoderParameters.uiNumberOfLayers ) );
  ROT( read_line( pFile, "%d",  &cEncoderParameters.uiConstrainedIntraBL ) );
  ROT( read_line( pFile, "",    NULL ) );

  for( unsigned int uiLayer = 0; uiLayer < cEncoderParameters.uiNumberOfLayers; uiLayer++ )
  {
    LayerParameters& rcLayer = cEncoderParameters.acLayerParameters[uiLayer];

    ROT( read_line( pFile, "",    NULL ) );
    ROT( read_line( pFile, "",    NULL ) );
    ROT( read_line( pFile, "%lf", &rcLayer.dTargetRate ) );
    ROT( read_line( pFile, "%lf", &rcLayer.dMinMismatch ) );
    ROT( read_line( pFile, "%lf", &rcLayer.dMaxMismatch ) );
    ROT( read_line( pFile, "%lf", &rcLayer.dStartQP ) );
  }

  return 0;
}





int main( int argc, char** argv)
{
  EncoderParameters cEncoderParameters;
  
  USAGE( argc < 2 );
  FILE* pFile = fopen( argv[1], "rt" );
  if( ! pFile )
  {
    printf("\n\nCannot open config file \"%s\"\n\n", argv[1] );
    exit(1);
  }
  else
  {
    if( read_config_file( cEncoderParameters, pFile ) )
    {
      printf("\n\nError while reading from config file \"%s\"\n\n", argv[1] );
      exit(1);
    }
    fclose( pFile );
  }
  



  //----- iterative encode -----
  unsigned int uiNumberOfLayers = cEncoderParameters.uiNumberOfLayers;
  for( unsigned int uiNumLayers = 1; uiNumLayers <= uiNumberOfLayers; uiNumLayers++ )
  {
    cEncoderParameters.uiNumberOfLayers = uiNumLayers;
    encode_layer( cEncoderParameters );
  }


  //----- output -----
  printf("\n\n\n");
  for( unsigned int uiLayer = 0; uiLayer < uiNumberOfLayers; uiLayer++ )
  {
    printf("L%d:   QP = %8.4lf    RATE =%10.4lf [ %6.3lf %% ]\n",
      uiLayer,
        cEncoderParameters.acLayerParameters[uiLayer].dResidualQP,
        cEncoderParameters.acLayerParameters[uiLayer].dRate,
      ( cEncoderParameters.acLayerParameters[uiLayer].dRate - 
        cEncoderParameters.acLayerParameters[uiLayer].dTargetRate ) /
        cEncoderParameters.acLayerParameters[uiLayer].dTargetRate * 100.0 );
  }
  printf("\n\n\n");

  return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av一区二区三区在线| 色呦呦国产精品| 亚洲老司机在线| 欧美zozozo| 欧美日韩精品系列| 99热在这里有精品免费| 国产在线精品一区二区| 亚洲电影第三页| 日韩美女久久久| 国产日韩欧美电影| 日韩欧美视频在线| 欧美日本乱大交xxxxx| 色婷婷av一区| 91在线无精精品入口| 国v精品久久久网| 国内精品写真在线观看| 免费成人性网站| 五月婷婷综合网| 亚洲一区在线观看免费| 亚洲黄色小视频| 亚洲日本在线a| 亚洲天堂免费在线观看视频| 久久久国产精品麻豆 | 国产精品午夜在线| 精品国产乱码久久久久久免费| 欧美日韩久久久| 欧美性大战久久久久久久蜜臀| 99久久精品免费看| eeuss鲁片一区二区三区| 国产精品亚洲第一区在线暖暖韩国 | 日本中文一区二区三区| 亚洲最大成人网4388xx| 亚洲免费在线视频一区 二区| 国产日韩一级二级三级| 国产人成一区二区三区影院| 久久综合色婷婷| 久久综合视频网| 久久久综合精品| 久久先锋影音av| 日本一区二区视频在线观看| 国产精品全国免费观看高清| 国产精品免费视频一区| 国产精品久久久久一区二区三区| 国产精品视频yy9299一区| 国产精品色噜噜| 1区2区3区国产精品| 亚洲欧洲日韩综合一区二区| 成人免费在线视频| 亚洲小少妇裸体bbw| 亚洲国产精品天堂| 日日摸夜夜添夜夜添精品视频| 日韩精品亚洲一区二区三区免费| 日韩vs国产vs欧美| 国产精选一区二区三区| 成人深夜福利app| 色婷婷精品大在线视频| 欧美日韩一区二区在线观看视频| 91麻豆精品国产| 久久女同互慰一区二区三区| 中文字幕av不卡| 亚洲精品你懂的| 丝袜美腿亚洲综合| 国产一区二区三区免费在线观看 | 国产乱国产乱300精品| 成+人+亚洲+综合天堂| 91九色最新地址| 欧美一级免费大片| 日本一区二区三区国色天香| 亚洲精品少妇30p| 免费xxxx性欧美18vr| 韩国欧美国产1区| 一本大道av伊人久久综合| 欧美猛男gaygay网站| 久久久久一区二区三区四区| 亚洲日本va午夜在线影院| 视频一区视频二区在线观看| 久久99国产精品成人| 一本一道波多野结衣一区二区| 51精品秘密在线观看| 国产精品女同互慰在线看| 亚洲观看高清完整版在线观看| 久久av资源网| 91一区二区在线观看| 欧美一区二区播放| 成人免费在线观看入口| 免费观看在线综合| 91色视频在线| 精品国产百合女同互慰| 亚洲精品乱码久久久久| 国产精品小仙女| 欧美群妇大交群中文字幕| 国产精品女主播av| 精品视频在线免费观看| 国产调教视频一区| 日韩不卡一二三区| 欧美影院一区二区| 国产精品福利影院| 国产大陆亚洲精品国产| 欧美老女人在线| 亚洲欧美日韩系列| 国产在线精品一区二区夜色| 欧美日韩一区小说| 亚洲欧美综合在线精品| 国产传媒一区在线| 日韩一级片网站| 亚洲一级二级在线| 99综合影院在线| 欧美本精品男人aⅴ天堂| 五月天网站亚洲| 一本大道av一区二区在线播放| 国产亚洲精品aa| 久久99国产精品久久| 3d动漫精品啪啪1区2区免费 | 亚洲色大成网站www久久九九| 精品夜夜嗨av一区二区三区| 欧美精品三级日韩久久| 亚洲精品一二三| 91亚洲资源网| 日韩毛片高清在线播放| 成人妖精视频yjsp地址| 久久亚洲一区二区三区明星换脸| 青青草国产精品97视觉盛宴 | 777奇米四色成人影色区| 亚洲午夜激情av| 在线精品亚洲一区二区不卡| 国产精品超碰97尤物18| 99久久婷婷国产精品综合| 国产精品拍天天在线| 粉嫩av一区二区三区在线播放| 精品99999| 国产成人综合在线播放| 久久奇米777| 国产剧情一区在线| 国产欧美一区二区三区鸳鸯浴| 国产精品一区二区在线观看不卡| 精品国产伦一区二区三区观看方式 | 日韩久久精品一区| 免费在线看一区| 精品国产一区二区在线观看| 激情文学综合插| 久久久蜜臀国产一区二区| 国产成人精品亚洲午夜麻豆| 国产午夜精品一区二区三区视频| 国产精品综合在线视频| 中文字幕不卡在线| 一本在线高清不卡dvd| 一区二区国产视频| 欧美一区二区三区人| 另类中文字幕网| 欧美精品一区二区三区高清aⅴ| 国产在线精品一区二区| 国产精品情趣视频| 在线一区二区视频| 青青草原综合久久大伊人精品 | 国产精品理论在线观看| 色香蕉久久蜜桃| 亚洲成人资源在线| 日韩欧美另类在线| 成熟亚洲日本毛茸茸凸凹| 亚洲三级理论片| 91精品国产综合久久久久| 国产最新精品精品你懂的| 国产精品美女一区二区在线观看| 91视频观看视频| 日韩精品色哟哟| 国产日韩精品一区二区浪潮av| www.亚洲色图| 日韩精品电影一区亚洲| 久久久三级国产网站| 欧美伊人久久大香线蕉综合69| 另类小说视频一区二区| 国产精品激情偷乱一区二区∴| 欧美日韩aaaaaa| 国产成人在线色| 亚洲电影你懂得| 国产无人区一区二区三区| 欧美性生活一区| 国产一区二区调教| 亚洲午夜日本在线观看| 精品女同一区二区| 色婷婷综合激情| 久久精品国产精品亚洲精品| 亚洲色图丝袜美腿| 精品少妇一区二区三区免费观看| 成人黄色综合网站| 另类中文字幕网| 一区二区三区成人| 国产偷国产偷精品高清尤物| 欧美性xxxxxxxx| 国产aⅴ综合色| 日韩经典中文字幕一区| 国产精品久久久久毛片软件| 欧美一级一区二区| 欧洲一区二区三区免费视频| 极品美女销魂一区二区三区 | 国产成人a级片| 视频在线观看国产精品| 亚洲裸体在线观看| 日本一区二区电影| 精品国产成人在线影院|