Ignore:
Timestamp:
7 Oct 2014, 20:41:24 (10 years ago)
Author:
tech
Message:

Integrated Fix PTL inference.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/HTM-12.0-dev1/source/Lib/TLibCommon/TComSlice.h

    r1060 r1062  
    208208 
    209209#if H_MV_HLS10_PTL
     210#if H_MV
    210211  Bool m_max12bitConstraintFlag;
    211212  Bool m_max10bitConstraintFlag;
     
    219220  Bool m_inbldFlag;
    220221#endif
     222#endif
    221223public:
    222224  ProfileTierLevel();
     
    249251  Void setFrameOnlyConstraintFlag(Bool b) { m_frameOnlyConstraintFlag = b; }
    250252
     253#if H_MV
    251254#if H_MV_HLS10_PTL
    252255  Void setMax12bitConstraintFlag( Bool flag ) { m_max12bitConstraintFlag = flag; }
     
    278281  Void setInbldFlag( Bool flag ) { m_inbldFlag = flag; }
    279282  Bool getInbldFlag(  ) { return m_inbldFlag; }
     283#endif
     284#if H_MV_HLS10_PTL_INFER_FIX
     285
     286  Bool getV2ConstraintsPresentFlag()
     287  {
     288  return (
     289    getProfileIdc( ) ==  4 || getProfileCompatibilityFlag( 4 ) || getProfileIdc( ) ==  5 || getProfileCompatibilityFlag( 5 )  ||
     290    getProfileIdc( ) ==  6 || getProfileCompatibilityFlag( 6 ) || getProfileIdc( ) ==  7 || getProfileCompatibilityFlag( 7 )
     291    );
     292  }
     293 
     294  Bool getInbldPresentFlag()
     295  {
     296    return (
     297      ( getProfileIdc() >= 1 && getProfileIdc() <= 5 )  || getProfileCompatibilityFlag( 1 ) || getProfileCompatibilityFlag( 2 ) ||
     298      getProfileCompatibilityFlag( 3 ) || getProfileCompatibilityFlag( 4 )  ||   getProfileCompatibilityFlag( 5 )
     299      );
     300  }
     301
     302  Void copyV2ConstraintFlags( ProfileTierLevel* ptlRef )
     303  {
     304    setMax12bitConstraintFlag         ( ptlRef->getMax12bitConstraintFlag       ( ) );
     305    setMax10bitConstraintFlag         ( ptlRef->getMax10bitConstraintFlag       ( ) );
     306    setMax8bitConstraintFlag          ( ptlRef->getMax8bitConstraintFlag        ( ) );
     307    setMax422chromaConstraintFlag     ( ptlRef->getMax422chromaConstraintFlag   ( ) );
     308    setMax420chromaConstraintFlag     ( ptlRef->getMax420chromaConstraintFlag   ( ) );
     309    setMaxMonochromeConstraintFlag    ( ptlRef->getMaxMonochromeConstraintFlag  ( ) );
     310    setIntraConstraintFlag            ( ptlRef->getIntraConstraintFlag          ( ) );
     311    setOnePictureOnlyConstraintFlag   ( ptlRef->getOnePictureOnlyConstraintFlag ( ) );
     312    setLowerBitRateConstraintFlag     ( ptlRef->getLowerBitRateConstraintFlag   ( ) );   
     313  }
     314
     315  Void copyProfile( ProfileTierLevel* ptlRef )
     316  {
     317      setProfileSpace            ( ptlRef->getProfileSpace              ( ) );
     318      setTierFlag                ( ptlRef->getTierFlag                  ( ) );
     319      setProfileIdc              ( ptlRef->getProfileIdc                ( ) );
     320      for (Int j = 0; j < 32; j++)
     321      {     
     322        setProfileCompatibilityFlag(j, ptlRef->getProfileCompatibilityFlag  ( j ) );           
     323      }
     324      setProgressiveSourceFlag   ( ptlRef->getProgressiveSourceFlag     ( ) );
     325      setInterlacedSourceFlag    ( ptlRef->getInterlacedSourceFlag      ( ) );
     326      setNonPackedConstraintFlag ( ptlRef->getNonPackedConstraintFlag   ( ) );
     327      setFrameOnlyConstraintFlag ( ptlRef->getFrameOnlyConstraintFlag   ( ) );
     328      copyV2ConstraintFlags      ( ptlRef );
     329  }
     330#endif
    280331#endif
    281332
     
    301352  ProfileTierLevel* getSubLayerPTL(Int i)  { return &m_subLayerPTL[i]; }
    302353#if H_MV
     354#if H_MV_HLS10_PTL_INFER_FIX
     355  Void inferGeneralValues( Bool profilePresentFlag, Int k, TComPTL* refPTL )
     356  {
     357    ProfileTierLevel* refProfileTierLevel = NULL;
     358    if ( k > 0 )
     359    {   
     360      assert( refPTL != NULL);
     361      refProfileTierLevel = refPTL->getGeneralPTL();
     362    }
     363
     364    ProfileTierLevel* curProfileTierLevel = getGeneralPTL( );
     365
     366    if( !profilePresentFlag )
     367    {
     368      assert( k > 0 );
     369      assert( refProfileTierLevel != NULL );
     370      curProfileTierLevel->copyProfile( refProfileTierLevel);
     371    }
     372    else
     373    {
     374      if ( !curProfileTierLevel->getV2ConstraintsPresentFlag() )
     375      {
     376        curProfileTierLevel->setMax12bitConstraintFlag         ( false );
     377        curProfileTierLevel->setMax10bitConstraintFlag         ( false );
     378        curProfileTierLevel->setMax8bitConstraintFlag          ( false );
     379        curProfileTierLevel->setMax422chromaConstraintFlag     ( false );
     380        curProfileTierLevel->setMax420chromaConstraintFlag     ( false );
     381        curProfileTierLevel->setMaxMonochromeConstraintFlag    ( false );
     382        curProfileTierLevel->setIntraConstraintFlag            ( false );
     383        curProfileTierLevel->setOnePictureOnlyConstraintFlag   ( false );
     384        curProfileTierLevel->setLowerBitRateConstraintFlag     ( false );   
     385      }
     386
     387      if ( !curProfileTierLevel->getInbldPresentFlag() )
     388      {
     389        curProfileTierLevel->setInbldFlag( false );
     390      }     
     391    }         
     392  };
     393
     394  Void inferSubLayerValues( Int maxNumSubLayersMinus1, Int k, TComPTL* refPTL )
     395  {
     396    assert( k == 0 || refPTL != NULL );
     397
     398    for (Int i = maxNumSubLayersMinus1; i >= 0; i--)
     399    {
     400      ProfileTierLevel* refProfileTierLevel;
     401      if ( k != 0 )
     402      {
     403        refProfileTierLevel = refPTL->getSubLayerPTL( i );
     404      }
     405      else
     406      {
     407        if ( i == maxNumSubLayersMinus1)     
     408        {
     409          refProfileTierLevel = getGeneralPTL();
     410        }
     411        else
     412        {
     413          refProfileTierLevel = getSubLayerPTL( i + 1 );
     414        }
     415      }   
     416
     417      ProfileTierLevel* curProfileTierLevel = getSubLayerPTL( i );
     418      if( !getSubLayerLevelPresentFlag( i ) )
     419      {
     420        curProfileTierLevel->setLevelIdc( refProfileTierLevel->getLevelIdc() );
     421      }
     422
     423      if( !getSubLayerProfilePresentFlag( i ) )
     424      {
     425        curProfileTierLevel->copyProfile( refProfileTierLevel);
     426      }
     427      else
     428      {
     429        if ( !curProfileTierLevel->getV2ConstraintsPresentFlag() )
     430        {
     431          curProfileTierLevel->copyV2ConstraintFlags( refProfileTierLevel );
     432        }
     433
     434        if ( !curProfileTierLevel->getInbldPresentFlag() )
     435        {
     436          curProfileTierLevel->setInbldFlag( refProfileTierLevel->getInbldFlag() );
     437        }     
     438      }     
     439    }
     440  };
     441#else
    303442  Void copyLevelFrom( TComPTL* source );
     443#endif
    304444#endif
    305445};
Note: See TracChangeset for help on using the changeset viewer.