Changeset 1062 in 3DVCSoftware for branches/HTM-12.0-dev1/source/Lib/TLibCommon/TComSlice.h
- Timestamp:
- 7 Oct 2014, 20:41:24 (10 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/HTM-12.0-dev1/source/Lib/TLibCommon/TComSlice.h
r1060 r1062 208 208 209 209 #if H_MV_HLS10_PTL 210 #if H_MV 210 211 Bool m_max12bitConstraintFlag; 211 212 Bool m_max10bitConstraintFlag; … … 219 220 Bool m_inbldFlag; 220 221 #endif 222 #endif 221 223 public: 222 224 ProfileTierLevel(); … … 249 251 Void setFrameOnlyConstraintFlag(Bool b) { m_frameOnlyConstraintFlag = b; } 250 252 253 #if H_MV 251 254 #if H_MV_HLS10_PTL 252 255 Void setMax12bitConstraintFlag( Bool flag ) { m_max12bitConstraintFlag = flag; } … … 278 281 Void setInbldFlag( Bool flag ) { m_inbldFlag = flag; } 279 282 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 280 331 #endif 281 332 … … 301 352 ProfileTierLevel* getSubLayerPTL(Int i) { return &m_subLayerPTL[i]; } 302 353 #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 303 442 Void copyLevelFrom( TComPTL* source ); 443 #endif 304 444 #endif 305 445 };
Note: See TracChangeset for help on using the changeset viewer.