Changeset 1196 in 3DVCSoftware
- Timestamp:
- 4 May 2015, 17:47:40 (10 years ago)
- Location:
- trunk/source
- Files:
-
- 48 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/source/App/TAppDecoder/TAppDecTop.cpp
r1179 r1196 248 248 { 249 249 m_tDecTop[decIdx]->setTargetOptLayerSetIdx( m_targetOptLayerSetIdx ); 250 #if H_3D _ANNEX_SELECTION_FIX250 #if H_3D 251 251 m_tDecTop[decIdx]->setProfileIdc( ); 252 252 #endif … … 1053 1053 m_tDecTop[ decIdx ]->setLayerInitilizedFlags( m_layerInitilizedFlags ); 1054 1054 m_tDecTop[ decIdx ]->setTargetOptLayerSetIdx( m_targetOptLayerSetIdx ); 1055 #if H_3D _ANNEX_SELECTION_FIX1055 #if H_3D 1056 1056 m_tDecTop[ decIdx ]->setProfileIdc ( ); 1057 1057 #endif -
trunk/source/App/TAppEncoder/TAppEncCfg.cpp
r1179 r1196 225 225 } 226 226 #endif 227 #if HHI_INTER_COMP_PRED_K0052228 227 #if H_3D 229 228 in>>entry.m_interCompPredFlag; 230 #endif231 229 #endif 232 230 return in; … … 482 480 ("FastSearch", m_iFastSearch, 1, "0:Full search 1:Diamond 2:PMVFAST") 483 481 ("SearchRange,-sr", m_iSearchRange, 96, "Motion search range") 484 #if SONY_MV_V_CONST_C0078482 #if H_MV 485 483 ("DispSearchRangeRestriction", m_bUseDisparitySearchRangeRestriction, false, "restrict disparity search range") 486 484 ("VerticalDispSearchRange", m_iVerticalDisparitySearchRange, 56, "vertical disparity search range") … … 794 792 ("QtPredFlag" , m_qtPredFlag , true , "Quad tree prediction from texture to depth") 795 793 ("InterSdcFlag" , m_interSdcFlag , true , "Inter depth DCs" ) 796 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033797 794 ("DepthIntraSkip" , m_depthIntraSkipFlag , true , "Depth intra skip mode" ) 798 #else799 ("IntraSingleFlag" , m_intraSingleFlag , true , "Intra single mode" )800 #endif801 795 #endif //H_3D 802 796 ; … … 1559 1553 { 1560 1554 xConfirmPara( m_directRefLayers[i][j] < 0 || m_directRefLayers[i][j] >= i , "Reference layer id shall be greater than or equal to 0 and less than dependent layer id"); 1561 #if H_3D_DIRECT_DEP_TYPE1562 1555 xConfirmPara( m_dependencyTypes[i][j] < 0 || m_dependencyTypes[i][j] > 6 , "Dependency type shall be greater than or equal to 0 and less than 7"); 1563 #else1564 xConfirmPara( m_dependencyTypes[i][j] < 0 || m_dependencyTypes[i][j] > 2 , "Dependency type shall be greater than or equal to 0 and less than 3");1565 #endif1566 1556 } 1567 1557 } … … 1599 1589 xConfirmPara( m_iSearchRange < 0 , "Search Range must be more than 0" ); 1600 1590 xConfirmPara( m_bipredSearchRange < 0 , "Search Range must be more than 0" ); 1601 #if SONY_MV_V_CONST_C00781591 #if H_MV 1602 1592 xConfirmPara( m_iVerticalDisparitySearchRange <= 0 , "Vertical Disparity Search Range must be more than 0" ); 1603 1593 #endif … … 1716 1706 xConfirmPara( m_pchCameraParameterFile == 0 , "CameraParameterFile must be given"); 1717 1707 xConfirmPara( m_pchBaseViewCameraNumbers == 0 , "BaseViewCameraNumbers must be given" ); 1718 #if BUG_FIX_TK651719 #if HHI_CAM_PARA_K00521720 1708 xConfirmPara( m_iNumberOfViews != m_cCameraData.getBaseViewNumbers().size() , "Number of Views in BaseViewCameraNumbers must be equal to NumberOfViews" ); 1721 #else1722 xConfirmPara( ( ((UInt) m_numberOfLayers >> 1 ) != m_cCameraData.getBaseViewNumbers().size() ) && ( m_numberOfLayers != m_cCameraData.getBaseViewNumbers().size() ), "Number of Views in BaseViewCameraNumbers must be equal to NumberOfViews" );1723 #endif1724 #else1725 xConfirmPara( ((UInt) m_numberOfLayers >> 1 ) != m_cCameraData.getBaseViewNumbers().size(), "Number of Views in BaseViewCameraNumbers must be equal to NumberOfViews" );1726 #endif1727 1709 xConfirmPara ( m_iCodedCamParPrecision < 0 || m_iCodedCamParPrecision > 5, "CodedCamParsPrecision must be in range of 0..5" ); 1728 1710 #if H_3D_VSO … … 2477 2459 printf("Min PCM size : %d\n", 1 << m_uiPCMLog2MinSize); 2478 2460 printf("Motion search range : %d\n", m_iSearchRange ); 2479 #if SONY_MV_V_CONST_C00782461 #if H_MV 2480 2462 printf("Disp search range restriction: %d\n", m_bUseDisparitySearchRangeRestriction ); 2481 2463 printf("Vertical disp search range : %d\n", m_iVerticalDisparitySearchRange ); … … 2632 2614 printf( "QtPred:%d " , m_qtPredFlag ? 1 : 0 ); 2633 2615 printf( "InterSdc:%d " , m_interSdcFlag ? 1 : 0 ); 2634 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332635 2616 printf( "DepthIntraSkip:%d " , m_depthIntraSkipFlag ? 1 : 0 ); 2636 #else2637 printf( "IntraSingle:%d " , m_intraSingleFlag ? 1 : 0 );2638 #endif2639 2617 #endif 2640 2618 -
trunk/source/App/TAppEncoder/TAppEncCfg.h
r1179 r1196 289 289 Int m_iSearchRange; ///< ME search range 290 290 Int m_bipredSearchRange; ///< ME search range for bipred refinement 291 #if SONY_MV_V_CONST_C0078291 #if H_MV 292 292 Bool m_bUseDisparitySearchRangeRestriction; ///< restrict vertical search range for inter-view prediction 293 293 Int m_iVerticalDisparitySearchRange; ///< ME vertical search range for inter-view prediction … … 488 488 Bool m_qtPredFlag; 489 489 Bool m_interSdcFlag; 490 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033491 490 Bool m_depthIntraSkipFlag; 492 #else493 Bool m_intraSingleFlag;494 #endif495 491 #endif 496 492 // internal member functions … … 543 539 Int iSpace = max(1, ENC_CFG_CONSOUT_SPACE - (Int) description.length() ); 544 540 545 for ( Int i = 0; i < iSpace; i++ ) 541 for ( Int i = 0; i < iSpace; i++ ) 542 { 546 543 description.append( " " ); 544 } 547 545 548 546 description.append( ":" ); 549 547 printf( "%s", description.c_str() ); 550 548 551 for(Int i=0;i<rpcVector.size();i++) 549 for(Int i=0;i<rpcVector.size();i++) 550 { 552 551 xPrintVectorElem( rpcVector[i] ); 552 } 553 553 554 554 printf("\n"); -
trunk/source/App/TAppEncoder/TAppEncTop.cpp
r1179 r1196 140 140 xSetVPSVUI ( vps ); 141 141 #if H_3D 142 #if HHI_CAM_PARA_K0052143 142 xSetCamPara ( vps ); 144 #endif145 #endif146 #if H_3D147 143 m_ivPicLists.setVPS ( &vps ); 148 144 xDeriveDltArray ( vps, dlt ); … … 201 197 m_sps3dExtension.setQtPredFlag ( d, m_qtPredFlag ); 202 198 m_sps3dExtension.setInterSdcFlag ( d, m_interSdcFlag ); 203 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033204 199 m_sps3dExtension.setDepthIntraSkipFlag ( d, m_depthIntraSkipFlag ); 205 #else206 m_sps3dExtension.setIntraSingleFlag ( d, m_intraSingleFlag );207 #endif208 200 } 209 201 } … … 229 221 //====== Camera Parameters ========= 230 222 m_cTEncTop.setCameraParameters ( &m_cCameraData ); 231 #if !HHI_CAM_PARA_K0052232 m_cTEncTop.setCamParPrecision ( m_cCameraData.getCamParsCodedPrecision () );233 m_cTEncTop.setCamParInSliceHeader ( m_cCameraData.getVaryingCameraParameters() );234 235 m_cTEncTop.setCodedScale ( m_cCameraData.getCodedScale () );236 m_cTEncTop.setCodedOffset ( m_cCameraData.getCodedOffset () );237 #endif238 223 #if H_3D_VSO 239 224 //====== VSO ========= … … 359 344 m_cTEncTop.setBipredSearchRange ( m_bipredSearchRange ); 360 345 361 #if SONY_MV_V_CONST_C0078346 #if H_MV 362 347 m_cTEncTop.setUseDisparitySearchRangeRestriction ( m_bUseDisparitySearchRangeRestriction ); 363 348 m_cTEncTop.setVerticalDisparitySearchRange ( m_iVerticalDisparitySearchRange ); … … 651 636 } 652 637 #endif 653 #if H_3D_ANNEX_SELECTION_FIX654 638 #if H_3D 655 639 /// SET Profiles … … 692 676 } 693 677 #endif 694 #endif695 678 #if H_3D_VSO 696 679 if ( m_bUseVSO ) … … 799 782 { 800 783 #if H_3D 801 #if !HHI_CAM_PARA_K0052802 for ( Int viewIndex = 0; viewIndex < m_vps->getNumViews(); viewIndex++ )803 {804 m_vps->initCamParaVPS( viewIndex, true, m_cCameraData.getCamParsCodedPrecision(),805 m_cCameraData.getVaryingCameraParameters(), m_cCameraData.getCodedScale(), m_cCameraData.getCodedOffset() );806 }807 #endif808 784 #endif 809 785 … … 1143 1119 if (m_pchReconFileList[layerId]) 1144 1120 { 1145 #if H_MV_ALIGN_HM_151146 1121 m_acTVideoIOYuvReconFileList[layerId]->write( pcPicYuvRecTop, pcPicYuvRecBottom, m_confWinLeft, m_confWinRight, m_confWinTop, m_confWinBottom, m_isTopFieldFirst ); 1147 #else1148 m_acTVideoIOYuvReconFileList[layerId]->write( pcPicYuvRecTop, pcPicYuvRecBottom, m_confLeft, m_confRight, m_confTop, m_confBottom, m_isTopFieldFirst );1149 #endif1150 1122 } 1151 1123 } … … 1200 1172 if (m_pchReconFileList[layerId]) 1201 1173 { 1202 #if H_MV_ALIGN_HM_151203 1174 m_acTVideoIOYuvReconFileList[layerId]->write( pcPicYuvRec, m_confWinLeft, m_confWinRight, m_confWinTop, m_confWinBottom ); 1204 #else1205 m_acTVideoIOYuvReconFileList[layerId]->write( pcPicYuvRec, m_confLeft, m_confRight, m_confTop, m_confBottom );1206 #endif1207 1175 } 1208 1176 } … … 1390 1358 1391 1359 1392 #if HHI_INTER_COMP_PRED_K00521393 1360 #if H_3D 1394 1361 vps.initViewCompLayer( ); 1395 1362 #endif 1396 #endif1397 1363 } 1398 1364 … … 1412 1378 Bool defaultDirectDependencyFlag = false; 1413 1379 1414 #if H_3D_DIRECT_DEP_TYPE1415 1380 Int directDepTypeLenMinus2 = 0; 1416 #endif1417 1381 for( Int depLayer = 1; depLayer < m_numberOfLayers; depLayer++ ) 1418 1382 { … … 1424 1388 vps.setDirectDependencyFlag( depLayer, refLayer, true); 1425 1389 Int curDirectDependencyType = m_dependencyTypes[depLayer][i]; 1426 #if H_3D_DIRECT_DEP_TYPE1427 1390 directDepTypeLenMinus2 = std::max( directDepTypeLenMinus2, gCeilLog2( curDirectDependencyType + 1 ) - 2 ); 1428 #endif1429 1391 if ( defaultDirectDependencyType != -1 ) 1430 1392 { … … 1444 1406 vps.setDefaultDirectDependencyType( defaultDirectDependencyFlag ? defaultDirectDependencyType : -1 ); 1445 1407 1446 #if H_3D_DIRECT_DEP_TYPE1447 1408 assert( directDepTypeLenMinus2 <= 1 ); 1448 1409 vps.setDirectDepTypeLenMinus2( directDepTypeLenMinus2 ); 1449 #endif1450 1410 1451 1411 … … 1495 1455 #endif 1496 1456 { 1497 #if !HHI_INTER_COMP_PRED_K00521498 Bool refAlwaysIntra = ( i == getGOPSize() ) && ( m_iIntraPeriod[ curLayerIdInVps ] % m_iIntraPeriod[ refLayerIdInVps ] == 0 );1499 #endif1500 1457 Bool refLayerZero = ( i == getGOPSize() ) && ( refLayerIdInVps == 0 ); 1501 #if HHI_INTER_COMP_PRED_K00521502 // refAlwaysIntra actually not needed, since TemporalIds need to be aligned within an AU.1503 // Thus, reference pictures of IRAP pictures have TemporalId equal to 0.1504 1458 maxTid = std::max( maxTid, refLayerZero ? 0 : geRef.m_temporalId ); 1505 #else1506 maxTid = std::max( maxTid, ( refAlwaysIntra || refLayerZero ) ? 0 : geRef.m_temporalId );1507 #endif1508 1459 } 1509 1460 } … … 1513 1464 else 1514 1465 { 1515 #if HHI_INTER_COMP_PRED_K00521516 1466 if( m_depthFlag[ curLayerIdInVps ] && ( m_mpiFlag|| m_qtPredFlag || m_intraContourFlag ) ) 1517 1467 { … … 1552 1502 } 1553 1503 } 1554 #else1555 if( m_depthFlag[ curLayerIdInVps ] && ( m_mpiFlag|| m_qtPredFlag || m_intraContourFlag ) )1556 {1557 Int nuhLayerIdTex = vps.getLayerIdInNuh( vps.getViewIndex( curLayerIdInNuh ), false );1558 if ( nuhLayerIdTex == refLayerIdInNuh )1559 {1560 maxTid = std::max( maxTid, vps.getSubLayersVpsMaxMinus1( refLayerIdInVps) + 1 );1561 }1562 }1563 if( !m_depthFlag[ curLayerIdInVps ] && vps.getNumRefListLayers( curLayerIdInNuh) > 0 && ( m_depthRefinementFlag || m_viewSynthesisPredFlag || m_depthBasedBlkPartFlag ) )1564 {1565 Int maxPresentTid =-1;1566 Bool allPresent = true;1567 for (Int i = 0; i < vps.getNumRefListLayers( curLayerIdInNuh); i++ )1568 {1569 Int nuhLayerIdDep = vps.getLayerIdInNuh( vps.getViewIndex( vps.getIdRefListLayer(curLayerIdInNuh, i ) ), true );1570 if ( nuhLayerIdDep== refLayerIdInNuh )1571 {1572 maxPresentTid= std::max( maxTid, vps.getSubLayersVpsMaxMinus1( refLayerIdInVps) + 1 );1573 }1574 else1575 {1576 allPresent = false;1577 }1578 }1579 1580 if ( allPresent )1581 {1582 maxTid= std::max( maxTid, maxPresentTid );1583 }1584 }1585 #endif1586 1504 } 1587 1505 } // if ( vps.getDirectDependencyFlag( curLayerIdInVps, refLayerIdInVps ) ) … … 1823 1741 // ToDo not supported yet. 1824 1742 //repFormat->setSeparateColourPlaneVpsFlag( ); 1825 #if H_MV_FIX_CONF_WINDOW1826 1743 Bool conformanceWindowVpsFlag = ( m_confWinBottom != 0 ) || ( m_confWinRight != 0 ) || ( m_confWinTop != 0 ) || ( m_confWinBottom != 0 ); 1827 1744 repFormat->setConformanceWindowVpsFlag( conformanceWindowVpsFlag ); … … 1833 1750 repFormat->setConfWinVpsBottomOffset ( m_confWinBottom / TComSPS::getWinUnitY( repFormat->getChromaFormatVpsIdc() ) ); 1834 1751 } 1835 #else1836 repFormat->setConformanceWindowVpsFlag( true );1837 repFormat->setConfWinVpsLeftOffset ( m_confWinLeft / TComSPS::getWinUnitX( repFormat->getChromaFormatVpsIdc() ) );1838 repFormat->setConfWinVpsRightOffset ( m_confWinRight / TComSPS::getWinUnitX( repFormat->getChromaFormatVpsIdc() ) );1839 repFormat->setConfWinVpsTopOffset ( m_confWinTop / TComSPS::getWinUnitY( repFormat->getChromaFormatVpsIdc() ) );1840 repFormat->setConfWinVpsBottomOffset ( m_confWinBottom / TComSPS::getWinUnitY( repFormat->getChromaFormatVpsIdc() ) );1841 #endif1842 1752 assert( vps.getRepFormat( j ) == NULL ); 1843 1753 vps.setRepFormat( j , repFormat ); … … 1861 1771 1862 1772 repFormat->setConformanceWindowVpsFlag( true ); 1863 #if H_MV_ALIGN_HM_151864 1773 repFormat->setConfWinVpsLeftOffset ( m_confWinLeft / TComSPS::getWinUnitX( repFormat->getChromaFormatVpsIdc() ) ); 1865 1774 repFormat->setConfWinVpsRightOffset ( m_confWinRight / TComSPS::getWinUnitX( repFormat->getChromaFormatVpsIdc() ) ); 1866 1775 repFormat->setConfWinVpsTopOffset ( m_confWinTop / TComSPS::getWinUnitY( repFormat->getChromaFormatVpsIdc() ) ); 1867 1776 repFormat->setConfWinVpsBottomOffset ( m_confWinBottom / TComSPS::getWinUnitY( repFormat->getChromaFormatVpsIdc() ) ); 1868 #else1869 repFormat->setConfWinVpsLeftOffset ( m_confLeft / TComSPS::getWinUnitX( repFormat->getChromaFormatVpsIdc() ) );1870 repFormat->setConfWinVpsRightOffset ( m_confRight / TComSPS::getWinUnitX( repFormat->getChromaFormatVpsIdc() ) );1871 repFormat->setConfWinVpsTopOffset ( m_confTop / TComSPS::getWinUnitY( repFormat->getChromaFormatVpsIdc() ) );1872 repFormat->setConfWinVpsBottomOffset ( m_confBottom / TComSPS::getWinUnitY( repFormat->getChromaFormatVpsIdc() ) );1873 #endif1874 1777 assert( vps.getRepFormat( 0 ) == NULL ); 1875 1778 vps.setRepFormat( 0 , repFormat ); … … 2250 2153 } 2251 2154 2252 #if HHI_CAM_PARA_K00522253 2155 #if H_3D 2254 2156 Void TAppEncTop::xSetCamPara ( TComVPS& vps ) … … 2285 2187 } 2286 2188 #endif 2287 #endif2288 2189 2289 2190 -
trunk/source/App/TAppEncoder/TAppEncTop.h
r1179 r1196 142 142 Void xSetDpbSize ( TComVPS& vps ); 143 143 Void xSetVPSVUI ( TComVPS& vps ); 144 #if HHI_CAM_PARA_K0052145 144 #if H_3D 146 145 Void xSetCamPara ( TComVPS& vps ); 147 #endif148 146 #endif 149 147 GOPEntry* xGetGopEntry( Int layerIdInVps, Int poc ); -
trunk/source/Lib/TAppCommon/TAppComCamPara.cpp
r1179 r1196 399 399 400 400 401 #if !HHI_CAM_PARA_K0052402 Void403 TAppComCamPara::xGetViewOrderIndices( const std::vector<Int>& raiId2SortedId, std::vector<Int>& raiVOIdx )404 {405 AOF( raiId2SortedId.size() );406 raiVOIdx = raiId2SortedId;407 Int iSize = (Int)raiId2SortedId.size();408 Int iOffs = raiId2SortedId[ 0 ];409 for( Int iIdx = 0; iIdx < iSize; iIdx++ )410 {411 raiVOIdx[ iIdx ] -= iOffs;412 }413 }414 #endif415 401 416 402 … … 960 946 961 947 962 #if !HHI_CAM_PARA_K0052963 Void964 TAppComCamPara::xSetPdmConversionParams()965 {966 AOF( m_aiViewOrderIndex[ 0 ] == 0 );967 if ( m_bSetupFromCoded || m_iNumberOfBaseViews < 2 )968 {969 return;970 }971 972 //--- determine (virtual) camera parameter shift between view order index 1 and base view (view order index 0) ---973 Double dCamPosShift, dPicPosShift;974 Int iMinAbsVOI = (1<<30);975 Int iMinAbsVOIId = 0;976 for( Int iBaseId = 1; iBaseId < m_iNumberOfBaseViews; iBaseId++ )977 {978 Int iAbsVOI = ( m_aiViewOrderIndex[ iBaseId ] < 0 ? -m_aiViewOrderIndex[ iBaseId ] : m_aiViewOrderIndex[ iBaseId ] );979 if( iAbsVOI < iMinAbsVOI )980 {981 iMinAbsVOI = iAbsVOI;982 iMinAbsVOIId = iBaseId;983 }984 }985 AOF( iMinAbsVOIId != 0 && iMinAbsVOI != 0 );986 xGetCameraShifts( 0, iMinAbsVOIId, m_uiFirstFrameId, dCamPosShift, dPicPosShift );987 988 //--- determine maximum absolute camera position shift, precision, and base scale ---989 Double dMaxAbsCamPosShift = 0.0;990 for( Int iTargetId = 1; iTargetId < m_iNumberOfBaseViews; iTargetId++ )991 {992 for( Int iBaseId = 0; iBaseId < iTargetId; iBaseId++ )993 {994 xGetCameraShifts( (UInt)iBaseId, (UInt)iTargetId, m_uiFirstFrameId, dCamPosShift, dPicPosShift );995 dCamPosShift = ( dCamPosShift < 0.0 ? -dCamPosShift : dCamPosShift );996 dMaxAbsCamPosShift = ( dCamPosShift > dMaxAbsCamPosShift ? dCamPosShift : dMaxAbsCamPosShift );997 }998 }999 }1000 #endif1001 948 1002 949 … … 1284 1231 1285 1232 //===== set derived parameters ===== 1286 #if !HHI_CAM_PARA_K00521287 xGetViewOrderIndices( m_aiBaseId2SortedId, m_aiViewOrderIndex );1288 #endif1289 1233 m_bCamParsVaryOverTime = xGetCamParsChangeFlag(); 1290 1234 -
trunk/source/Lib/TAppCommon/TAppComCamPara.h
r1179 r1196 85 85 86 86 // SPS and slice header related variables 87 #if !HHI_CAM_PARA_K005288 std::vector<Int> m_aiViewOrderIndex; ///< list of view order indices89 #endif90 87 UInt m_uiCamParsCodedPrecision; ///< precision for coding of camera parameters (x: max error in disparity is 2^(-x) luma samples) 91 88 Bool m_bCamParsVaryOverTime; ///< flag specifying whether camera parameters vary for given frame numbers … … 147 144 // getting conversion parameters for disparity to virtual depth conversion 148 145 Void xGetCameraShifts ( UInt uiSourceView, UInt uiTargetView, UInt uiFrame, Double& rdCamPosShift, Double& rdPicPosShift ); 149 #if !HHI_CAM_PARA_K0052150 Void xSetPdmConversionParams ();151 #endif152 146 153 147 public: … … 220 214 Bool getVaryingCameraParameters() { return m_bCamParsVaryOverTime; } 221 215 UInt getCamParsCodedPrecision () { return m_uiCamParsCodedPrecision; } 222 #if !HHI_CAM_PARA_K0052223 std::vector<Int>& getViewOrderIndex () { return m_aiViewOrderIndex; }224 #endif225 216 Int** getCodedScale () { return m_aaiCodedScale; } 226 217 Int** getCodedOffset () { return m_aaiCodedOffset; } -
trunk/source/Lib/TLibCommon/ContextTables.h
r1179 r1196 51 51 #define NUM_SPLIT_FLAG_CTX 3 ///< number of context models for split flag 52 52 #define NUM_SKIP_FLAG_CTX 3 ///< number of context models for skip flag 53 #if SEC_DEPTH_INTRA_SKIP_MODE_K003353 #if H_3D 54 54 #define NUM_DIS_FLAG_CTX 1 55 55 #define NUM_DIS_TYPE_CTX 1 56 #else57 #if H_3D_SINGLE_DEPTH58 #define NUM_SINGLEDEPTH_FLAG_CTX 159 #define NUM_SINGLE_DEPTH_VALUE_DATA_CTX 160 #endif61 56 #endif 62 57 #define NUM_MERGE_FLAG_EXT_CTX 1 ///< number of context models for merge flag of merge extended … … 158 153 { CNU, CNU, CNU, }, 159 154 }; 160 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033155 #if H_3D 161 156 static const UChar 162 157 INIT_DIS_FLAG[3][NUM_DIS_FLAG_CTX] = … … 173 168 { 137 }, 174 169 }; 175 #else176 #if H_3D_SINGLE_DEPTH177 static const UChar178 INIT_SINGLEDEPTH_FLAG[3][NUM_SINGLEDEPTH_FLAG_CTX] =179 {180 { 185 },181 { 185 },182 { 185 },183 };184 static const UChar185 INIT_SINGLE_DEPTH_VALUE_DATA[3][NUM_SINGLE_DEPTH_VALUE_DATA_CTX] =186 {187 { 137 },188 { 137 },189 { 137 },190 };191 #endif192 170 #endif 193 171 static const UChar -
trunk/source/Lib/TLibCommon/TComDataCU.cpp
r1179 r1196 60 60 61 61 m_skipFlag = NULL; 62 #if SEC_DEPTH_INTRA_SKIP_MODE_K003362 #if H_3D 63 63 m_bDISFlag = NULL; 64 64 m_uiDISType = NULL; 65 #else66 #if H_3D_SINGLE_DEPTH67 m_singleDepthFlag = NULL;68 m_apSingleDepthValue = NULL;69 #endif70 65 #endif 71 66 m_pePartSize = NULL; … … 158 153 m_pbDBBPFlag = NULL; 159 154 #endif 160 161 155 } 162 156 … … 186 180 187 181 m_skipFlag = new Bool[ uiNumPartition ]; 188 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033182 #if H_3D 189 183 m_bDISFlag = new Bool[ uiNumPartition ]; 190 184 m_uiDISType = (UInt*)xMalloc(UInt, uiNumPartition); 191 #else192 #if H_3D_SINGLE_DEPTH193 m_singleDepthFlag = new Bool[ uiNumPartition ];194 m_apSingleDepthValue = (Pel*)xMalloc(Pel, uiNumPartition);195 #endif196 185 #endif 197 186 m_pePartSize = new Char[ uiNumPartition ]; … … 337 326 338 327 if ( m_skipFlag ) { delete[] m_skipFlag; m_skipFlag = NULL; } 339 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033328 #if H_3D 340 329 if ( m_bDISFlag ) { delete[] m_bDISFlag; m_bDISFlag = NULL; } 341 330 if ( m_uiDISType ) { xFree(m_uiDISType); m_uiDISType = NULL; } 342 #else343 #if H_3D_SINGLE_DEPTH344 if ( m_singleDepthFlag ) { delete[] m_singleDepthFlag; m_singleDepthFlag = NULL; }345 if ( m_apSingleDepthValue ) { xFree(m_apSingleDepthValue); m_apSingleDepthValue = NULL; }346 #endif347 331 #endif 348 332 if ( m_pePartSize ) { delete[] m_pePartSize; m_pePartSize = NULL; } … … 506 490 TComDataCU * pcFrom = pcPic->getCU(getAddr()); 507 491 m_skipFlag[ui] = pcFrom->getSkipFlag(ui); 508 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033492 #if H_3D 509 493 m_bDISFlag[ui] = pcFrom->getDISFlag(ui); 510 494 m_uiDISType[ui] = pcFrom->getDISType(ui); 511 #else512 #if H_3D_SINGLE_DEPTH513 m_singleDepthFlag[ui] = pcFrom->getSingleDepthFlag(ui);514 m_apSingleDepthValue[ui] = pcFrom->getSingleDepthValue(ui);515 #endif516 495 #endif 517 496 m_pePartSize[ui] = pcFrom->getPartitionSize(ui); … … 566 545 { 567 546 memset( m_skipFlag + firstElement, false, numElements * sizeof( *m_skipFlag ) ); 568 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033547 #if H_3D 569 548 memset( m_bDISFlag + firstElement, false, numElements * sizeof( *m_bDISFlag ) ); 570 549 memset( m_uiDISType + firstElement, 0, numElements * sizeof( *m_uiDISType) ); 571 #else572 #if H_3D_SINGLE_DEPTH573 memset( m_singleDepthFlag + firstElement, false, numElements * sizeof( *m_singleDepthFlag ) );574 memset( m_apSingleDepthValue + firstElement, 0, numElements * sizeof( *m_apSingleDepthValue ) );575 #endif576 550 #endif 577 551 memset( m_pePartSize + firstElement, SIZE_NONE, numElements * sizeof( *m_pePartSize ) ); … … 758 732 m_puhTransformSkip[2][ui] = 0; 759 733 m_skipFlag[ui] = false; 760 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033734 #if H_3D 761 735 m_bDISFlag[ui] = false; 762 736 m_uiDISType[ui] = 0; 763 #else764 #if H_3D_SINGLE_DEPTH765 m_singleDepthFlag[ui] = false;766 m_apSingleDepthValue[ui] = 0;767 #endif768 737 #endif 769 738 m_pePartSize[ui] = SIZE_NONE; … … 891 860 memset( m_puhCbf[2], 0, iSizeInUchar ); 892 861 memset( m_puhDepth, uiDepth, iSizeInUchar ); 893 #if H_3D_NBDV && !SEC_ARP_REM_ENC_RESTRICT_K0035894 m_pDvInfo->bDV = false;895 #endif896 862 #if H_3D_ARP 897 863 memset( m_puhARPW, 0, iSizeInUchar ); … … 934 900 { 935 901 m_skipFlag[ui] = false; 936 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033902 #if H_3D 937 903 m_bDISFlag[ui] = false; 938 904 m_uiDISType[ui] = 0; 939 #else940 #if H_3D_SINGLE_DEPTH941 m_singleDepthFlag[ui] = false;942 m_apSingleDepthValue[ui]= 0;943 #endif944 905 #endif 945 906 m_pePartSize[ui] = SIZE_NONE; … … 964 925 m_puhTransformSkip[2][ui] = pcCU->getTransformSkip(uiPartOffset+ui,TEXT_CHROMA_V); 965 926 m_skipFlag[ui] = pcCU->getSkipFlag(uiPartOffset+ui); 966 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033927 #if H_3D 967 928 m_bDISFlag[ui] = pcCU->getDISFlag(uiPartOffset+ui); 968 929 m_uiDISType[ui] = pcCU->getDISType(uiPartOffset+ui); 969 #else970 #if H_3D_SINGLE_DEPTH971 m_singleDepthFlag[ui] = pcCU->getSingleDepthFlag(uiPartOffset+ui);972 m_apSingleDepthValue[ui] = pcCU->getSingleDepthValue(uiPartOffset+ui);973 #endif974 930 #endif 975 931 m_pePartSize[ui] = pcCU->getPartitionSize(uiPartOffset+ui); … … 1000 956 m_pbICFlag [ui] = pcCU->m_pbICFlag[uiPartOffset+ui]; 1001 957 #endif 1002 1003 1004 958 #if H_3D_DIM 1005 959 for( Int i = 0; i < DIM_NUM_TYPE; i++ ) … … 1118 1072 1119 1073 m_skipFlag=pcCU->getSkipFlag() + uiPart; 1120 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331074 #if H_3D 1121 1075 m_bDISFlag = pcCU->getDISFlag() + uiPart; 1122 1076 m_uiDISType = pcCU->getDISType() + uiPart; 1123 #else1124 #if H_3D_SINGLE_DEPTH1125 m_singleDepthFlag = pcCU->getSingleDepthFlag() + uiPart;1126 m_apSingleDepthValue = pcCU->getSingleDepthValue() + uiPart;1127 #endif1128 1077 #endif 1129 1078 m_phQP=pcCU->getQP() + uiPart; … … 1143 1092 m_pbSPIVMPFlag = pcCU->getSPIVMPFlag() + uiPart; 1144 1093 #endif 1145 1146 1094 #if H_3D_ARP 1147 1095 m_puhARPW = pcCU->getARPW() + uiPart; … … 1150 1098 m_pbICFlag = pcCU->getICFlag() + uiPart; 1151 1099 #endif 1152 1153 1154 1100 m_puhLumaIntraDir = pcCU->getLumaIntraDir() + uiPart; 1155 1101 m_puhChromaIntraDir = pcCU->getChromaIntraDir() + uiPart; … … 1260 1206 1261 1207 m_skipFlag = pcCU->getSkipFlag () + uiAbsPartIdx; 1262 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331208 #if H_3D 1263 1209 m_bDISFlag = pcCU->getDISFlag () + uiAbsPartIdx; 1264 1210 m_uiDISType = pcCU->getDISType() + uiAbsPartIdx; 1265 #else1266 #if H_3D_SINGLE_DEPTH1267 m_singleDepthFlag = pcCU->getSingleDepthFlag () + uiAbsPartIdx;1268 m_apSingleDepthValue = pcCU->getSingleDepthValue () + uiAbsPartIdx;1269 #endif1270 1211 #endif 1271 1212 m_pePartSize = pcCU->getPartitionSize () + uiAbsPartIdx; … … 1295 1236 #endif 1296 1237 #if H_3D_SPIVMP 1297 m_pbSPIVMPFlag = pcCU->getSPIVMPFlag() + uiAbsPartIdx; 1298 #endif 1299 1238 m_pbSPIVMPFlag = pcCU->getSPIVMPFlag() + uiAbsPartIdx; 1239 #endif 1300 1240 m_apiMVPIdx[eRefPicList] = pcCU->getMVPIdx(eRefPicList) + uiAbsPartIdx; 1301 m_apiMVPNum[eRefPicList] = pcCU->getMVPNum(eRefPicList) + uiAbsPartIdx; 1302 1241 m_apiMVPNum[eRefPicList] = pcCU->getMVPNum(eRefPicList) + uiAbsPartIdx; 1303 1242 #if H_3D_ARP 1304 1243 m_puhARPW = pcCU->getARPW() + uiAbsPartIdx; 1305 #endif 1306 1307 1244 #endif 1308 1245 #if H_3D_DBBP 1309 1246 m_pbDBBPFlag = pcCU->getDBBPFlag() + uiAbsPartIdx; … … 1340 1277 Int sizeInChar = sizeof( Char ) * uiNumPartition; 1341 1278 memcpy( m_skipFlag + uiOffset, pcCU->getSkipFlag(), sizeof( *m_skipFlag ) * uiNumPartition ); 1342 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331279 #if H_3D 1343 1280 memcpy( m_bDISFlag + uiOffset, pcCU->getDISFlag(), sizeof( *m_bDISFlag ) * uiNumPartition ); 1344 1281 memcpy( m_uiDISType + uiOffset, pcCU->getDISType(), sizeof( *m_uiDISType ) * uiNumPartition); 1345 #else1346 #if H_3D_SINGLE_DEPTH1347 memcpy( m_singleDepthFlag + uiOffset, pcCU->getSingleDepthFlag(), sizeof( *m_singleDepthFlag ) * uiNumPartition );1348 memcpy( m_apSingleDepthValue + uiOffset, pcCU->getSingleDepthValue(), sizeof( *m_apSingleDepthValue ) * uiNumPartition);1349 #endif1350 1282 #endif 1351 1283 memcpy( m_phQP + uiOffset, pcCU->getQP(), sizeInChar ); … … 1358 1290 memcpy( m_piVSPFlag + uiOffset, pcCU->getVSPFlag(), sizeof( Char ) * uiNumPartition ); 1359 1291 memcpy( m_pDvInfo + uiOffset, pcCU->getDvInfo(), sizeof( *m_pDvInfo ) * uiNumPartition ); 1360 1361 1292 #endif 1362 1293 #if H_3D_SPIVMP … … 1374 1305 memcpy( m_puhCbf[1] + uiOffset, pcCU->getCbf(TEXT_CHROMA_U), iSizeInUchar ); 1375 1306 memcpy( m_puhCbf[2] + uiOffset, pcCU->getCbf(TEXT_CHROMA_V), iSizeInUchar ); 1376 1377 1378 1379 1307 #if H_3D_DIM 1380 1308 for( Int i = 0; i < DIM_NUM_TYPE; i++ ) … … 1465 1393 1466 1394 memcpy( rpcCU->getSkipFlag() + m_uiAbsIdxInLCU, m_skipFlag, sizeof( *m_skipFlag ) * m_uiNumPartition ); 1467 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331395 #if H_3D 1468 1396 memcpy( rpcCU->getDISFlag() + m_uiAbsIdxInLCU, m_bDISFlag, sizeof( *m_bDISFlag ) * m_uiNumPartition ); 1469 1397 memcpy( rpcCU->getDISType() + m_uiAbsIdxInLCU, m_uiDISType, sizeof( *m_uiDISType ) * m_uiNumPartition ); 1470 #else1471 #if H_3D_SINGLE_DEPTH1472 memcpy( rpcCU->getSingleDepthFlag() + m_uiAbsIdxInLCU, m_singleDepthFlag, sizeof( *m_singleDepthFlag ) * m_uiNumPartition );1473 memcpy( rpcCU->getSingleDepthValue() + m_uiAbsIdxInLCU, m_apSingleDepthValue, sizeof( *m_apSingleDepthValue ) * m_uiNumPartition);1474 #endif1475 1398 #endif 1476 1399 memcpy( rpcCU->getQP() + m_uiAbsIdxInLCU, m_phQP, sizeInChar ); … … 1478 1401 memcpy( rpcCU->getDvInfo() + m_uiAbsIdxInLCU, m_pDvInfo, sizeof(* m_pDvInfo) * m_uiNumPartition ); 1479 1402 #endif 1480 1481 1482 1403 memcpy( rpcCU->getPartitionSize() + m_uiAbsIdxInLCU, m_pePartSize, sizeof( *m_pePartSize ) * m_uiNumPartition ); 1483 1404 memcpy( rpcCU->getPredictionMode() + m_uiAbsIdxInLCU, m_pePredMode, sizeof( *m_pePredMode ) * m_uiNumPartition ); … … 1585 1506 Int sizeInChar = sizeof( Char ) * uiQNumPart; 1586 1507 memcpy( rpcCU->getSkipFlag() + uiPartOffset, m_skipFlag, sizeof( *m_skipFlag ) * uiQNumPart ); 1587 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331508 #if H_3D 1588 1509 memcpy( rpcCU->getDISFlag() + uiPartOffset, m_bDISFlag, sizeof( *m_bDISFlag ) * uiQNumPart ); 1589 1510 memcpy( rpcCU->getDISType() + uiPartOffset, m_uiDISType, sizeof( *m_uiDISType ) * uiQNumPart ); 1590 #else1591 #if H_3D_SINGLE_DEPTH1592 memcpy( rpcCU->getSingleDepthFlag() + uiPartOffset, m_singleDepthFlag, sizeof( *m_singleDepthFlag ) * uiQNumPart );1593 memcpy( rpcCU->getSingleDepthValue() + uiPartOffset, m_apSingleDepthValue, sizeof( *m_apSingleDepthValue ) * uiQNumPart);1594 #endif1595 1511 #endif 1596 1512 memcpy( rpcCU->getQP() + uiPartOffset, m_phQP, sizeInChar ); … … 1616 1532 memcpy( rpcCU->getCbf(TEXT_CHROMA_U) + uiPartOffset, m_puhCbf[1], iSizeInUchar ); 1617 1533 memcpy( rpcCU->getCbf(TEXT_CHROMA_V) + uiPartOffset, m_puhCbf[2], iSizeInUchar ); 1618 1619 1620 1534 #if H_3D_DIM 1621 1535 for( Int i = 0; i < DMM_NUM_TYPE; i++ ) … … 2352 2266 { 2353 2267 return NULL; 2354 } 2355 2268 } 2356 2269 #if H_3D_FCO 2357 2270 TComPic* depthPic = getSlice()->getIvPic(true, getSlice()->getViewIndex() ); … … 2388 2301 Int iPictureHeight = depthPicYuv->getHeight(); 2389 2302 2390 #if !HS_DBBP_CLEAN_K00482391 Int iWidth = uiWidth;2392 Int iHeight = uiHeight;2393 #endif2394 2303 2395 2304 Bool depthRefineFlag = false; … … 2404 2313 } 2405 2314 2406 #if HS_DBBP_CLEAN_K00482407 2315 Int depthPosX = Clip3(0, iPictureWidth - 1, iBlkX + ((cDv.getHor()+2)>>2)); 2408 2316 Int depthPosY = Clip3(0, iPictureHeight - 1, iBlkY + ((cDv.getVer()+2)>>2)); 2409 #else2410 Int depthPosX = Clip3(0, iPictureWidth - iWidth, iBlkX + ((cDv.getHor()+2)>>2));2411 Int depthPosY = Clip3(0, iPictureHeight- iHeight, iBlkY + ((cDv.getVer()+2)>>2));2412 #endif2413 2317 2414 2318 pDepthPels = depthPicYuv->getLumaAddr() + depthPosX + depthPosY * uiDepthStride; … … 2500 2404 memset( m_skipFlag + absPartIdx, skip, m_pcPic->getNumPartInCU() >> ( 2 * depth ) ); 2501 2405 } 2502 2503 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 2406 #if H_3D 2504 2407 Void TComDataCU::setDISFlagSubParts( Bool bDIS, UInt absPartIdx, UInt depth ) 2505 2408 { … … 2512 2415 setSubPartT( uiDISType, m_uiDISType, uiAbsPartIdx, uiDepth, uiPUIdx ); 2513 2416 } 2514 #else2515 #if H_3D_SINGLE_DEPTH2516 Void TComDataCU::setSingleDepthFlagSubParts( Bool singleDepth, UInt absPartIdx, UInt depth )2517 {2518 assert( sizeof( *m_singleDepthFlag) == 1 );2519 memset( m_singleDepthFlag + absPartIdx, singleDepth, m_pcPic->getNumPartInCU() >> ( 2 * depth ) );2520 }2521 2522 Void TComDataCU::setSingleDepthValueSubParts(Pel singleDepthValue, UInt uiAbsPartIdx, UInt uiPUIdx, UInt uiDepth )2523 {2524 setSubPartT<Pel>( singleDepthValue, m_apSingleDepthValue, uiAbsPartIdx, uiDepth, uiPUIdx );2525 }2526 #endif2527 2417 #endif 2528 2418 … … 3941 3831 #endif 3942 3832 #if H_3D_ARP 3943 Bool bARPFlag = getARPW(uiAbsPartIdx) >0 ? true : false;3833 Bool bARPFlag = getARPW(uiAbsPartIdx) > 0; 3944 3834 #endif 3945 3835 #if H_3D_DBBP … … 3974 3864 m_mergCands[MRG_A1].setCand( &pcMvFieldNeighbours[m_baseListidc<<1], puhInterDirNeighbours[m_baseListidc] 3975 3865 #if H_3D_VSP 3976 , 3977 (pcCULeft->getVSPFlag(uiLeftPartIdx) != 0 3866 , (pcCULeft->getVSPFlag(uiLeftPartIdx) != 0 3978 3867 #if H_3D_IC 3979 3868 && !bICFlag … … 3998 3887 m_mergCands[MRG_B1].setCand( &pcMvFieldNeighbours[m_baseListidc<<1], puhInterDirNeighbours[m_baseListidc] 3999 3888 #if H_3D_VSP 4000 , 4001 false 3889 , false 4002 3890 #endif 4003 3891 , false … … 4026 3914 m_mergCands[MRG_A0].setCand( &pcMvFieldNeighbours[m_baseListidc<<1], puhInterDirNeighbours[m_baseListidc] 4027 3915 #if H_3D_VSP 4028 , 4029 false 3916 , false 4030 3917 #endif 4031 3918 , false … … 4040 3927 m_mergCands[MRG_B2].setCand( &pcMvFieldNeighbours[m_baseListidc<<1], puhInterDirNeighbours[m_baseListidc] 4041 3928 #if H_3D_VSP 4042 , 4043 false 3929 , false 4044 3930 #endif 4045 3931 , false … … 4068 3954 TComPic * pcTexPic = m_pcSlice->getTexturePic(); 4069 3955 #if H_3D_FCO 4070 #if H_3D_FCO4071 3956 if (pcTexPic && pcTexPic->getReconMark()) 4072 #else4073 if (pcTexturePic->getReconMark())4074 #endif4075 3957 { 4076 3958 #endif … … 4107 3989 Int iTexPosX, iTexPosY; 4108 3990 const TComMv cMvRounding( 1 << ( 2 - 1 ), 1 << ( 2 - 1 ) ); 4109 3991 4110 3992 Int iCenterPosX = iCurrPosX + ( ( iWidth / iPUWidth ) >> 1 ) * iPUWidth + ( iPUWidth >> 1 ); 4111 3993 Int iCenterPosY = iCurrPosY + ( ( iHeight / iPUHeight ) >> 1 ) * iPUHeight + (iPUHeight >> 1); … … 4114 3996 if(iWidth == iPUWidth && iHeight == iPUHeight) 4115 3997 { 4116 4117 3998 iCenterPosX = iCurrPosX + (iWidth >> 1); 3999 iCenterPosY = iCurrPosY + (iHeight >> 1); 4118 4000 } 4119 4001 … … 4151 4033 if ( bSPIVMPFlag == true ) 4152 4034 { 4153 4154 4155 4156 4035 iInterDirSaved = (cMvFieldSaved[0].getRefIdx()!=-1 ? 1: 0) + (cMvFieldSaved[1].getRefIdx()!=-1 ? 2: 0); 4036 tmpDir = iInterDirSaved; 4037 tmpMV[0] = cMvFieldSaved[0]; 4038 tmpMV[1] = cMvFieldSaved[1]; 4157 4039 } 4158 4040 … … 4180 4062 TComMv cMv = cTexMvField.getMv() + cMvRounding; 4181 4063 cMv >>=2; 4182 #if !(NTT_BUG_FIX_TK54)4183 this->clipMv( cMv );4184 #endif4185 4064 pcMvFieldSP[2*iPartition + uiCurrRefListId].setMvField(cMv, iValidDepRef); 4186 4065 } … … 4197 4076 } 4198 4077 } 4199 #if !SHARP_SUBBLOCK_CLEAN_K00444200 if (iPUHeight + iPUWidth == 12)4201 {4202 if (puhInterDirSP[iPartition] == 3)4203 {4204 puhInterDirSP[iPartition] = 1;4205 pcMvFieldSP[2*iPartition + 1].setMvField(TComMv(0,0), -1);4206 }4207 }4208 #endif4209 4078 4210 4079 iPartition ++; … … 4309 4178 if (!bRemoveSpa) 4310 4179 { 4311 Bool SPIVMPFlag = false;4180 Bool spiMvpFlag = false; 4312 4181 if(!m_pcSlice->getIsDepth()) 4313 4182 { 4314 SPIVMPFlag = true;4183 spiMvpFlag = true; 4315 4184 } 4316 4185 #if H_3D_DBBP 4317 SPIVMPFlag &= !bDBBPFlag;4318 #endif 4319 4320 m_mergCands[MRG_IVMC].setCand( tmpMV, ivCandDir[0], false, SPIVMPFlag);4186 spiMvpFlag &= !bDBBPFlag; 4187 #endif 4188 4189 m_mergCands[MRG_IVMC].setCand( tmpMV, ivCandDir[0], false, spiMvpFlag); 4321 4190 4322 4191 if ( mrgCandIdx == iCount ) … … 5422 5291 } 5423 5292 5424 #if SONY_MV_V_CONST_C00785425 Void TComDataCU::checkM V_V(TComMv& rcMv, RefPicList eRefPicList, int iRefIdx )5293 #if H_MV 5294 Void TComDataCU::checkMvVertRest (TComMv& rcMv, RefPicList eRefPicList, int iRefIdx ) 5426 5295 { 5427 5296 if ( getSlice()->getSPS()->getInterViewMvVertConstraintFlag() ) … … 5780 5649 } 5781 5650 5782 if ( bIsCurrRefLongTerm || bIsColRefLongTerm ) // CY: this condition equals to both bIsCurrRefLongTerm and bIsColRefLongTerm being 15651 if ( bIsCurrRefLongTerm || bIsColRefLongTerm ) 5783 5652 { 5784 5653 #if H_3D_TMVP 5785 #if !H_3D_FIX_TMVP_SCALING_VIEW_ID5786 Int iCurrViewId = m_pcSlice->getViewIndex ();5787 Int iCurrRefViewId = m_pcSlice->getRefPic(eRefPicList, riRefIdx)->getViewIndex ();5788 Int iColViewId = pColCU->getSlice()->getViewIndex();5789 Int iColRefViewId = pColCU->getSlice()->getRefPic( eColRefPicList, pColCU->getCUMvField(eColRefPicList)->getRefIdx(uiAbsPartAddr))->getViewIndex();5790 #else5791 5654 Int iCurrViewId = m_pcSlice->getViewId (); 5792 5655 Int iCurrRefViewId = m_pcSlice->getRefPic(eRefPicList, riRefIdx)->getViewId (); 5793 5656 Int iColViewId = pColCU->getSlice()->getViewId(); 5794 5657 Int iColRefViewId = pColCU->getSlice()->getRefPic( eColRefPicList, pColCU->getCUMvField(eColRefPicList)->getRefIdx(uiAbsPartAddr))->getViewId(); 5795 #endif5796 #if H_3D_TMVP_SCALING_FIX_K00535797 5658 iScale = 4096; 5798 5659 if ( iCurrRefViewId != iCurrViewId && iColViewId != iColRefViewId ) 5799 #endif 5660 { 5800 5661 iScale = xGetDistScaleFactor( iCurrViewId, iCurrRefViewId, iColViewId, iColRefViewId ); 5801 #if H_3D_TMVP_FIX_TICKET_97 5662 } 5802 5663 if ( bMRG && iScale != 4096 && m_pcSlice->getIvMvScalingFlag( ) ) 5803 #else5804 if ( iScale != 4096 && m_pcSlice->getIvMvScalingFlag( ) )5805 #endif5806 5664 { 5807 5665 rcMv = cColMv.scaleMv( iScale ); … … 5815 5673 #endif 5816 5674 } 5817 else // CY: both bIsCurrRefLongTerm and bIsColRefLongTerm are 05675 else 5818 5676 { 5819 5677 iScale = xGetDistScaleFactor(iCurrPOC, iCurrRefPOC, iColPOC, iColRefPOC); … … 5979 5837 } 5980 5838 #endif 5839 5981 5840 #if H_3D_IV_MERGE 5982 #if SEC_ARP_REM_ENC_RESTRICT_K00355983 5841 Void TComDataCU::getDispforDepth (UInt uiPartIdx, UInt uiPartAddr, DisInfo* pDisp) 5984 #else 5985 Bool TComDataCU::getDispforDepth (UInt uiPartIdx, UInt uiPartAddr, DisInfo* pDisp) 5986 #endif 5987 { 5988 5842 { 5989 5843 assert(getPartitionSize( uiPartAddr ) == SIZE_2Nx2N); 5990 5844 … … 5992 5846 if ( getSlice()->getDefaultRefViewIdxAvailableFlag() ) 5993 5847 { 5994 Int iViewIdx = getSlice()->getDefaultRefViewIdx(); 5995 pDisp->m_aVIdxCan = iViewIdx; 5996 Int iDisp = getSlice()->getDepthToDisparityB( iViewIdx )[ (Int64) (1 << ( getSlice()->getSPS()->getBitDepthY() - 1 )) ]; 5997 5998 cMv.setHor(iDisp); 5999 cMv.setVer(0); 6000 pDisp->m_acNBDV = cMv; 6001 pDisp->m_aVIdxCan = iViewIdx; 6002 #if !SEC_ARP_REM_ENC_RESTRICT_K0035 6003 return true; 6004 #endif 6005 } 6006 #if !SEC_ARP_REM_ENC_RESTRICT_K0035 6007 return false; 6008 #endif 6009 } 6010 #endif 6011 6012 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 5848 Int iViewIdx = getSlice()->getDefaultRefViewIdx(); 5849 pDisp->m_aVIdxCan = iViewIdx; 5850 Int iDisp = getSlice()->getDepthToDisparityB( iViewIdx )[ (Int64) (1 << ( getSlice()->getSPS()->getBitDepthY() - 1 )) ]; 5851 5852 cMv.setHor(iDisp); 5853 cMv.setVer(0); 5854 pDisp->m_acNBDV = cMv; 5855 pDisp->m_aVIdxCan = iViewIdx; 5856 } 5857 } 5858 #endif 5859 5860 #if H_3D 6013 5861 Bool TComDataCU::getNeighDepth ( UInt uiPartIdx, UInt uiPartAddr, Pel* pNeighDepth, Int index ) 6014 5862 { 6015 #if NEIGHBORING_PIX_AVAILABILITY_FIX6016 5863 UInt uiPartIdxLT, uiPartIdxRT; 6017 5864 this->deriveLeftRightTopIdxAdi( uiPartIdxLT, uiPartIdxRT, 0, 0 ); … … 6066 5913 6067 5914 return bDepAvail; 6068 #else 6069 Bool bDepAvail = false; 6070 Pel *pDepth = this->getPic()->getPicYuvRec()->getLumaAddr(); 6071 Int iDepStride = this->getPic()->getPicYuvRec()->getStride(); 6072 6073 Int xP, yP, nPSW, nPSH; 6074 this->getPartPosition(uiPartIdx, xP, yP, nPSW, nPSH); 6075 UInt PicHeight=this->getPic()->getPicYuvRec()->getHeight(); 6076 UInt PicWidth=this->getPic()->getPicYuvRec()->getWidth(); 6077 switch(index) 6078 { 6079 case 0: // Mid Left 6080 if( ( xP != 0 ) && ( ( yP + ( nPSH >> 1 ) ) < PicHeight ) ) 6081 { 6082 *pNeighDepth = pDepth[ (yP+(nPSH>>1)) * iDepStride + (xP-1) ]; 6083 bDepAvail = true; 6084 } 6085 break; 6086 case 1: // Mid Above 6087 if( ( yP != 0 ) && ( ( xP + ( nPSW >> 1 ) ) < PicWidth ) ) 6088 { 6089 *pNeighDepth = pDepth[ (yP-1) * iDepStride + (xP + (nPSW>>1)) ]; 6090 bDepAvail = true; 6091 } 6092 break; 6093 default: 6094 break; 6095 } 6096 return bDepAvail; 6097 #endif 6098 } 6099 #else 6100 #if H_3D_SINGLE_DEPTH 6101 Bool TComDataCU::getNeighDepth (UInt uiPartIdx, UInt uiPartAddr, Pel* pNeighDepth, Int index) 6102 { 6103 6104 Bool bDepAvail = false; 6105 Pel *pDepth = this->getPic()->getPicYuvRec()->getLumaAddr(); 6106 Int iDepStride = this->getPic()->getPicYuvRec()->getStride(); 6107 6108 Int xP, yP, nPSW, nPSH; 6109 this->getPartPosition(uiPartIdx, xP, yP, nPSW, nPSH); 6110 UInt PicHeight=this->getPic()->getPicYuvRec()->getHeight(); 6111 UInt PicWidth=this->getPic()->getPicYuvRec()->getWidth(); 6112 switch(index) 6113 { 6114 case 0: // Mid Left 6115 if( ( xP != 0 ) && ( ( yP + ( nPSH >> 1 ) ) < PicHeight ) ) 6116 { 6117 *pNeighDepth = pDepth[ (yP+(nPSH>>1)) * iDepStride + (xP-1) ]; 6118 bDepAvail = true; 6119 } 6120 break; 6121 case 1: // Mid Above 6122 if( ( yP != 0 ) && ( ( xP + ( nPSW >> 1 ) ) < PicWidth ) ) 6123 { 6124 *pNeighDepth = pDepth[ (yP-1) * iDepStride + (xP + (nPSW>>1)) ]; 6125 bDepAvail = true; 6126 } 6127 break; 6128 default: 6129 break; 6130 } 6131 return bDepAvail; 6132 } 6133 #endif 6134 #endif 6135 5915 } 5916 #endif 6136 5917 #if H_3D_NBDV 6137 5918 //Notes from QC: … … 6139 5920 //TBD#2: set of DvMCP values need to be done as part of inter-view motion prediction process. Remove this comment once merge related integration is done 6140 5921 //To be checked: Parallel Merge features for NBDV, related to DV_DERIVATION_PARALLEL_B0096 and LGE_IVMP_PARALLEL_MERGE_B0136 are not integrated. The need of these features due to the adoption of CU-based NBDV is not clear. We need confirmation on this, especially by proponents 6141 #if SEC_ARP_REM_ENC_RESTRICT_K00356142 5922 Void TComDataCU::getDisMvpCandNBDV( DisInfo* pDInfo 6143 #else6144 Bool TComDataCU::getDisMvpCandNBDV( DisInfo* pDInfo6145 #endif6146 5923 #if H_3D_NBDV_REF 6147 5924 , Bool bDepthRefine … … 6151 5928 //// ******* Init variables ******* ///// 6152 5929 // Init disparity struct for results 6153 #if !SEC_ARP_REM_ENC_RESTRICT_K00356154 pDInfo->bDV = false;6155 #endif6156 5930 pDInfo->m_aVIdxCan = -1; 6157 5931 … … 6217 5991 if( bCheck ) 6218 5992 { 6219 #if !(NTT_BUG_FIX_TK54)6220 clipMv(cColMv);6221 #endif6222 5993 pDInfo->m_acNBDV = cColMv; 6223 5994 pDInfo->m_aVIdxCan = iTargetViewIdx; … … 6239 6010 #else 6240 6011 picDepth = getSlice()->getIvPic( true, iTargetViewIdx ); 6241 #if !BUG_FIX_TK656242 assert(picDepth != NULL);6243 #endif6244 6012 #endif 6245 6013 if (picDepth && bDepthRefine) 6014 { 6246 6015 estimateDVFromDM(iTargetViewIdx, uiPartIdx, picDepth, uiPartAddr, &cColMv ); 6247 6016 } 6248 6017 pDInfo->m_acDoNBDV = cColMv; 6249 6018 #endif //H_3D_NBDV_REF 6250 #if SEC_ARP_REM_ENC_RESTRICT_K00356251 6019 return; 6252 #else6253 return true;6254 #endif6255 6020 } 6256 6021 } … … 6269 6034 #endif 6270 6035 ) ) 6271 #if SEC_ARP_REM_ENC_RESTRICT_K00356272 6036 return; 6273 #else6274 return true;6275 #endif6276 6037 6277 6038 //// ******* Get disparity from above block ******* ///// … … 6285 6046 #endif 6286 6047 ) ) 6287 #if SEC_ARP_REM_ENC_RESTRICT_K00356288 6048 return; 6289 #else6290 return true;6291 #endif6292 6049 } 6293 6050 … … 6302 6059 { 6303 6060 TComMv cDispVec = cIDVInfo.m_acMvCand[iList][ curPos ]; 6304 #if !(NTT_BUG_FIX_TK54)6305 clipMv( cDispVec );6306 #endif6307 6061 pDInfo->m_acNBDV = cDispVec; 6308 6062 pDInfo->m_aVIdxCan = cIDVInfo.m_aVIdxCan[iList][ curPos ]; … … 6324 6078 #else 6325 6079 TComPic* picDepth = getSlice()->getIvPic( true, pDInfo->m_aVIdxCan ); 6326 #if !BUG_FIX_TK656327 assert(picDepth!=NULL);6328 #endif6329 6080 #endif 6330 6081 … … 6335 6086 pDInfo->m_acDoNBDV = cDispVec; 6336 6087 #endif 6337 #if SEC_ARP_REM_ENC_RESTRICT_K00356338 6088 return; 6339 #else6340 return true;6341 #endif6342 6089 } 6343 6090 } … … 6350 6097 if (getSlice()->getDefaultRefViewIdxAvailableFlag()) 6351 6098 { 6352 6099 pDInfo->m_aVIdxCan = getSlice()->getDefaultRefViewIdx(); 6353 6100 6354 6101 #if H_3D_NBDV_REF 6355 6102 TComPic* picDepth = NULL; 6356 6103 #if H_3D_FCO_VSP_DONBDV_E0163 6357 6358 6359 6360 6361 6362 6363 6364 6365 6366 6367 6104 picDepth = getSlice()->getIvPic(true, getSlice()->getViewIndex() ); 6105 if ( picDepth->getPicYuvRec() != NULL ) 6106 { 6107 defaultDV.setZero(); 6108 } 6109 else // Go back with virtual depth 6110 { 6111 picDepth = getSlice()->getIvPic( true, getSlice()->getDefaultRefViewIdx()); 6112 } 6113 6114 assert(picDepth != NULL); 6368 6115 #else 6369 picDepth = getSlice()->getIvPic( true, getSlice()->getDefaultRefViewIdx()); 6370 #endif 6371 if (picDepth && bDepthRefine) 6372 { 6373 estimateDVFromDM(getSlice()->getDefaultRefViewIdx(), uiPartIdx, picDepth, uiPartAddr, &defaultDV ); // from base view 6374 } 6375 pDInfo->m_acDoNBDV = defaultDV; 6376 #endif 6377 #if !SEC_ARP_REM_ENC_RESTRICT_K0035 6378 return true; 6379 #endif 6380 } 6381 #if !SEC_ARP_REM_ENC_RESTRICT_K0035 6382 return false; 6383 #endif 6116 picDepth = getSlice()->getIvPic( true, getSlice()->getDefaultRefViewIdx()); 6117 #endif 6118 if (picDepth && bDepthRefine) 6119 { 6120 estimateDVFromDM(getSlice()->getDefaultRefViewIdx(), uiPartIdx, picDepth, uiPartAddr, &defaultDV ); // from base view 6121 } 6122 pDInfo->m_acDoNBDV = defaultDV; 6123 #endif 6124 } 6384 6125 } 6385 6126 … … 6423 6164 Pel iDisp = getMcpFromDM( pcBaseViewDepthPicYuv, cMvPred, iBlkX, iBlkY, iWidth, iHeight, aiShiftLUT ); 6424 6165 cMvPred->setHor( iDisp ); 6425 #if !(NTT_BUG_FIX_TK54)6426 clipMv(*cMvPred);6427 #endif6428 6166 } 6429 6167 } … … 6451 6189 if (refViewIdx != m_pcSlice->getViewIndex()) 6452 6190 { 6453 #if !(NTT_BUG_FIX_TK54)6454 clipMv(cMvPred);6455 #endif6456 6191 pNbDvInfo->m_acNBDV = cMvPred; 6457 6192 pNbDvInfo->m_aVIdxCan = refViewIdx; … … 6472 6207 #else 6473 6208 picDepth = getSlice()->getIvPic (true, refViewIdx ); 6474 #if !BUG_FIX_TK656475 assert(picDepth != NULL);6476 #endif6477 6209 #endif 6478 6210 UInt uiPartIdx = 0; //Notes from MTK: Please confirm that using 0 as partition index and partition address is correct for CU-level DoNBDV … … 6480 6212 6481 6213 if (picDepth && bDepthRefine) 6214 { 6482 6215 estimateDVFromDM(refViewIdx, uiPartIdx, picDepth, uiPartAddr, &cMvPred ); 6483 6216 } 6484 6217 pNbDvInfo->m_acDoNBDV = cMvPred; 6485 6218 #endif … … 6870 6603 #endif 6871 6604 #endif 6872 #if !(NTT_BUG_FIX_TK54)6873 clipMv( cMv );6874 #endif6875 6605 paiPdmRefIdx [ uiCurrRefListId ] = iPdmRefIdx; 6876 6606 pacPdmMv [ uiCurrRefListId ] = cMv; … … 6904 6634 { 6905 6635 RefPicList eCurrRefPicList = RefPicList( uiCurrRefListId ); 6906 Bool bLoop _stop = false;6907 for(Int iLoop = 0; iLoop < 2 && !bLoop _stop; ++iLoop)6636 Bool bLoopStop = false; 6637 for(Int iLoop = 0; iLoop < 2 && !bLoopStop; ++iLoop) 6908 6638 { 6909 6639 RefPicList eBaseRefPicList = (iLoop ==1)? RefPicList( 1 - uiCurrRefListId ) : RefPicList( uiCurrRefListId ); … … 6931 6661 } 6932 6662 6933 #if !(NTT_BUG_FIX_TK54) 6934 clipMv( cMv ); 6935 #endif 6936 bLoop_stop = true; 6663 bLoopStop = true; 6937 6664 6938 6665 pcMvFieldSP[2*iPartition + uiCurrRefListId].setMvField(cMv, iPdmRefIdx); … … 6954 6681 6955 6682 } 6956 #if !SHARP_SUBBLOCK_CLEAN_K00446957 if (iSPHeight + iSPWidth == 12)6958 {6959 if (puhInterDirSP[iPartition] == 3)6960 {6961 puhInterDirSP[iPartition] = 1;6962 pcMvFieldSP[2*iPartition + 1].setMvField(TComMv(0,0), -1);6963 }6964 }6965 #endif6966 6683 iPartition ++; 6967 6684 } … … 6996 6713 Int iBaseAbsPartIdx; 6997 6714 6998 #if SEC_SHIFTED_IVMC_POS_K00366999 6715 Int offsetW = (iLoopCan == 0) ? 0 : ( iWidth * 2 ); 7000 6716 Int offsetH = (iLoopCan == 0) ? 0 : ( iHeight * 2 ); 7001 #else7002 Int offsetW = (iLoopCan == 0) ? 0 : ( ((iWidth /2)*4) + 4 );7003 Int offsetH = (iLoopCan == 0) ? 0 : ( ((iHeight/2)*4) + 4 );7004 #endif7005 6717 7006 6718 Int iBasePosX = Clip3( 0, pcBaseRec->getWidth () - 1, iCurrPosX + ( (cDv.getHor() + offsetW + 2 ) >> 2 ) ); … … 7048 6760 #endif 7049 6761 #endif 7050 #if !(NTT_BUG_FIX_TK54)7051 clipMv( cMv );7052 #endif7053 6762 paiPdmRefIdx [ (uiCurrRefListId + (iLoopCan<<2)) ] = iPdmRefIdx; 7054 6763 pacPdmMv [ (uiCurrRefListId + (iLoopCan<<2)) ] = cMv; … … 7104 6813 #endif 7105 6814 cMv.setVer( 0 ); 7106 #if !(NTT_BUG_FIX_TK54)7107 clipMv( cMv );7108 #endif7109 6815 pacPdmMv [iRefListId + 2 + (iLoopCan<<2)] = cMv; 7110 6816 } … … 7187 6893 { 7188 6894 UInt uiCurrPartNumb = m_pcPic->getNumPartInCU() >> (uiDepth << 1); 7189 for( UInt ui = 0; ui < uiCurrPartNumb; ui++ ) { m_dmmWedgeTabIdx[dmmType][uiAbsPartIdx+ui] = tabIdx; } 6895 for( UInt ui = 0; ui < uiCurrPartNumb; ui++ ) 6896 { 6897 m_dmmWedgeTabIdx[dmmType][uiAbsPartIdx+ui] = tabIdx; 6898 } 7190 6899 } 7191 6900 #endif -
trunk/source/Lib/TLibCommon/TComDataCU.h
r1179 r1196 72 72 PartSize eVirtualPartSize; 73 73 UInt uiVirtualPartIndex; 74 } D BBPTmpData;74 } DbbpTmpData; 75 75 #endif 76 76 … … 110 110 // ------------------------------------------------------------------------------------------------------------------- 111 111 Bool* m_skipFlag; ///< array of skip flags 112 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033112 #if H_3D 113 113 Bool* m_bDISFlag; 114 114 UInt* m_uiDISType; 115 #else116 #if H_3D_SINGLE_DEPTH117 Bool* m_singleDepthFlag; ///< array of single depth flags118 Pel* m_apSingleDepthValue;119 #endif120 115 #endif 121 116 Char* m_pePartSize; ///< array of partition sizes … … 178 173 #endif 179 174 #if H_3D_VSP 180 Char* m_piVSPFlag; ///< array of VSP flags to indicate whehter a block uses VSP or not 181 ///< 0: non-VSP; 1: VSP 175 Char* m_piVSPFlag; ///< array of VSP flags to indicate whehter a block uses VSP or not ///< 0: non-VSP; 1: VSP 182 176 #endif 183 177 #if H_3D_SPIVMP 184 Bool* m_pbSPIVMPFlag; ///< array of sub-PU IVMP flags to indicate whehter a block uses sub-PU IVMP 185 ///< 0: non-SPIVMP; 1: SPIVMP 178 Bool* m_pbSPIVMPFlag; ///< array of sub-PU IVMP flags to indicate whehter a block uses sub-PU IVMP ///< 0: non-SPIVMP; 1: SPIVMP 186 179 #endif 187 180 #if H_3D_ARP … … 199 192 Bool* m_pbSDCFlag; 200 193 Pel* m_apSegmentDCOffset[2]; 201 Pel m_apDmmPredictor[2];194 Pel m_apDmmPredictor[2]; 202 195 #endif 203 196 #endif 204 197 #if H_3D_DBBP 205 198 Bool* m_pbDBBPFlag; ///< array of DBBP flags 206 D BBPTmpData m_sDBBPTmpData;199 DbbpTmpData m_sDBBPTmpData; 207 200 #endif 208 201 #if H_3D … … 252 245 Bool xGetColMVP( RefPicList eRefPicList, Int uiCUAddr, Int uiPartUnitIdx, TComMv& rcMv, Int& riRefIdx 253 246 #if H_3D_TMVP 254 , 255 Bool bMRG = true 247 , Bool bMRG = true 256 248 #endif 257 249 ); … … 350 342 Void setSkipFlag ( UInt idx, Bool skip) { m_skipFlag[idx] = skip; } 351 343 Void setSkipFlagSubParts ( Bool skip, UInt absPartIdx, UInt depth ); 352 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033344 #if H_3D 353 345 Bool* getDISFlag () { return m_bDISFlag; } 354 346 Bool getDISFlag ( UInt idx) { return m_bDISFlag[idx]; } … … 360 352 Void getDISType ( UInt idx, UInt uiDISType) { m_uiDISType[idx] = uiDISType; } 361 353 Void setDISTypeSubParts ( UInt uiDISType, UInt uiAbsPartIdx, UInt uiPUIdx, UInt uiDepth ); 362 #else363 #if H_3D_SINGLE_DEPTH364 Bool* getSingleDepthFlag () { return m_singleDepthFlag; }365 Bool getSingleDepthFlag (UInt idx) { return m_singleDepthFlag[idx]; }366 Void setSingleDepthFlag ( UInt idx, Bool singleDepth) { m_singleDepthFlag[idx] = singleDepth; }367 Void setSingleDepthFlagSubParts ( Bool singleDepth, UInt absPartIdx, UInt depth );368 369 Pel* getSingleDepthValue( ) { return m_apSingleDepthValue; }370 Pel getSingleDepthValue (UInt idx) { return m_apSingleDepthValue[idx]; }371 Void setSingleDepthValue ( UInt idx, Pel pDepthValue) { m_apSingleDepthValue[idx] = pDepthValue; }372 Void setSingleDepthValueSubParts (Pel singleDepthValue, UInt uiAbsPartIdx, UInt uiPUIdx, UInt uiDepth );373 #endif374 354 #endif 375 355 Char* getPredictionMode () { return m_pePredMode; } … … 385 365 Void setDBBPFlag ( UInt uiIdx, Bool b ) { m_pbDBBPFlag[uiIdx] = b; } 386 366 Void setDBBPFlagSubParts ( Bool bDBBPFlag, UInt uiAbsPartIdx, UInt uiPartIdx, UInt uiDepth ); 387 D BBPTmpData* getDBBPTmpData () { return &m_sDBBPTmpData; }367 DbbpTmpData* getDBBPTmpData () { return &m_sDBBPTmpData; } 388 368 #endif 389 369 … … 506 486 ); 507 487 Bool xGetColDisMV ( Int currCandPic, RefPicList eRefPicList, Int refidx, Int uiCUAddr, Int uiPartUnitIdx, TComMv& rcMv, Int & iTargetViewIdx, Int & iStartViewIdx ); 508 #if SEC_ARP_REM_ENC_RESTRICT_K0035509 488 Void getDisMvpCandNBDV ( DisInfo* pDInfo 510 #else511 Bool getDisMvpCandNBDV ( DisInfo* pDInfo512 #endif513 489 #if H_3D_NBDV_REF 514 490 , Bool bDepthRefine = false … … 517 493 518 494 #if H_3D 519 #if SEC_ARP_REM_ENC_RESTRICT_K0035520 495 Void getDispforDepth ( UInt uiPartIdx, UInt uiPartAddr, DisInfo* cDisp); 521 #else522 Bool getDispforDepth ( UInt uiPartIdx, UInt uiPartAddr, DisInfo* cDisp);523 #endif524 496 Bool getDispMvPredCan(UInt uiPartIdx, RefPicList eRefPicList, Int iRefIdx, Int* paiPdmRefIdx, TComMv* pacPdmMv, DisInfo* pDis, Int* iPdm ); 525 #endif 526 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 497 527 498 Bool getNeighDepth (UInt uiPartIdx, UInt uiPartAddr, Pel* pNeighDepth, Int index); 528 #else529 #if H_3D_SINGLE_DEPTH530 Bool getNeighDepth (UInt uiPartIdx, UInt uiPartAddr, Pel* pNeighDepth, Int index);531 #endif532 499 #endif 533 500 #if H_3D_NBDV_REF … … 625 592 626 593 Void clipMv ( TComMv& rcMv ); 627 #if SONY_MV_V_CONST_C0078628 Void checkM V_V(TComMv& rcMv, RefPicList eRefPicList, int iRefIdx );594 #if H_MV 595 Void checkMvVertRest (TComMv& rcMv, RefPicList eRefPicList, int iRefIdx ); 629 596 #endif 630 597 Void getMvPredLeft ( TComMv& rcMvPred ) { rcMvPred = m_cMvFieldA.getMv(); } -
trunk/source/Lib/TLibCommon/TComMotionInfo.cpp
r1179 r1196 335 335 Int iStartPelY = g_auiRasterToPelY[g_auiZscanToRaster[uiAbsPartIdx]]; 336 336 Int iEndPelX = iStartPelX + iWidth; 337 Int iEndPelY = iStartPelY + iHeight; 338 339 Int iCurrRaster, uiPartAddr; 337 Int iEndPelY = iStartPelY + iHeight; 340 338 341 339 for (Int i=iStartPelY; i<iEndPelY; i+=pcCU->getPic()->getMinCUHeight()) … … 343 341 for (Int j=iStartPelX; j < iEndPelX; j += pcCU->getPic()->getMinCUWidth()) 344 342 { 345 iCurrRaster = i / pcCU->getPic()->getMinCUHeight() * pcCU->getPic()->getNumPartInWidth() + j/pcCU->getPic()->getMinCUWidth();346 uiPartAddr = g_auiRasterToZscan[iCurrRaster];343 Int iCurrRaster = i / pcCU->getPic()->getMinCUHeight() * pcCU->getPic()->getNumPartInWidth() + j/pcCU->getPic()->getMinCUWidth(); 344 Int uiPartAddr = g_auiRasterToZscan[iCurrRaster]; 347 345 uiPartAddr -= pcCU->getZorderIdxInCU(); 348 346 -
trunk/source/Lib/TLibCommon/TComMotionInfo.h
r1179 r1196 63 63 typedef struct _DisCand 64 64 { 65 #if !SEC_ARP_REM_ENC_RESTRICT_K003566 Bool bDV;67 #endif68 65 TComMv m_acNBDV; // DV from NBDV 69 66 #if H_3D_NBDV_REF -
trunk/source/Lib/TLibCommon/TComPrediction.cpp
r1179 r1196 54 54 m_pDepthBlock = (Int*) malloc(MAX_NUM_SPU_W*MAX_NUM_SPU_W*sizeof(Int)); 55 55 if (m_pDepthBlock == NULL) 56 { 56 57 printf("ERROR: UKTGHU, No memory allocated.\n"); 58 } 57 59 #endif 58 60 } … … 62 64 #if H_3D_VSP 63 65 if (m_pDepthBlock != NULL) 64 free(m_pDepthBlock); 66 { 67 free(m_pDepthBlock); 68 } 65 69 m_cYuvDepthOnVsp.destroy(); 66 70 #endif … … 513 517 514 518 #if H_3D_DIM_DMM 515 if( dimType == DMM4_IDX && dmm4Segmentation == NULL ) { dmmSegmentation->destroy(); delete dmmSegmentation; } 519 if( dimType == DMM4_IDX && dmm4Segmentation == NULL ) 520 { 521 dmmSegmentation->destroy(); 522 delete dmmSegmentation; 523 } 516 524 #endif 517 525 } … … 630 638 631 639 #if H_3D_DBBP 632 #if HS_DBBP_CLEAN_K0048633 640 PartSize TComPrediction::getPartitionSizeFromDepth(Pel* pDepthPels, UInt uiDepthStride, UInt uiSize, TComDataCU*& pcCU) 634 #else635 PartSize TComPrediction::getPartitionSizeFromDepth(Pel* pDepthPels, UInt uiDepthStride, UInt uiSize)636 #endif637 641 { 638 642 // find virtual partitioning for this CU based on depth block 639 643 // segmentation of texture block --> mask IDs 640 644 Pel* pDepthBlockStart = pDepthPels; 641 645 642 646 // first compute average of depth block for thresholding 643 647 Int iSumDepth = 0; 644 648 Int iSubSample = 4; 645 #if HS_DBBP_CLEAN_K0048646 649 Int iPictureWidth = pcCU->getSlice()->getIvPic (true, pcCU->getDvInfo(0).m_aVIdxCan)->getPicYuvRec()->getWidth(); 647 650 Int iPictureHeight = pcCU->getSlice()->getIvPic (true, pcCU->getDvInfo(0).m_aVIdxCan)->getPicYuvRec()->getHeight(); … … 653 656 Int iBlkX = ( pcCU->getAddr() % pcCU->getSlice()->getIvPic (true, pcCU->getDvInfo(0).m_aVIdxCan)->getFrameWidthInCU() ) * g_uiMaxCUWidth + g_auiRasterToPelX[ g_auiZscanToRaster[ pcCU->getZorderIdxInCU() ] ]+ ((cDv.getHor()+2)>>2); 654 657 Int iBlkY = ( pcCU->getAddr() / pcCU->getSlice()->getIvPic (true, pcCU->getDvInfo(0).m_aVIdxCan)->getFrameWidthInCU() ) * g_uiMaxCUHeight + g_auiRasterToPelY[ g_auiZscanToRaster[ pcCU->getZorderIdxInCU() ] ]+ ((cDv.getVer()+2)>>2); 658 655 659 UInt t=0; 656 660 657 661 for (Int y=0; y<uiSize; y+=iSubSample) 658 662 { 659 663 for (Int x=0; x<uiSize; x+=iSubSample) 660 {661 if (iBlkX+x>iPictureWidth)662 {663 Int depthPel = pDepthPels[t];664 iSumDepth += depthPel;665 }666 else667 {668 Int depthPel = pDepthPels[x];669 t=x;670 iSumDepth += depthPel;671 }672 }673 664 { 665 if (iBlkX+x>iPictureWidth) 666 { 667 Int depthPel = pDepthPels[t]; 668 iSumDepth += depthPel; 669 } 670 else 671 { 672 Int depthPel = pDepthPels[x]; 673 t=x; 674 iSumDepth += depthPel; 675 } 676 } 677 674 678 // next row 675 679 if (!(iBlkY+y+4>iPictureHeight)) 676 pDepthPels += uiDepthStride*iSubSample; 677 #else 678 for (Int y=0; y<uiSize; y+=iSubSample) 679 { 680 for (Int x=0; x<uiSize; x+=iSubSample) 681 { 682 Int depthPel = pDepthPels[x]; 683 684 iSumDepth += depthPel; 685 } 686 687 // next row 688 pDepthPels += uiDepthStride*iSubSample; 689 #endif 690 } 691 680 { 681 pDepthPels += uiDepthStride*iSubSample; 682 } 683 } 684 692 685 Int iSizeInBits = g_aucConvertToBit[uiSize] - g_aucConvertToBit[iSubSample]; // respect sub-sampling factor 693 686 Int iMean = iSumDepth >> iSizeInBits*2; // iMean /= (uiSize*uiSize); 694 687 695 688 // start again for segmentation 696 689 pDepthPels = pDepthBlockStart; 697 690 698 691 // start mapping process 699 692 Int matchedPartSum[2][2] = {{0,0},{0,0}}; // counter for each part size and boolean option 700 693 PartSize virtualPartSizes[2] = { SIZE_Nx2N, SIZE_2NxN}; 701 694 702 695 UInt uiHalfSize = uiSize>>1; 703 696 for (Int y=0; y<uiSize; y+=iSubSample) … … 705 698 for (Int x=0; x<uiSize; x+=iSubSample) 706 699 { 707 #if HS_DBBP_CLEAN_K0048708 700 Int depthPel = 0; 709 if (iBlkX+x>iPictureWidth) 710 { 711 depthPel = pDepthPels[t]; 712 } 713 else 714 { 715 depthPel = pDepthPels[x]; 716 t=x; 717 } 718 #else 719 Int depthPel = pDepthPels[x]; 720 #endif 721 701 if (iBlkX+x>iPictureWidth) 702 { 703 depthPel = pDepthPels[t]; 704 } 705 else 706 { 707 depthPel = pDepthPels[x]; 708 t=x; 709 } 710 722 711 // decide which segment this pixel belongs to 723 712 Int ucSegment = (Int)(depthPel>iMean); 724 713 725 714 // Matched Filter to find optimal (conventional) partitioning 726 715 727 716 // SIZE_Nx2N 728 717 if(x<uiHalfSize) // left … … 734 723 matchedPartSum[0][1-ucSegment]++; 735 724 } 736 725 737 726 // SIZE_2NxN 738 727 if(y<uiHalfSize) // top … … 745 734 } 746 735 } 747 736 748 737 // next row 749 #if HS_DBBP_CLEAN_K0048750 738 if (!(iBlkY+y+4>iPictureHeight)) 751 #endif 752 pDepthPels += uiDepthStride*iSubSample; 753 } 754 739 { 740 pDepthPels += uiDepthStride*iSubSample; 741 } 742 } 743 755 744 PartSize matchedPartSize = SIZE_NONE; 756 745 757 746 Int iMaxMatchSum = 0; 758 747 for(Int p=0; p<2; p++) // loop over partition … … 767 756 } 768 757 } 769 758 770 759 AOF( matchedPartSize != SIZE_NONE ); 771 760 772 761 return matchedPartSize; 773 762 } 774 763 775 #if HS_DBBP_CLEAN_K0048776 764 Bool TComPrediction::getSegmentMaskFromDepth( Pel* pDepthPels, UInt uiDepthStride, UInt uiWidth, UInt uiHeight, Bool* pMask, TComDataCU*& pcCU) 777 #else778 Bool TComPrediction::getSegmentMaskFromDepth( Pel* pDepthPels, UInt uiDepthStride, UInt uiWidth, UInt uiHeight, Bool* pMask )779 #endif780 765 { 781 766 // segmentation of texture block --> mask IDs … … 786 771 Int uiMinDepth = MAX_INT; 787 772 Int uiMaxDepth = 0; 788 #if HS_DBBP_CLEAN_K0048789 773 uiMinDepth = pDepthPels[ 0 ]; 790 774 uiMaxDepth = pDepthPels[ 0 ]; 791 775 iSumDepth = pDepthPels[ 0 ]; 792 UInt t=0;776 793 777 Int iPictureWidth = pcCU->getSlice()->getIvPic (true, pcCU->getDvInfo(0).m_aVIdxCan)->getPicYuvRec()->getWidth(); 794 778 Int iPictureHeight = pcCU->getSlice()->getIvPic (true, pcCU->getDvInfo(0).m_aVIdxCan)->getPicYuvRec()->getHeight(); … … 848 832 uiMaxDepth = std::max( uiMaxDepth, (Int)pDepthPels[ uiDepthStride * (uiHeight - 1) + uiWidth - 1 ]); 849 833 } 850 #else851 iSumDepth = pDepthPels[ 0 ];852 iSumDepth += pDepthPels[ uiWidth - 1 ];853 iSumDepth += pDepthPels[ uiDepthStride * (uiHeight - 1) ];854 iSumDepth += pDepthPels[ uiDepthStride * (uiHeight - 1) + uiWidth - 1 ];855 856 uiMinDepth = pDepthPels[ 0 ];857 uiMinDepth = std::min( uiMinDepth, (Int)pDepthPels[ uiWidth - 1 ]);858 uiMinDepth = std::min( uiMinDepth, (Int)pDepthPels[ uiDepthStride * (uiHeight - 1) ]);859 uiMinDepth = std::min( uiMinDepth, (Int)pDepthPels[ uiDepthStride * (uiHeight - 1) + uiWidth - 1 ]);860 861 uiMaxDepth = pDepthPels[ 0 ];862 uiMaxDepth = std::max( uiMaxDepth, (Int)pDepthPels[ uiWidth - 1 ]);863 uiMaxDepth = std::max( uiMaxDepth, (Int)pDepthPels[ uiDepthStride * (uiHeight - 1) ]);864 uiMaxDepth = std::max( uiMaxDepth, (Int)pDepthPels[ uiDepthStride * (uiHeight - 1) + uiWidth - 1 ]);865 #endif866 834 867 835 // don't generate mask for blocks with small depth range (encoder decision) … … 880 848 881 849 // generate mask 850 UInt t=0; 882 851 UInt uiSumPix[2] = {0,0}; 883 852 for (Int y=0; y<uiHeight; y++) … … 885 854 for (Int x=0; x<uiHeight; x++) 886 855 { 887 #if HS_DBBP_CLEAN_K0048888 856 Int depthPel = 0; 889 857 if (iBlkX+x>iPictureWidth) … … 896 864 t=x; 897 865 } 898 #else899 Int depthPel = pDepthPels[x];900 #endif901 866 902 867 // decide which segment this pixel belongs to … … 916 881 917 882 // next row 918 #if HS_DBBP_CLEAN_K0048919 883 if (!(iBlkY+y+1>iPictureHeight)) 920 #endif921 884 pDepthPels += uiDepthStride; 922 885 pMask += MAX_CU_SIZE; … … 1003 966 } 1004 967 1005 if ( tmpTar ) { xFree(tmpTar); tmpTar = NULL; } 968 if ( tmpTar ) 969 { 970 xFree(tmpTar); 971 tmpTar = NULL; 972 } 1006 973 1007 974 // now combine chroma … … 1106 1073 } 1107 1074 1108 if ( tmpTarU ) { xFree(tmpTarU); tmpTarU = NULL; } 1109 if ( tmpTarV ) { xFree(tmpTarV); tmpTarV = NULL; } 1075 if( tmpTarU ) 1076 { 1077 xFree(tmpTarU); 1078 tmpTarU = NULL; 1079 } 1080 if ( tmpTarV ) 1081 { 1082 xFree(tmpTarV); 1083 tmpTarV = NULL; 1084 } 1110 1085 } 1111 1086 #endif … … 1293 1268 TComMv cMv = pcCU->getCUMvField( eRefPicList )->getMv( uiPartAddr ); 1294 1269 pcCU->clipMv(cMv); 1295 #if SONY_MV_V_CONST_C00781296 pcCU->checkM V_V(cMv, eRefPicList, iRefIdx );1270 #if H_MV 1271 pcCU->checkMvVertRest(cMv, eRefPicList, iRefIdx ); 1297 1272 #endif 1298 1273 #if H_3D_ARP … … 1393 1368 #if H_3D_NBDV 1394 1369 DisInfo cDistparity; 1395 #if SEC_ARP_REM_ENC_RESTRICT_K00351396 1370 cDistparity.m_acNBDV = pcCU->getDvInfo(0).m_acNBDV; 1397 1371 cDistparity.m_aVIdxCan = pcCU->getDvInfo(uiPartAddr).m_aVIdxCan; 1398 1372 #else 1399 cDistparity.bDV = pcCU->getDvInfo(uiPartAddr).bDV;1400 if( cDistparity.bDV )1401 {1402 cDistparity.m_acNBDV = pcCU->getDvInfo(0).m_acNBDV;1403 assert(pcCU->getDvInfo(uiPartAddr).bDV == pcCU->getDvInfo(0).bDV);1404 cDistparity.m_aVIdxCan = pcCU->getDvInfo(uiPartAddr).m_aVIdxCan;1405 }1406 #endif1407 #else1408 1373 assert(0); // ARP can be applied only when a DV is available 1409 1374 #endif 1410 #if SEC_ARP_REM_ENC_RESTRICT_K00351411 1375 UChar dW = pcCU->getARPW ( uiPartAddr ); 1412 #else 1413 UChar dW = cDistparity.bDV ? pcCU->getARPW ( uiPartAddr ) : 0; 1414 #endif 1415 1416 #if !SEC_ARP_REM_ENC_RESTRICT_K0035 1417 if( cDistparity.bDV ) 1418 #endif 1376 1419 1377 { 1420 1378 Int arpRefIdx = pcCU->getSlice()->getFirstTRefIdx(eRefPicList); … … 1468 1426 pYuvB0->clear(); pYuvB1->clear(); 1469 1427 } 1470 #if !SEC_ARP_REM_ENC_RESTRICT_K00351471 assert ( cDistparity.bDV );1472 #endif1473 1428 TComMv cNBDV = cDistparity.m_acNBDV; 1474 1429 pcCU->clipMv( cNBDV ); … … 2438 2393 for( UInt k = 0; k < (patternStride * patternStride); k++ ) 2439 2394 { 2440 if( true == biSegPattern[k] ) { ptrDst[k] = valDC2; } 2441 else { ptrDst[k] = valDC1; } 2395 if( true == biSegPattern[k] ) 2396 { 2397 ptrDst[k] = valDC2; 2398 } 2399 else 2400 { 2401 ptrDst[k] = valDC1; 2402 } 2442 2403 } 2443 2404 } … … 2449 2410 for( UInt uiX = 0; uiX < patternStride; uiX++ ) 2450 2411 { 2451 if( true == biSegPattern[uiX] ) { piTemp[uiX] = valDC2; } 2452 else { piTemp[uiX] = valDC1; } 2412 if( true == biSegPattern[uiX] ) 2413 { 2414 piTemp[uiX] = valDC2; 2415 } 2416 else 2417 { 2418 piTemp[uiX] = valDC1; 2419 } 2453 2420 } 2454 2421 piTemp += dstStride; … … 2520 2487 Int iSumPix[2]; 2521 2488 memset(iSumPix, 0, sizeof(Int)*2); 2489 2522 2490 for( Int i = 0; i < uiNumSegments; i++ ) 2523 2491 { 2524 rpSegMeans[i] = 0; 2525 } 2526 if (orgDC == false) 2492 rpSegMeans[i] = 0; 2493 } 2494 2495 if ( !orgDC ) 2527 2496 { 2528 2497 Pel* pLeftTop = pOrig; … … 2544 2513 subSamplePix = 1; 2545 2514 } 2515 2546 2516 for (Int y=0; y<uiSize; y+=subSamplePix) 2547 2517 { … … 2563 2533 { 2564 2534 if( iSumPix[ucSeg] > 0 ) 2535 { 2565 2536 rpSegMeans[ucSeg] = iSumDepth[ucSeg] / iSumPix[ucSeg]; 2537 } 2566 2538 else 2539 { 2567 2540 rpSegMeans[ucSeg] = 0; // this happens for zero-segments 2541 } 2568 2542 } 2569 2543 } -
trunk/source/Lib/TLibCommon/TComPrediction.h
r1179 r1196 121 121 Void xPredInterUniSubPU ( TComDataCU *cu, UInt uiPartAddr, Int iWidth, Int iHeight, RefPicList eRefPicList, TComYuv*& rpcYuvPred, Bool bi, Int widthSubPU=4, Int heightSubPU=4 ); 122 122 #endif 123 124 Void xWeightedAverage ( TComYuv* pcYuvSrc0, TComYuv* pcYuvSrc1, Int iRefIdx0, Int iRefIdx1, UInt uiPartAddr, Int iWidth, Int iHeight, TComYuv*& rpcYuvDst ); 125 123 Void xWeightedAverage ( TComYuv* pcYuvSrc0, TComYuv* pcYuvSrc1, Int iRefIdx0, Int iRefIdx1, UInt uiPartAddr, Int iWidth, Int iHeight, TComYuv*& rpcYuvDst ); 126 124 Void xGetLLSPrediction ( TComPattern* pcPattern, Int* pSrc0, Int iSrcStride, Pel* pDst0, Int iDstStride, UInt uiWidth, UInt uiHeight, UInt uiExt0 ); 127 125 #if H_3D_IC … … 175 173 176 174 #if H_3D_DBBP 177 #if HS_DBBP_CLEAN_K0048178 175 PartSize getPartitionSizeFromDepth(Pel* pDepthPels, UInt uiDepthStride, UInt uiSize, TComDataCU*& pcCU); 179 176 Bool getSegmentMaskFromDepth( Pel* pDepthPels, UInt uiDepthStride, UInt uiWidth, UInt uiHeight, Bool* pMask, TComDataCU*& pcCU); 180 #else181 PartSize getPartitionSizeFromDepth(Pel* pDepthPels, UInt uiDepthStride, UInt uiSize);182 Bool getSegmentMaskFromDepth( Pel* pDepthPels, UInt uiDepthStride, UInt uiWidth, UInt uiHeight, Bool* pMask );183 #endif184 177 Void combineSegmentsWithMask( TComYuv* pInYuv[2], TComYuv* pOutYuv, Bool* pMask, UInt uiWidth, UInt uiHeight, UInt uiPartAddr, UInt partSize ); 185 178 #endif -
trunk/source/Lib/TLibCommon/TComRdCost.cpp
r1179 r1196 341 341 else if( eDFunc >= DF_HADS && eDFunc <= DF_HADS16N ) 342 342 { 343 #if !RWTH_DBBP_NO_SATD_K0028344 rcDistParam.DistFunc = TComRdCost::xGetMaskedHADs;345 #else346 343 rcDistParam.DistFunc = TComRdCost::xGetMaskedSAD; 347 #endif348 344 } 349 345 else if( eDFunc >= DF_VSD && eDFunc <= DF_VSD16N ) … … 445 441 if( m_bUseMask ) 446 442 { 447 #if !RWTH_DBBP_NO_SATD_K0028448 rcDistParam.DistFunc = (bHADME)?TComRdCost::xGetMaskedHADs:TComRdCost::xGetMaskedSAD;449 #else450 443 rcDistParam.DistFunc = TComRdCost::xGetMaskedSAD; 451 #endif452 444 } 453 445 #endif … … 472 464 if( m_bUseMask ) 473 465 { 474 #if !RWTH_DBBP_NO_SATD_K0028475 rcDP.DistFunc = (bHadamard)?TComRdCost::xGetMaskedHADs:TComRdCost::xGetMaskedSAD;476 #else477 466 rcDP.DistFunc = TComRdCost::xGetMaskedSAD; 478 #endif479 467 } 480 468 #endif … … 729 717 } 730 718 731 #if !RWTH_DBBP_NO_SATD_K0028732 UInt TComRdCost::xGetMaskedHADs( DistParam* pcDtParam )733 {734 AOF(!pcDtParam->bApplyWeight);735 #if H_3D_IC736 AOF(!pcDtParam->bUseIC);737 #endif738 Pel* piOrg = pcDtParam->pOrg;739 Pel* piCur = pcDtParam->pCur;740 Int iRows = pcDtParam->iRows;741 Int iCols = pcDtParam->iCols;742 Int iStrideCur = pcDtParam->iStrideCur;743 Int iStrideOrg = pcDtParam->iStrideOrg;744 Int iStep = pcDtParam->iStep;745 746 Int x, y;747 748 UInt uiSum = 0;749 750 #if NS_HAD751 if( ( ( iRows % 8 == 0) && (iCols % 8 == 0) && ( iRows == iCols ) ) || ( ( iRows % 8 == 0 ) && (iCols % 8 == 0) && !pcDtParam->bUseNSHAD ) )752 #else753 if( ( iRows % 8 == 0) && (iCols % 8 == 0) )754 #endif755 {756 Int iOffsetOrg = iStrideOrg<<3;757 Int iOffsetCur = iStrideCur<<3;758 for ( y=0; y<iRows; y+= 8 )759 {760 for ( x=0; x<iCols; x+= 8 )761 {762 if( piOrg[x] != DBBP_INVALID_SHORT )763 {764 uiSum += xCalcHADs8x8( &piOrg[x], &piCur[x*iStep], iStrideOrg, iStrideCur, iStep );765 }766 }767 piOrg += iOffsetOrg;768 piCur += iOffsetCur;769 }770 }771 #if NS_HAD772 else if ( ( iCols > 8 ) && ( iCols > iRows ) && pcDtParam->bUseNSHAD )773 {774 Int iOffsetOrg = iStrideOrg<<2;775 Int iOffsetCur = iStrideCur<<2;776 for ( y=0; y<iRows; y+= 4 )777 {778 for ( x=0; x<iCols; x+= 16 )779 {780 if( piOrg[x] != DBBP_INVALID_SHORT )781 {782 uiSum += xCalcHADs16x4( &piOrg[x], &piCur[x*iStep], iStrideOrg, iStrideCur, iStep );783 }784 }785 piOrg += iOffsetOrg;786 piCur += iOffsetCur;787 }788 }789 else if ( ( iRows > 8 ) && ( iCols < iRows ) && pcDtParam->bUseNSHAD )790 {791 Int iOffsetOrg = iStrideOrg<<4;792 Int iOffsetCur = iStrideCur<<4;793 for ( y=0; y<iRows; y+= 16 )794 {795 for ( x=0; x<iCols; x+= 4 )796 {797 if( piOrg[x] != DBBP_INVALID_SHORT )798 {799 uiSum += xCalcHADs4x16( &piOrg[x], &piCur[x*iStep], iStrideOrg, iStrideCur, iStep );800 }801 }802 piOrg += iOffsetOrg;803 piCur += iOffsetCur;804 }805 }806 #endif807 else if( ( iRows % 4 == 0) && (iCols % 4 == 0) )808 {809 Int iOffsetOrg = iStrideOrg<<2;810 Int iOffsetCur = iStrideCur<<2;811 812 for ( y=0; y<iRows; y+= 4 )813 {814 for ( x=0; x<iCols; x+= 4 )815 {816 if( piOrg[x] != DBBP_INVALID_SHORT )817 {818 uiSum += xCalcHADs4x4( &piOrg[x], &piCur[x*iStep], iStrideOrg, iStrideCur, iStep );819 }820 }821 piOrg += iOffsetOrg;822 piCur += iOffsetCur;823 }824 }825 else if( ( iRows % 2 == 0) && (iCols % 2 == 0) )826 {827 Int iOffsetOrg = iStrideOrg<<1;828 Int iOffsetCur = iStrideCur<<1;829 for ( y=0; y<iRows; y+=2 )830 {831 for ( x=0; x<iCols; x+=2 )832 {833 if( piOrg[x] != DBBP_INVALID_SHORT )834 {835 uiSum += xCalcHADs2x2( &piOrg[x], &piCur[x*iStep], iStrideOrg, iStrideCur, iStep );836 }837 }838 piOrg += iOffsetOrg;839 piCur += iOffsetCur;840 }841 }842 else843 {844 assert(false);845 }846 847 return uiSum >> DISTORTION_PRECISION_ADJUSTMENT(pcDtParam->bitDepth-8);848 }849 #endif850 719 851 720 UInt TComRdCost::xGetMaskedVSD( DistParam* pcDtParam ) … … 2993 2862 UInt TComRdCost::getVSDEstimate( Int dDM, Pel* pOrg, Int iOrgStride, Pel* pVirRec, Pel* pVirOrg, Int iVirStride, Int x, Int y ) 2994 2863 { 2995 Double dD; 2996 Int iTemp; 2997 2998 dD = ( (Double) ( dDM >> DISTORTION_PRECISION_ADJUSTMENT( g_bitDepthY - 8 ) ) ) * m_dDisparityCoeff; 2864 Double dD = ( (Double) ( dDM >> DISTORTION_PRECISION_ADJUSTMENT( g_bitDepthY - 8 ) ) ) * m_dDisparityCoeff; 2999 2865 3000 2866 Double dDepthWeight = ( pOrg[x] >= ( (1<<(g_bitDepthY - 3)) + (1<<(g_bitDepthY - 2)) ) ? 4 : pOrg[x] > ((1<<g_bitDepthY) >> 4) ? (Float)(pOrg[x] - ((1<<g_bitDepthY) >> 4))/(Float)((1<<g_bitDepthY) >> 3) + 1 : 1.0 ); 3001 2867 Double dTemp = ( 0.5 * fabs(dD) * dDepthWeight * ( abs( (Int) pVirRec[ x+y*iVirStride ] - (Int) pVirRec[ x-1+y*iVirStride ] ) + abs( (Int) pVirRec[ x+y*iVirStride ] - (Int) pVirRec[ x+1+y*iVirStride ] ) ) ); 3002 iTemp = (Int) (((dTemp) < 0)? (Int)((dTemp) - 0.5) : (Int)((dTemp) + 0.5));2868 Int iTemp = (Int) (((dTemp) < 0)? (Int)((dTemp) - 0.5) : (Int)((dTemp) + 0.5)); 3003 2869 3004 2870 return (UInt) ( (iTemp*iTemp)>>1 ); -
trunk/source/Lib/TLibCommon/TComRdCost.h
r1179 r1196 320 320 static UInt xGetMaskedSSE ( DistParam* pcDtParam ); 321 321 static UInt xGetMaskedSAD ( DistParam* pcDtParam ); 322 #if !RWTH_DBBP_NO_SATD_K0028323 static UInt xGetMaskedHADs ( DistParam* pcDtParam );324 #endif325 322 static UInt xGetMaskedVSD ( DistParam* pcDtParam ); 326 323 #endif -
trunk/source/Lib/TLibCommon/TComRom.cpp
r1179 r1196 104 104 if( !g_dmmWedgeLists.empty() ) 105 105 { 106 for( UInt ui = 0; ui < g_dmmWedgeLists.size(); ui++ ) { g_dmmWedgeLists[ui].clear(); } 106 for( UInt ui = 0; ui < g_dmmWedgeLists.size(); ui++ ) 107 { 108 g_dmmWedgeLists[ui].clear(); 109 } 107 110 g_dmmWedgeLists.clear(); 108 111 } 109 112 if( !g_dmmWedgeRefLists.empty() ) 110 113 { 111 for( UInt ui = 0; ui < g_dmmWedgeRefLists.size(); ui++ ) { g_dmmWedgeRefLists[ui].clear(); } 114 for( UInt ui = 0; ui < g_dmmWedgeRefLists.size(); ui++ ) 115 { 116 g_dmmWedgeRefLists[ui].clear(); 117 } 112 118 g_dmmWedgeRefLists.clear(); 113 119 } … … 115 121 if( !g_dmmWedgeNodeLists.empty() ) 116 122 { 117 for( UInt ui = 0; ui < g_dmmWedgeNodeLists.size(); ui++ ) { g_dmmWedgeNodeLists[ui].clear(); } 123 for( UInt ui = 0; ui < g_dmmWedgeNodeLists.size(); ui++ ) 124 { 125 g_dmmWedgeNodeLists[ui].clear(); 126 } 118 127 g_dmmWedgeNodeLists.clear(); 119 128 } … … 745 754 assert( uiWidth == uiHeight ); 746 755 747 #if SHARP_DMM_CLEAN_K0042748 756 Int posStart = 0, posEnd = 0; 749 #else750 UChar uhStartX = 0, uhStartY = 0, uhEndX = 0, uhEndY = 0;751 Int iStepStartX = 0, iStepStartY = 0, iStepEndX = 0, iStepEndY = 0;752 #endif753 757 754 758 UInt uiBlockSize = 0; … … 762 766 for( UInt uiOri = 0; uiOri < 6; uiOri++ ) 763 767 { 764 #if !SHARP_DMM_CLEAN_K0042 765 // init the edge line parameters for each of the 6 wedgelet types 766 switch( uiOri ) 767 { 768 case( 0 ): { uhStartX = 0; uhStartY = 0; uhEndX = 0; uhEndY = 0; iStepStartX = +1; iStepStartY = 0; iStepEndX = 0; iStepEndY = +1; break; } 769 case( 1 ): { uhStartX = (uiBlockSize-1); uhStartY = 0; uhEndX = (uiBlockSize-1); uhEndY = 0; iStepStartX = 0; iStepStartY = +1; iStepEndX = -1; iStepEndY = 0; break; } 770 case( 2 ): { uhStartX = (uiBlockSize-1); uhStartY = (uiBlockSize-1); uhEndX = (uiBlockSize-1); uhEndY = (uiBlockSize-1); iStepStartX = -1; iStepStartY = 0; iStepEndX = 0; iStepEndY = -1; break; } 771 case( 3 ): { uhStartX = 0; uhStartY = (uiBlockSize-1); uhEndX = 0; uhEndY = (uiBlockSize-1); iStepStartX = 0; iStepStartY = -1; iStepEndX = +1; iStepEndY = 0; break; } 772 case( 4 ): { uhStartX = 0; uhStartY = 0; uhEndX = 0; uhEndY = (uiBlockSize-1); iStepStartX = +1; iStepStartY = 0; iStepEndX = +1; iStepEndY = 0; break; } 773 case( 5 ): { uhStartX = (uiBlockSize-1); uhStartY = 0; uhEndX = 0; uhEndY = 0; iStepStartX = 0; iStepStartY = +1; iStepEndX = 0; iStepEndY = +1; break; } 774 } 775 #endif 776 777 #if SHARP_DMM_CLEAN_K0042 768 778 769 posEnd = (Int) racWedgeList.size(); 779 770 if (uiOri == 0 || uiOri == 4) 780 771 { 781 #endif782 772 for( Int iK = 0; iK < uiBlockSize; iK += (uiWidth>=16 ?2:1)) 783 773 { 784 774 for( Int iL = 0; iL < uiBlockSize; iL += ((uiWidth>=16 && uiOri<4)?2:1) ) 785 775 { 786 #if SHARP_DMM_CLEAN_K0042787 776 Int xS = iK; 788 777 Int yS = 0; … … 790 779 Int yE = (uiOri == 0) ? iL : uiBlockSize - 1; 791 780 cTempWedgelet.setWedgelet( xS, yS, xE, yE, uiOri, eWedgeRes, ((iL%2)==0 && (iK%2)==0) ); 792 #else793 cTempWedgelet.setWedgelet( uhStartX + (iK*iStepStartX) , uhStartY + (iK*iStepStartY), uhEndX + (iL*iStepEndX), uhEndY + (iL*iStepEndY), (UChar)uiOri, eWedgeRes, ((iL%2)==0 && (iK%2)==0) );794 #endif795 781 addWedgeletToList( cTempWedgelet, racWedgeList, racWedgeRefList ); 796 782 } 797 783 } 798 #if SHARP_DMM_CLEAN_K0042799 784 } 800 785 else … … 807 792 } 808 793 posStart = posEnd; 809 #endif810 794 } 811 795 -
trunk/source/Lib/TLibCommon/TComRom.h
r1179 r1196 290 290 291 291 #if H_MV_ENC_DEC_TRAC 292 #define DTRACE_CU(x,y) 293 #define DTRACE_PU(x,y) 294 #define DTRACE_TU(x,y) 295 296 #define DTRACE_CU_S(x) 297 #define DTRACE_PU_S(x) 298 #define DTRACE_TU_S(x) 292 #define DTRACE_CU(x,y) ; 293 #define DTRACE_PU(x,y) ; 294 #define DTRACE_TU(x,y) ; 295 296 #define DTRACE_CU_S(x) ; 297 #define DTRACE_PU_S(x) ; 298 #define DTRACE_TU_S(x) ; 299 299 300 300 #endif -
trunk/source/Lib/TLibCommon/TComSlice.cpp
r1179 r1196 137 137 #endif 138 138 #if H_3D 139 #if HHI_INTER_COMP_PRED_K0052140 139 , m_inCmpPredFlag ( false ) 141 #endif142 #if HHI_CAM_PARA_K0052143 140 , m_numViews ( 0 ) 144 #endif145 141 , m_depthToDisparityB ( NULL ) 146 142 , m_depthToDisparityF ( NULL ) 147 #endif 148 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 143 149 144 , m_bApplyDIS (false) 150 #else151 #if H_3D_SINGLE_DEPTH152 , m_bApplySingleDepthMode (false)153 #endif154 145 #endif 155 146 #endif … … 191 182 m_iDefaultRefViewIdx = -1; 192 183 m_bDefaultRefViewIdxAvailableFlag = false; 193 #if H HI_INTER_COMP_PRED_K0052184 #if H_3D 194 185 m_ivMvPredFlag = false; 195 186 m_ivMvScalingFlag = false; … … 214 205 m_puiSubstreamSizes = NULL; 215 206 #if H_3D 216 #if HHI_CAM_PARA_K0052217 207 for( UInt i = 0; i < m_numViews; i++ ) 218 #else219 for( UInt i = 0; i < getViewIndex(); i++ )220 #endif221 208 { 222 209 if ( m_depthToDisparityB && m_depthToDisparityB[ i ] ) … … 604 591 UInt NumPocLtCurr = 0; 605 592 Int i; 606 607 #if HHI_RES_PRED_K0052 593 #if H_3D 608 594 m_pocsInCurrRPSs.clear(); 609 595 #endif 610 611 596 for(i=0; i < m_pcRPS->getNumberOfNegativePictures(); i++) 612 597 { … … 619 604 NumPocStCurr0++; 620 605 pcRefPic->setCheckLTMSBPresent(false); 621 #if H HI_RES_PRED_K0052606 #if H_3D 622 607 m_pocsInCurrRPSs.push_back( pcRefPic->getPOC() ); 623 608 #endif … … 635 620 NumPocStCurr1++; 636 621 pcRefPic->setCheckLTMSBPresent(false); 637 #if H HI_RES_PRED_K0052622 #if H_3D 638 623 m_pocsInCurrRPSs.push_back( pcRefPic->getPOC() ); 639 624 #endif … … 650 635 RefPicSetLtCurr[NumPocLtCurr] = pcRefPic; 651 636 NumPocLtCurr++; 652 #if H HI_RES_PRED_K0052637 #if H_3D 653 638 m_pocsInCurrRPSs.push_back( pcRefPic->getPOC() ); 654 639 #endif … … 662 647 663 648 Int numPocInterCurr = NumPocStCurr0 + NumPocStCurr1 + NumPocLtCurr; 664 #if H HI_RES_PRED_K0052649 #if H_3D 665 650 assert( numPocInterCurr == (Int) m_pocsInCurrRPSs.size() ); 666 651 #endif … … 837 822 Void TComSlice::setCamparaSlice( Int** aaiScale, Int** aaiOffset ) 838 823 { 839 #if HHI_CAM_PARA_K0052840 824 Int voiInVps = m_pcVPS->getVoiInVps(getViewIndex() ); 841 825 if( m_pcVPS->getNumCp( voiInVps ) > 0 ) … … 855 839 } 856 840 } 857 #else858 if( m_pcVPS->hasCamParInSliceHeader( m_viewIndex ) )859 {860 for( UInt uiBaseViewIndex = 0; uiBaseViewIndex < m_viewIndex; uiBaseViewIndex++ )861 {862 m_aaiCodedScale [ 0 ][ uiBaseViewIndex ] = aaiScale [ uiBaseViewIndex ][ m_viewIndex ];863 m_aaiCodedScale [ 1 ][ uiBaseViewIndex ] = aaiScale [ m_viewIndex ][ uiBaseViewIndex ];864 m_aaiCodedOffset[ 0 ][ uiBaseViewIndex ] = aaiOffset[ uiBaseViewIndex ][ m_viewIndex ];865 m_aaiCodedOffset[ 1 ][ uiBaseViewIndex ] = aaiOffset[ m_viewIndex ][ uiBaseViewIndex ];866 }867 }868 #endif869 841 } 870 842 #endif … … 1165 1137 } 1166 1138 #endif 1167 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331139 #if H_3D 1168 1140 m_bApplyDIS = pSrc->m_bApplyDIS; 1169 #else1170 #if H_3D_SINGLE_DEPTH1171 m_bApplySingleDepthMode = pSrc->m_bApplySingleDepthMode;1172 #endif1173 1141 #endif 1174 1142 #if H_3D_IC … … 2217 2185 { 2218 2186 m_numViews = 1; 2219 #if HHI_VIEW_ID_LIST_I5_J0107 || HHI_INTER_COMP_PRED_K00522220 2187 #if H_3D 2221 2188 AOF( m_viewOIdxList.size() == 0 ); … … 2223 2190 m_viewOIdxList.push_back( 0 ); 2224 2191 #endif 2225 #endif2226 2192 2227 2193 for( Int i = 0; i <= getMaxLayersMinus1(); i++ ) … … 2241 2207 { 2242 2208 m_numViews++; 2243 #if HHI_VIEW_ID_LIST_I5_J0107 || HHI_INTER_COMP_PRED_K00522244 2209 #if H_3D 2245 2210 m_viewOIdxList.push_back( getViewOrderIdx( lId ) ); 2246 2211 #endif 2247 #endif2248 2212 } 2249 2213 } … … 2271 2235 } 2272 2236 } 2273 #if !BUG_FIX_TK652274 assert( foundLayerIdinNuh != -1 );2275 #endif2276 2237 return foundLayerIdinNuh; 2277 2238 } … … 2281 2242 Int i = 0, j = 0; 2282 2243 2283 #if HHI_CAM_PARA_K00522284 2244 m_numCp = new Int [ iNumViews ]; 2285 2245 m_cpRefVoi = new Int*[ iNumViews ]; … … 2287 2247 2288 2248 m_cpPresentFlag = new Bool*[ iNumViews ]; 2289 #else2290 m_bCamParPresent = new Bool[ iNumViews ];2291 m_bCamParInSliceHeader = new Bool[ iNumViews ];2292 #endif2293 2249 2294 2250 … … 2297 2253 for ( i = 0; i < iNumViews ; i++ ) 2298 2254 { 2299 #if HHI_CAM_PARA_K00522300 2255 m_cpInSliceSegmentHeaderFlag[i] = false; 2301 #else2302 m_bCamParPresent[i] = false;2303 m_bCamParInSliceHeader[i] = false;2304 #endif2305 2256 2306 2257 m_aaaiCodedScale[i] = new Int*[ 2 ]; 2307 2258 m_aaaiCodedOffset[i] = new Int*[ 2 ]; 2308 2259 2309 #if HHI_CAM_PARA_K00522310 2260 m_numCp [i] = 0; 2311 2261 m_cpRefVoi[i] = new Int[ iNumViews ]; … … 2316 2266 m_cpPresentFlag[i][j] = false; 2317 2267 } 2318 #endif2319 2268 for ( j = 0; j < 2; j++ ) 2320 2269 { … … 2335 2284 Int i = 0, j = 0; 2336 2285 2337 #if !HHI_CAM_PARA_K00522338 if ( m_bCamParPresent != NULL )2339 {2340 delete [] m_bCamParPresent;2341 }2342 if ( m_bCamParInSliceHeader != NULL )2343 {2344 delete [] m_bCamParInSliceHeader;2345 }2346 #else2347 2286 if ( m_numCp != NULL ) 2348 2287 { … … 2373 2312 delete [] m_cpInSliceSegmentHeaderFlag; 2374 2313 } 2375 #endif2376 2314 2377 2315 … … 2404 2342 2405 2343 2406 #if !HHI_CAM_PARA_K00522407 Void TComVPS::initCamParaVPS( UInt uiViewIndex, Bool bCamParPresent, UInt uiCamParPrecision, Bool bCamParSlice, Int** aaiScale, Int** aaiOffset )2408 {2409 AOT( uiViewIndex != 0 && !bCamParSlice && ( aaiScale == 0 || aaiOffset == 0 ) );2410 2411 m_uiCamParPrecision = ( ( uiViewIndex != 0 )? uiCamParPrecision : 0 );2412 m_bCamParPresent[ uiViewIndex ] = (( uiViewIndex != 0 )? bCamParPresent : false );2413 m_bCamParInSliceHeader[ uiViewIndex ] = ( (uiViewIndex != 0)? bCamParSlice : false );2414 2415 if( !m_bCamParInSliceHeader[ uiViewIndex ] )2416 {2417 for( UInt uiBaseViewIndex = 0; uiBaseViewIndex < uiViewIndex; uiBaseViewIndex++ )2418 {2419 m_aaaiCodedScale [ uiViewIndex ][ 0 ][ uiBaseViewIndex ] = aaiScale [ uiBaseViewIndex ][ uiViewIndex ];2420 m_aaaiCodedScale [ uiViewIndex ][ 1 ][ uiBaseViewIndex ] = aaiScale [ uiViewIndex ][ uiBaseViewIndex ];2421 m_aaaiCodedOffset[ uiViewIndex ][ 0 ][ uiBaseViewIndex ] = aaiOffset[ uiBaseViewIndex ][ uiViewIndex ];2422 m_aaaiCodedOffset[ uiViewIndex ][ 1 ][ uiBaseViewIndex ] = aaiOffset[ uiViewIndex ][ uiBaseViewIndex ];2423 }2424 }2425 }2426 #endif2427 2344 2428 2345 #endif // H_3D … … 2804 2721 } 2805 2722 2723 #if H_3D 2724 Void TComVPS::initViewCompLayer() 2725 { 2726 assert( m_viewCompLayerId.size() == 0 && m_viewCompLayerPresentFlag.size() == 0 ); 2727 for( Int i = 0; i < getNumViews(); i++ ) 2728 { 2729 m_viewCompLayerId .push_back( std::vector<Int>(0) ); 2730 m_viewCompLayerPresentFlag.push_back( std::vector<Bool>(0) ); 2731 2732 for( Int depFlag = 0; depFlag <= 1; depFlag++ ) 2733 { 2734 Int iViewOIdx = getViewOIdxList( i ); 2735 Int layerId = -1; 2736 for( Int j = 0; j <= getMaxLayersMinus1(); j++ ) 2737 { 2738 Int jNuhLId = getLayerIdInNuh( j ); 2739 if( getVpsDepthFlag( jNuhLId ) == ( (Bool) depFlag ) && getViewOrderIdx( jNuhLId ) == iViewOIdx 2740 && getDependencyId( jNuhLId ) == 0 && getAuxId( jNuhLId ) == 0 ) 2741 { 2742 layerId = jNuhLId; 2743 } 2744 } 2745 m_viewCompLayerPresentFlag[ i ].push_back( layerId != -1 ); 2746 m_viewCompLayerId [ i ].push_back( layerId ); 2747 } 2748 } 2749 } 2750 2751 Int TComVPS::getVoiInVps(Int viewOIdx) 2752 { 2753 for ( Int i = 0; i < m_viewOIdxList.size(); i++ ) 2754 { 2755 if ( m_viewOIdxList[ i ] == viewOIdx ) 2756 { 2757 return i; 2758 } 2759 } 2760 assert( 0 ); 2761 return -1; 2762 } 2763 2764 Void TComVPS::deriveCpPresentFlag() 2765 { 2766 for( Int nInVps = 0; nInVps < getNumViews(); nInVps++ ) 2767 { 2768 for( Int mInVps = 0; mInVps < getNumViews(); mInVps++ ) 2769 { 2770 m_cpPresentFlag[nInVps][mInVps] = 0; 2771 } 2772 } 2773 2774 for( Int n = 1; n < getNumViews(); n++ ) 2775 { 2776 Int iInVps = getVoiInVps( getViewOIdxList( n ) ); 2777 for( Int m = 0; m < getNumCp( iInVps ); m++ ) 2778 { 2779 m_cpPresentFlag[ iInVps ][ getVoiInVps( getCpRefVoi( iInVps, m ) ) ] = 1; 2780 } 2781 } 2782 } 2783 #endif 2806 2784 2807 2785 #endif // H_MV … … 2858 2836 , m_interViewMvVertConstraintFlag (false) 2859 2837 #endif 2860 #if H_3D2861 #if !HHI_CAM_PARA_K00522862 , m_bCamParInSliceHeader (false)2863 #endif2864 #endif2865 2838 { 2866 2839 for ( Int i = 0; i < MAX_TLAYER; i++ ) … … 3885 3858 { 3886 3859 Int layerIdInNuh = getRefPicLayerId( i ); 3887 #if HHI_RES_PRED_K0052 3860 3888 3861 TComPic* picV = getIvPic( getIsDepth(), getVPS()->getViewIndex( layerIdInNuh ) ); 3889 3862 assert( picV != NULL ); … … 3900 3873 3901 3874 if (getFirstTRefIdx(eRefPicList) >= 0 && refRpRefAvailFlag ) 3902 #else3903 Int viewIdx = getVPS()->getViewId( layerIdInNuh );3904 TComPic*pcPicPrev = ivPicLists->getPic(viewIdx, 0, prevPOC);3905 if (getFirstTRefIdx(eRefPicList) >= 0 && pcPicPrev && pcPicPrev->getSlice( 0 )->isReferenced())3906 #endif3907 3875 { 3908 3876 m_arpRefPicAvailable[eRefPicList][layerIdInNuh] = true; … … 3917 3885 } 3918 3886 #endif 3887 3919 3888 #if H_3D_IC 3889 // This is an encoder only function and should be moved to TEncSlice or TEncSearch!! 3920 3890 Void TComSlice::xSetApplyIC(Bool bUseLowLatencyICEnc) 3921 3891 { … … 3981 3951 } 3982 3952 else 3983 { 3984 Int iMaxPelValue = ( 1 << g_bitDepthY ); 3985 Int *aiRefOrgHist; 3986 Int *aiCurrHist; 3987 aiRefOrgHist = (Int *) xMalloc( Int,iMaxPelValue ); 3988 aiCurrHist = (Int *) xMalloc( Int,iMaxPelValue ); 3989 memset( aiRefOrgHist, 0, iMaxPelValue*sizeof(Int) ); 3990 memset( aiCurrHist, 0, iMaxPelValue*sizeof(Int) ); 3991 // Reference Idx Number 3992 Int iNumRefIdx = getNumRefIdx( REF_PIC_LIST_0 ); 3993 TComPic* pcCurrPic = NULL; 3994 TComPic* pcRefPic = NULL; 3995 TComPicYuv* pcCurrPicYuv = NULL; 3996 TComPicYuv* pcRefPicYuvOrg = NULL; 3997 pcCurrPic = getPic(); 3998 pcCurrPicYuv = pcCurrPic->getPicYuvOrg(); 3999 Int iWidth = pcCurrPicYuv->getWidth(); 4000 Int iHeight = pcCurrPicYuv->getHeight(); 4001 4002 4003 // Get InterView Reference picture 4004 // !!!!! Assume only one Interview Reference Picture in L0 4005 for ( Int i = 0; i < iNumRefIdx; i++ ) 4006 { 4007 pcRefPic = getRefPic( REF_PIC_LIST_0, i ); 4008 if ( pcRefPic != NULL ) 4009 { 4010 if ( pcCurrPic->getViewIndex() != pcRefPic->getViewIndex() ) 4011 { 4012 pcRefPicYuvOrg = pcRefPic->getPicYuvOrg(); 4013 } 4014 } 4015 } 4016 4017 if ( pcRefPicYuvOrg != NULL ) 4018 { 4019 Pel* pCurrY = pcCurrPicYuv ->getLumaAddr(); 4020 Pel* pRefOrgY = pcRefPicYuvOrg ->getLumaAddr(); 4021 Int iCurrStride = pcCurrPicYuv->getStride(); 4022 Int iRefStride = pcRefPicYuvOrg->getStride(); 4023 Int iSumOrgSAD = 0; 4024 Double dThresholdOrgSAD = getIsDepth() ? 0.1 : 0.05; 4025 4026 // Histogram building - luminance 4027 for ( Int y = 0; y < iHeight; y++ ) 4028 { 4029 for ( Int x = 0; x < iWidth; x++ ) 4030 { 4031 aiCurrHist[pCurrY[x]]++; 4032 aiRefOrgHist[pRefOrgY[x]]++; 4033 } 4034 pCurrY += iCurrStride; 4035 pRefOrgY += iRefStride; 4036 } 4037 // Histogram SAD 4038 for ( Int i = 0; i < iMaxPelValue; i++ ) 4039 { 4040 iSumOrgSAD += abs( aiCurrHist[i] - aiRefOrgHist[i] ); 4041 } 4042 // Setting 4043 if ( iSumOrgSAD > Int( dThresholdOrgSAD * iWidth * iHeight ) ) 4044 { 4045 m_bApplyIC = true; 4046 } 4047 else 4048 { 4049 m_bApplyIC = false; 4050 } 4051 } 4052 4053 xFree( aiCurrHist ); 4054 xFree( aiRefOrgHist ); 4055 aiCurrHist = NULL; 4056 aiRefOrgHist = NULL; 3953 { 3954 TComPic* pcCurrPic = getPic(); 3955 TComPicYuv* pcCurrPicYuv = pcCurrPic->getPicYuvOrg(); 3956 3957 // Get InterView Reference picture 3958 // !!!!! Assume only one Interview Reference Picture in L0 3959 // GT: Is this assumption correct? 3960 3961 TComPicYuv* pcRefPicYuvOrg = NULL; 3962 for ( Int i = 0; i < getNumRefIdx( REF_PIC_LIST_0 ); i++ ) 3963 { 3964 TComPic* pcRefPic = getRefPic( REF_PIC_LIST_0, i ); 3965 if ( pcRefPic != NULL ) 3966 { 3967 if ( pcCurrPic->getViewIndex() != pcRefPic->getViewIndex() ) 3968 { 3969 pcRefPicYuvOrg = pcRefPic->getPicYuvOrg(); 3970 } 3971 } 3972 } 3973 3974 if ( pcRefPicYuvOrg != NULL ) 3975 { 3976 // Histogram building - luminance 3977 Int iMaxPelValue = ( 1 << g_bitDepthY ); 3978 Int *aiRefOrgHist = (Int *) xMalloc( Int,iMaxPelValue ); 3979 Int *aiCurrHist = (Int *) xMalloc( Int,iMaxPelValue ); 3980 memset( aiRefOrgHist, 0, iMaxPelValue*sizeof(Int) ); 3981 memset( aiCurrHist, 0, iMaxPelValue*sizeof(Int) ); 3982 3983 Int iWidth = pcCurrPicYuv->getWidth(); 3984 Int iHeight = pcCurrPicYuv->getHeight(); 3985 3986 Pel* pCurrY = pcCurrPicYuv ->getLumaAddr(); 3987 Pel* pRefOrgY = pcRefPicYuvOrg ->getLumaAddr(); 3988 Int iCurrStride = pcCurrPicYuv->getStride(); 3989 Int iRefStride = pcRefPicYuvOrg->getStride(); 3990 3991 for ( Int y = 0; y < iHeight; y++ ) 3992 { 3993 for ( Int x = 0; x < iWidth; x++ ) 3994 { 3995 aiCurrHist[pCurrY[x]]++; 3996 aiRefOrgHist[pRefOrgY[x]]++; 3997 } 3998 pCurrY += iCurrStride; 3999 pRefOrgY += iRefStride; 4000 } 4001 4002 // Histogram SAD 4003 Int iSumOrgSAD = 0; 4004 for ( Int i = 0; i < iMaxPelValue; i++ ) 4005 { 4006 iSumOrgSAD += abs( aiCurrHist[i] - aiRefOrgHist[i] ); 4007 } 4008 4009 // Setting 4010 Double dThresholdOrgSAD = getIsDepth() ? 0.1 : 0.05; 4011 4012 if ( iSumOrgSAD > Int( dThresholdOrgSAD * iWidth * iHeight ) ) 4013 { 4014 m_bApplyIC = true; 4015 } 4016 else 4017 { 4018 m_bApplyIC = false; 4019 } 4020 4021 xFree( aiCurrHist ); 4022 xFree( aiRefOrgHist ); 4023 } 4057 4024 }//if(bUseLowLatencyICEnc) 4058 4025 } … … 4087 4054 return; 4088 4055 4089 #if HHI_CAM_PARA_K00524090 4056 m_numViews = getVPS()->getNumViews(); 4091 #endif4092 4057 /// GT: Allocation should be moved to a better place later; 4093 4058 if ( m_depthToDisparityB == NULL ) 4094 4059 { 4095 #if HHI_CAM_PARA_K00524096 4060 m_depthToDisparityB = new Int*[ m_numViews ]; 4097 4061 for ( Int i = 0; i < getVPS()->getNumViews(); i++ ) 4098 #else4099 m_depthToDisparityB = new Int*[ getViewIndex() ];4100 for ( Int i = 0; i < getViewIndex(); i++ )4101 #endif4102 4062 { 4103 4063 m_depthToDisparityB[ i ] = new Int[ Int(1 << g_bitDepthY) ]; … … 4108 4068 if ( m_depthToDisparityF == NULL ) 4109 4069 { 4110 #if HHI_CAM_PARA_K00524111 4070 m_depthToDisparityF = new Int*[ m_numViews ]; 4112 4071 for ( Int i = 0; i < m_numViews; i++ ) 4113 #else4114 m_depthToDisparityF= new Int*[ getViewIndex() ];4115 for ( Int i = 0; i < getViewIndex(); i++ )4116 #endif4117 4072 { 4118 4073 m_depthToDisparityF[ i ] = new Int[ Int(1 << g_bitDepthY) ]; … … 4125 4080 TComVPS* vps = getVPS(); 4126 4081 4127 #if HHI_CAM_PARA_K00524128 4082 Int log2Div = g_bitDepthY - 1 + vps->getCpPrecision(); 4129 4083 Int voiInVps = vps->getVoiInVps( getViewIndex() ); … … 4155 4109 } 4156 4110 } 4157 #else4158 Int log2Div = g_bitDepthY - 1 + vps->getCamParPrecision();4159 4160 Int viewIndex = getViewIndex();4161 4162 Bool camParaSH = vps->hasCamParInSliceHeader( viewIndex );4163 4164 Int* codScale = camParaSH ? m_aaiCodedScale [ 0 ] : vps->getCodedScale ( viewIndex );4165 Int* codOffset = camParaSH ? m_aaiCodedOffset[ 0 ] : vps->getCodedOffset ( viewIndex );4166 Int* invCodScale = camParaSH ? m_aaiCodedScale [ 1 ] : vps->getInvCodedScale ( viewIndex );4167 Int* invCodOffset = camParaSH ? m_aaiCodedOffset[ 1 ] : vps->getInvCodedOffset( viewIndex );4168 4169 for (Int i = 0; i <= ( getViewIndex() - 1); i++)4170 {4171 for ( Int d = 0; d <= ( ( 1 << g_bitDepthY ) - 1 ); d++ )4172 {4173 Int offset = ( codOffset [ i ] << g_bitDepthY ) + ( ( 1 << log2Div ) >> 1 );4174 m_depthToDisparityB[ i ][ d ] = ( codScale [ i ] * d + offset ) >> log2Div;4175 4176 Int invOffset = ( invCodOffset[ i ] << g_bitDepthY ) + ( ( 1 << log2Div ) >> 1 );4177 m_depthToDisparityF[ i ][ d ] = ( invCodScale[ i ] * d + invOffset ) >> log2Div;4178 }4179 }4180 #endif4181 4111 } 4182 4112 #endif … … 4222 4152 Bool depthFlag = getIsDepth(); 4223 4153 4224 #if !HHI_INTER_COMP_PRED_K00524225 Bool depthOfRefViewsAvailFlag = false;4226 Bool textOfCurViewAvailFlag = false;4227 4228 TComVPS* vps = getVPS();4229 4230 if( !depthFlag )4231 {4232 depthOfRefViewsAvailFlag = true;4233 for( Int i = 0; i <= vps->getNumRefListLayers( getLayerId() ) - 1; i++)4234 {4235 Bool curDepthAvailableFlag = false;4236 for (Int j = 0; j <= vps->getMaxLayersMinus1(); j++ )4237 {4238 if ( vps->getDirectDependencyFlag( vps->getLayerIdInVps( getLayerId() ), j )4239 && vps->getVpsDepthFlag ( vps->getLayerIdInNuh( j ) ) == 14240 && vps->getViewOrderIdx( vps->getLayerIdInNuh( j ) ) == vps->getViewOrderIdx( vps->getIdRefListLayer( getLayerId(), i ) )4241 && vps->getDependencyId( vps->getLayerIdInNuh( j ) ) == 04242 && vps->getAuxId ( vps->getLayerIdInNuh( j ) ) == 04243 )4244 {4245 curDepthAvailableFlag = true;4246 }4247 }4248 if ( !curDepthAvailableFlag )4249 {4250 depthOfRefViewsAvailFlag = false;4251 }4252 }4253 }4254 else4255 {4256 for (Int j = 0; j <= vps->getMaxLayersMinus1(); j++ )4257 {4258 if ( vps->getDirectDependencyFlag( vps->getLayerIdInVps( getLayerId() ), j )4259 && vps->getVpsDepthFlag( vps->getLayerIdInNuh( j ) ) == 04260 && vps->getViewOrderIdx( vps->getLayerIdInNuh( j ) ) == getViewIndex()4261 && vps->getDependencyId( vps->getLayerIdInNuh( j ) ) == 04262 && vps->getAuxId ( vps->getLayerIdInNuh( j ) ) == 04263 )4264 {4265 textOfCurViewAvailFlag = true;4266 }4267 }4268 }4269 4270 4271 Bool lidG0 = ( getLayerId() > 0 );4272 Bool nRLLG0 = ( getVPS()->getNumRefListLayers( getLayerId() ) > 0 );4273 4274 TComSps3dExtension* sps3dExt = getSPS()->getSps3dExtension();4275 4276 m_ivMvPredFlag = sps3dExt->getIvMvPredFlag ( depthFlag ) && lidG0 && nRLLG0 ;4277 m_ivMvScalingFlag = sps3dExt->getIvMvScalingFlag ( depthFlag ) && lidG0 ;4278 m_ivResPredFlag = sps3dExt->getIvResPredFlag ( depthFlag ) && lidG0 && nRLLG0 ;4279 m_depthRefinementFlag = sps3dExt->getDepthRefinementFlag ( depthFlag ) && lidG0 && depthOfRefViewsAvailFlag;4280 m_viewSynthesisPredFlag = sps3dExt->getViewSynthesisPredFlag( depthFlag ) && lidG0 && nRLLG0 && depthOfRefViewsAvailFlag;4281 m_depthBasedBlkPartFlag = sps3dExt->getDepthBasedBlkPartFlag( depthFlag ) && lidG0 && depthOfRefViewsAvailFlag;4282 m_mpiFlag = sps3dExt->getMpiFlag ( depthFlag ) && lidG0 && textOfCurViewAvailFlag;4283 m_intraContourFlag = sps3dExt->getIntraContourFlag ( depthFlag ) && lidG0 && textOfCurViewAvailFlag;4284 m_intraSdcWedgeFlag = sps3dExt->getIntraSdcWedgeFlag ( depthFlag ) && lidG0 ;4285 m_qtPredFlag = sps3dExt->getQtPredFlag ( depthFlag ) && lidG0 && textOfCurViewAvailFlag;4286 m_interSdcFlag = sps3dExt->getInterSdcFlag ( depthFlag ) && lidG0 ;4287 #if SEC_DEPTH_INTRA_SKIP_MODE_K00334288 m_depthIntraSkipFlag = sps3dExt->getDepthIntraSkipFlag ( depthFlag ) && lidG0 ;4289 #else4290 m_intraSingleFlag = sps3dExt->getIntraSingleFlag ( depthFlag ) && lidG0 ;4291 #endif4292 4293 m_subPbSize = lidG0 ? ( 1 << ( sps3dExt->getLog2SubPbSizeMinus3 ( depthFlag ) + 3 ) ) : getSPS()->getMaxCUWidth();4294 m_mpiSubPbSize = 1 << ( sps3dExt->getLog2MpiSubPbSizeMinus3( depthFlag ) + 3 );4295 #else4296 4154 Bool nRLLG0 = ( getVPS()->getNumRefListLayers( getLayerId() ) > 0 ); 4297 4155 … … 4301 4159 m_ivMvScalingFlag = sps3dExt->getIvMvScalingFlag ( depthFlag ) ; 4302 4160 m_ivResPredFlag = sps3dExt->getIvResPredFlag ( depthFlag ) && nRLLG0 ; 4303 #if HHI_CAM_PARA_K00524304 4161 m_depthRefinementFlag = sps3dExt->getDepthRefinementFlag ( depthFlag ) && getInCompPredFlag() && m_cpAvailableFlag; 4305 4162 m_viewSynthesisPredFlag = sps3dExt->getViewSynthesisPredFlag( depthFlag ) && nRLLG0 && getInCompPredFlag() && m_cpAvailableFlag; 4306 #else4307 m_depthRefinementFlag = sps3dExt->getDepthRefinementFlag ( depthFlag ) && getInCompPredFlag();4308 m_viewSynthesisPredFlag = sps3dExt->getViewSynthesisPredFlag( depthFlag ) && nRLLG0 && getInCompPredFlag();4309 #endif4310 4163 m_depthBasedBlkPartFlag = sps3dExt->getDepthBasedBlkPartFlag( depthFlag ) && getInCompPredFlag(); 4311 4164 m_mpiFlag = sps3dExt->getMpiFlag ( depthFlag ) && getInCompPredFlag(); … … 4319 4172 m_mpiSubPbSize = 1 << ( sps3dExt->getLog2MpiSubPbSizeMinus3( depthFlag ) + 3 ); 4320 4173 4321 #endif4322 4174 4323 4175 #if H_3D_OUTPUT_ACTIVE_TOOLS … … 4325 4177 std::cout << "DepthFlag: :" << getIsDepth() << std::endl; 4326 4178 std::cout << "ViewOrderIdx: :" << getViewIndex() << std::endl; 4327 #if HHI_INTER_COMP_PRED_K00524328 4179 std::cout << "InterCmpPredAvailableFlag:" << getInCmpPredAvailFlag() << std::endl; 4329 4180 std::cout << "InterCompPredFlag :" << getInCompPredFlag() << std::endl; 4330 //std::cout << "TextOfCurViewAvailFlag :" << textOfCurViewAvailFlag << std::endl;4331 #else4332 std::cout << "DepthOfRefViewsAvailFlag:" << depthOfRefViewsAvailFlag << std::endl;4333 std::cout << "TextOfCurViewAvailFlag :" << textOfCurViewAvailFlag << std::endl;4334 #endif4335 4181 4336 4182 std::cout << "ivMvPredFlag :" << m_ivMvPredFlag << std::endl; … … 4345 4191 std::cout << "qtPredFlag :" << m_qtPredFlag << std::endl; 4346 4192 std::cout << "interSdcFlag :" << m_interSdcFlag << std::endl; 4347 #if SEC_DEPTH_INTRA_SKIP_MODE_K00334348 4193 std::cout << "depthIntraSkipFlag :" << m_depthIntraSkipFlag << std::endl; 4349 #else4350 std::cout << "intraSingleFlag :" << m_intraSingleFlag << std::endl;4351 #endif4352 4194 std::cout << "subPbSize :" << m_subPbSize << std::endl; 4353 4195 std::cout << "mpiSubPbSize :" << m_mpiSubPbSize << std::endl; 4354 4196 #endif 4355 4197 } 4198 4199 Void TComSlice::deriveInCmpPredAndCpAvailFlag() 4200 { 4201 Int numCurCmpLIds = getIsDepth() ? 1 : getNumActiveRefLayerPics(); 4202 std::vector<Int> curCmpLIds; 4203 if ( getIsDepth() ) 4204 { 4205 curCmpLIds.push_back( getLayerId() ); 4206 } 4207 else 4208 { 4209 for (Int i = 0; i < numCurCmpLIds; i++) 4210 { 4211 curCmpLIds.push_back( getRefPicLayerId( i ) ); 4212 } 4213 } 4214 4215 m_cpAvailableFlag = true; 4216 m_inCmpRefViewIdcs.clear(); 4217 Bool allRefCmpLayersAvailFlag = true; 4218 4219 for( Int i = 0; i <= numCurCmpLIds - 1; i++ ) 4220 { 4221 m_inCmpRefViewIdcs.push_back( getVPS()->getViewOrderIdx( curCmpLIds[ i ] )); 4222 if( !getVPS()->getCpPresentFlag( getVPS()->getVoiInVps( getViewIndex() ), getVPS()->getVoiInVps( m_inCmpRefViewIdcs[ i ] ) ) ) 4223 { 4224 m_cpAvailableFlag = false; 4225 } 4226 Bool refCmpCurLIdAvailFlag = false; 4227 if( getVPS()->getViewCompLayerPresentFlag( m_inCmpRefViewIdcs[ i ], !getIsDepth() ) ) 4228 { 4229 Int j = getVPS()->getLayerIdInVps( getVPS()->getViewCompLayerId( m_inCmpRefViewIdcs[ i ], !getIsDepth() ) ); 4230 if ( getVPS()->getDirectDependencyFlag( getVPS()->getLayerIdInVps( getLayerId() ) , j ) && 4231 getVPS()->getSubLayersVpsMaxMinus1( j ) >= getTemporalId() && 4232 ( getTemporalId() == 0 || getVPS()->getMaxTidIlRefPicsPlus1( j , getVPS()->getLayerIdInVps( getLayerId() ) ) > getTemporalId() ) 4233 ) 4234 { 4235 refCmpCurLIdAvailFlag = true; 4236 } 4237 } 4238 if( !refCmpCurLIdAvailFlag ) 4239 { 4240 allRefCmpLayersAvailFlag = false; 4241 } 4242 } 4243 4244 if( !allRefCmpLayersAvailFlag ) 4245 { 4246 m_inCmpPredAvailFlag = false; 4247 } 4248 else 4249 { 4250 TComSps3dExtension* sps3dExt = getSPS()->getSps3dExtension(); 4251 if( !getIsDepth() ) 4252 { 4253 m_inCmpPredAvailFlag = sps3dExt->getViewSynthesisPredFlag( getIsDepth() ) || 4254 sps3dExt->getDepthBasedBlkPartFlag( getIsDepth() ) || 4255 sps3dExt->getDepthRefinementFlag ( getIsDepth() ); 4256 } 4257 else 4258 { 4259 m_inCmpPredAvailFlag = sps3dExt->getIntraContourFlag( getIsDepth() ) || 4260 sps3dExt->getQtPredFlag( getIsDepth() ) || 4261 sps3dExt->getMpiFlag( getIsDepth() ); 4262 } 4263 } 4264 } 4265 4266 Void TComSlice::checkInCompPredRefLayers() 4267 { 4268 if ( getInCompPredFlag() ) 4269 { 4270 for (Int i = 0; i < getNumCurCmpLIds(); i++ ) 4271 { 4272 assert( getIvPic(!getIsDepth(), getInCmpRefViewIdcs( i ) ) != NULL ); 4273 // It is a requirement of bitstream conformance that there 4274 // is a picture in the DPB with PicOrderCntVal equal to the PicOrderCntVal of the current picture, 4275 // and a nuh_layer_id value equal to ViewCompLayerId[ inCmpRefViewIdcs[ i ] ][ !DepthFlag ]. 4276 } 4277 } 4278 } 4279 4356 4280 #endif 4357 4281 -
trunk/source/Lib/TLibCommon/TComSlice.h
r1179 r1196 912 912 Int xGetDimBitOffset( Int j ); 913 913 Void xSetRefLayerFlags( Int currLayerId ); 914 914 915 // VPS EXTENSION 2 SYNTAX ELEMENTS 915 916 #if H_3D 916 #if HHI_CAM_PARA_K0052917 917 Int* m_numCp; 918 918 Int** m_cpRefVoi; … … 920 920 Int m_cpPrecision; 921 921 Bool* m_cpInSliceSegmentHeaderFlag; 922 #else923 UInt m_uiCamParPrecision;924 Bool* m_bCamParInSliceHeader;925 Bool* m_bCamParPresent;926 #endif927 922 Int ***m_aaaiCodedScale ; 928 923 Int ***m_aaaiCodedOffset; 929 924 930 #if HHI_VIEW_ID_LIST_I5_J0107 || HHI_INTER_COMP_PRED_K0052931 925 std::vector<Int> m_viewOIdxList; 932 #endif933 #if HHI_INTER_COMP_PRED_K0052934 926 std::vector< std::vector<Bool> > m_viewCompLayerPresentFlag; 935 927 std::vector< std::vector<Int> > m_viewCompLayerId; 936 #endif937 928 #endif 938 929 … … 1021 1012 Void setVpsNonVuiExtensionLength( Int val ) { m_vpsNonVuiExtensionLength = val; } 1022 1013 Int getVpsNonVuiExtensionLength( ) { return m_vpsNonVuiExtensionLength; } 1023 1014 1015 // VPS Extension 1024 1016 Void setSplittingFlag( Bool val ) { m_splittingFlag = val; } 1025 1017 Bool getSplittingFlag() { return m_splittingFlag; } … … 1163 1155 Int getNumViews() { return m_numViews; } 1164 1156 Void initNumViews(); 1165 #if HHI_INTER_COMP_PRED_K00521166 1157 #if H_3D 1167 Void initViewCompLayer( ) 1168 { 1169 assert( m_viewCompLayerId.size() == 0 && m_viewCompLayerPresentFlag.size() == 0 ); 1170 for( Int i = 0; i < getNumViews(); i++ ) 1171 { 1172 m_viewCompLayerId .push_back( std::vector<Int>(0) ); 1173 m_viewCompLayerPresentFlag.push_back( std::vector<Bool>(0) ); 1174 1175 for( Int depFlag = 0; depFlag <= 1; depFlag++ ) 1176 { 1177 Int iViewOIdx = getViewOIdxList( i ); 1178 Int layerId = -1; 1179 for( Int j = 0; j <= getMaxLayersMinus1(); j++ ) 1180 { 1181 Int jNuhLId = getLayerIdInNuh( j ); 1182 if( getVpsDepthFlag( jNuhLId ) == ( (Bool) depFlag ) && getViewOrderIdx( jNuhLId ) == iViewOIdx 1183 && getDependencyId( jNuhLId ) == 0 && getAuxId( jNuhLId ) == 0 ) 1184 { 1185 layerId = jNuhLId; 1186 } 1187 } 1188 m_viewCompLayerPresentFlag[ i ].push_back( layerId != -1 ); 1189 m_viewCompLayerId [ i ].push_back( layerId ); 1190 } 1191 } 1192 }; 1193 #endif 1194 #endif 1195 1196 #if HHI_VIEW_ID_LIST_I5_J0107 || HHI_INTER_COMP_PRED_K0052 1158 Void initViewCompLayer( ); 1197 1159 Int getViewOIdxList( Int i ) { return m_viewOIdxList[i]; } 1198 #if HHI_CAM_PARA_K00521199 1160 std::vector<Int> getViewOIdxList( ) { return m_viewOIdxList; } 1200 #endif 1201 #endif 1202 1203 #if HHI_INTER_COMP_PRED_K0052 1204 #if HHI_CAM_PARA_K0052 1205 Int getVoiInVps( Int viewOIdx ) 1206 #else 1207 Int getInvViewOIdxList( Int viewOIdx ) 1208 #endif 1209 { 1210 for ( Int i = 0; i < m_viewOIdxList.size(); i++ ) 1211 { 1212 if ( m_viewOIdxList[ i ] == viewOIdx ) 1213 { 1214 return i; 1215 } 1216 } 1217 assert( 0 ); 1218 return -1; 1219 }; 1220 1221 #if HHI_CAM_PARA_K0052 1161 1162 Int getVoiInVps( Int viewOIdx );; 1163 1222 1164 Bool getViewCompLayerPresentFlag (Int i, Bool d ) { return m_viewCompLayerPresentFlag[ getVoiInVps(i) ][d]; } 1223 1165 Bool getViewCompLayerId (Int i, Bool d ) { return m_viewCompLayerId [ getVoiInVps(i) ][d]; } 1224 #else1225 Bool getViewCompLayerPresentFlag (Int i, Bool d ) { return m_viewCompLayerPresentFlag[ getInvViewOIdxList(i) ][d]; }1226 Bool getViewCompLayerId (Int i, Bool d ) { return m_viewCompLayerId [ getInvViewOIdxList(i) ][d]; }1227 #endif1228 1166 #endif 1229 1167 Bool getDependencyFlag( Int i, Int j ) { return m_dependencyFlag[i][j]; } … … 1347 1285 Void createCamPars(Int iNumViews); 1348 1286 Void deleteCamPars(); 1349 #if HHI_CAM_PARA_K00521350 1287 Void initCamParaVPS( Int vOIdxInVps, Int numCp, Bool cpInSliceSegmentHeaderFlag, Int* cpRefVoi, Int** aaiScale, Int** aaiOffset ); 1351 #else 1352 Void initCamParaVPS ( UInt uiViewIndex, Bool bCamParPresent = false, UInt uiCamParPrecision = 0, Bool bCamParSlice = false, Int** aaiScale = 0, Int** aaiOffset = 0 ); 1353 #endif 1354 1355 #if HHI_CAM_PARA_K0052 1288 1356 1289 1357 1290 Void setCpPrecision( Int val ) { m_cpPrecision = val; } … … 1380 1313 1381 1314 // Derived 1382 Void deriveCpPresentFlag( ) 1383 { 1384 for( Int nInVps = 0; nInVps < getNumViews(); nInVps++ ) 1385 { 1386 for( Int mInVps = 0; mInVps < getNumViews(); mInVps++ ) 1387 { 1388 m_cpPresentFlag[nInVps][mInVps] = 0; 1389 } 1390 } 1391 1392 for( Int n = 1; n < getNumViews(); n++ ) 1393 { 1394 Int iInVps = getVoiInVps( getViewOIdxList( n ) ); 1395 for( Int m = 0; m < getNumCp( iInVps ); m++ ) 1396 { 1397 m_cpPresentFlag[ iInVps ][ getVoiInVps( getCpRefVoi( iInVps, m ) ) ] = 1; 1398 } 1399 } 1400 } 1315 Void deriveCpPresentFlag( ); 1401 1316 1402 1317 Void setCpPresentFlag( Int i, Int m, Bool flag ) { m_cpPresentFlag[i][m] = flag; } 1403 1318 Bool getCpPresentFlag( Int i, Int m ) { return m_cpPresentFlag[i][m]; } 1404 1319 1405 #else1406 UInt getCamParPrecision () { return m_uiCamParPrecision; }1407 1408 Bool getCamParPresent ( Int viewIndex ) { return m_bCamParPresent[viewIndex]; }1409 Void setCamParPresent ( Int viewIndex, Bool val ) { m_bCamParPresent[viewIndex] = val; }1410 Bool hasCamParInSliceHeader( Int viewIndex ) { return m_bCamParInSliceHeader[viewIndex]; }1411 Void setHasCamParInSliceHeader( Int viewIndex, Bool b ) { m_bCamParInSliceHeader[viewIndex] = b; }1412 #endif1413 1320 1414 1321 … … 1705 1612 m_qtPredFlag [d] = false; 1706 1613 m_interSdcFlag [d] = false; 1707 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331708 1614 m_depthIntraSkipFlag [d] = false; 1709 #else1710 m_intraSingleFlag [d] = false;1711 #endif1712 1615 } 1713 1616 } … … 1752 1655 Bool getInterSdcFlag( Int d ) { return m_interSdcFlag[d]; } 1753 1656 1754 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331755 1657 Void setDepthIntraSkipFlag( Int d, Bool flag ) { m_depthIntraSkipFlag[d] = flag; } 1756 1658 Bool getDepthIntraSkipFlag( Int d ) { return m_depthIntraSkipFlag[d]; } 1757 #else1758 Void setIntraSingleFlag( Int d, Bool flag ) { m_intraSingleFlag[d] = flag; }1759 Bool getIntraSingleFlag( Int d ) { return m_intraSingleFlag[d]; }1760 #endif1761 1659 1762 1660 private: … … 1775 1673 Bool m_qtPredFlag [2]; 1776 1674 Bool m_interSdcFlag [2]; 1777 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331778 1675 Bool m_depthIntraSkipFlag [2]; 1779 #else1780 Bool m_intraSingleFlag [2];1781 #endif1782 1676 }; 1783 1677 … … 1884 1778 #if H_3D 1885 1779 TComSps3dExtension m_sps3dExtension; 1886 #if !HHI_CAM_PARA_K00521887 UInt m_uiCamParPrecision;1888 Bool m_bCamParInSliceHeader;1889 #endif1890 1780 Int m_aaiCodedScale [2][MAX_NUM_LAYERS]; 1891 1781 Int m_aaiCodedOffset[2][MAX_NUM_LAYERS]; … … 2517 2407 UInt m_nARPStepNum; 2518 2408 Int m_aiFirstTRefIdx [2]; 2519 #if HHI_RES_PRED_K00522520 2409 std::vector<Int> m_pocsInCurrRPSs; 2521 #endif2522 2410 #endif 2523 2411 #if H_3D_IC … … 2526 2414 #endif 2527 2415 #if H_3D 2528 #if HHI_INTER_COMP_PRED_K00522529 2416 std::vector<Int> m_inCmpRefViewIdcs; 2530 2417 Bool m_inCmpPredAvailFlag; 2531 2418 Bool m_inCmpPredFlag; 2532 #endif2533 #if HHI_CAM_PARA_K00522534 2419 Bool m_cpAvailableFlag; 2535 2420 Int m_numViews; 2536 #endif2537 2421 TComPic* m_ivPicsCurrPoc [2][MAX_NUM_LAYERS]; 2538 2422 Int** m_depthToDisparityB; … … 2540 2424 #endif 2541 2425 #endif 2542 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332543 2426 Bool m_bApplyDIS; 2544 #else2545 #if H_3D_SINGLE_DEPTH2546 Bool m_bApplySingleDepthMode;2547 #endif2548 #endif2549 2427 #if H_3D_IC 2550 Int *m_aICEnableCandidate;2551 Int *m_aICEnableNum;2428 Int* m_aICEnableCandidate; 2429 Int* m_aICEnableNum; 2552 2430 #endif 2553 2431 Int m_iDefaultRefViewIdx; … … 2565 2443 Bool m_qtPredFlag ; 2566 2444 Bool m_interSdcFlag ; 2567 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332568 2445 Bool m_depthIntraSkipFlag ; 2569 #else2570 Bool m_intraSingleFlag ;2571 #endif2572 2446 Int m_mpiSubPbSize ; 2573 2447 Int m_subPbSize ; … … 2637 2511 Int getRefPOC ( RefPicList e, Int iRefIdx) { return m_aiRefPOCList[e][iRefIdx]; } 2638 2512 #if H_3D 2639 #if HHI_INTER_COMP_PRED_K00522640 2513 Bool getInCmpPredAvailFlag( ) { return m_inCmpPredAvailFlag; } 2641 #if HHI_CAM_PARA_K00522642 2514 Bool getCpAvailableFlag( ) { return m_cpAvailableFlag; } 2643 #endif2644 2515 Bool getInCompPredFlag( ) { return m_inCmpPredFlag; } 2645 2516 Void setInCompPredFlag( Bool b ) { m_inCmpPredFlag = b; } 2646 2517 Int getInCmpRefViewIdcs( Int i ) { return m_inCmpRefViewIdcs [i]; } 2647 2518 Int getNumCurCmpLIds( ) { return (Int) m_inCmpRefViewIdcs.size(); } 2648 #endif2649 2519 TComPic* getIvPic ( Bool depthFlag, Int viewIndex){ return m_ivPicsCurrPoc[ depthFlag ? 1 : 0 ][ viewIndex ]; } 2650 2520 #endif … … 2875 2745 Void setFirstTRefIdx ( RefPicList e, Int i ) { m_aiFirstTRefIdx[e] = i; } 2876 2746 Bool getArpRefPicAvailable( RefPicList e, Int viewIdx) {return m_arpRefPicAvailable[e][getVPS()->getLayerIdInNuh(viewIdx, 0)]; } 2877 #if HHI_RES_PRED_K00522878 2747 std::vector<Int> getPocsInCurrRPSs() { return m_pocsInCurrRPSs; }; 2879 #endif2880 2748 #endif 2881 2749 Void setIsDepth ( Bool isDepth ) { m_isDepth = isDepth; } … … 2886 2754 Int* getInvCodedScale () { return m_aaiCodedScale [1]; } 2887 2755 Int* getInvCodedOffset () { return m_aaiCodedOffset[1]; } 2888 #if HHI_CAM_PARA_K00522889 2756 Void setCpScale( Int j, Int val ) { m_aaiCodedScale[0][j] = val; } 2890 2757 Int getCpScale( Int j ) { return m_aaiCodedScale[0][j]; } … … 2898 2765 Void setCpInvOff( Int j, Int val ) { m_aaiCodedOffset[1][j] = val; } 2899 2766 Int getCpInvOff( Int j ) { return m_aaiCodedOffset[1][j]; } 2900 #endif2901 2767 2902 2768 #endif … … 2906 2772 Void setDepthToDisparityLUTs(); 2907 2773 2908 #if HHI_CAM_PARA_K00522909 2774 Int* getDepthToDisparityB( Int refViewIdx ) { return m_depthToDisparityB[ getVPS()->getVoiInVps( refViewIdx) ]; }; 2910 2775 Int* getDepthToDisparityF( Int refViewIdx ) { return m_depthToDisparityF[ getVPS()->getVoiInVps( refViewIdx) ]; }; 2911 #else2912 Int* getDepthToDisparityB( Int refViewIdx ) { return m_depthToDisparityB[ refViewIdx ]; };2913 Int* getDepthToDisparityF( Int refViewIdx ) { return m_depthToDisparityF[ refViewIdx ]; };2914 #endif2915 2776 #endif 2916 2777 #if H_3D_IC … … 3015 2876 #if H_3D 3016 2877 // 3D-HEVC tool parameters 3017 #if HHI_INTER_COMP_PRED_K0052 3018 Void deriveInCmpPredAndCpAvailFlag() 3019 { 3020 Int numCurCmpLIds = getIsDepth() ? 1 : getNumActiveRefLayerPics(); 3021 std::vector<Int> curCmpLIds; 3022 if ( getIsDepth() ) 3023 { 3024 curCmpLIds.push_back( getLayerId() ); 3025 } 3026 else 3027 { 3028 for (Int i = 0; i < numCurCmpLIds; i++) 3029 { 3030 curCmpLIds.push_back( getRefPicLayerId( i ) ); 3031 } 3032 } 3033 3034 #if HHI_CAM_PARA_K0052 3035 m_cpAvailableFlag = true; 3036 m_inCmpRefViewIdcs.clear(); 3037 #endif 3038 Bool allRefCmpLayersAvailFlag = true; 3039 3040 for( Int i = 0; i <= numCurCmpLIds - 1; i++ ) 3041 { 3042 m_inCmpRefViewIdcs.push_back( getVPS()->getViewOrderIdx( curCmpLIds[ i ] )); 3043 #if HHI_CAM_PARA_K0052 3044 if( !getVPS()->getCpPresentFlag( getVPS()->getVoiInVps( getViewIndex() ), getVPS()->getVoiInVps( m_inCmpRefViewIdcs[ i ] ) ) ) 3045 { 3046 m_cpAvailableFlag = false; 3047 } 3048 #endif 3049 Bool refCmpCurLIdAvailFlag = false; 3050 if( getVPS()->getViewCompLayerPresentFlag( m_inCmpRefViewIdcs[ i ], !getIsDepth() ) ) 3051 { 3052 Int j = getVPS()->getLayerIdInVps( getVPS()->getViewCompLayerId( m_inCmpRefViewIdcs[ i ], !getIsDepth() ) ); 3053 if ( getVPS()->getDirectDependencyFlag( getVPS()->getLayerIdInVps( getLayerId() ) , j ) && 3054 getVPS()->getSubLayersVpsMaxMinus1( j ) >= getTemporalId() && 3055 ( getTemporalId() == 0 || getVPS()->getMaxTidIlRefPicsPlus1( j , getVPS()->getLayerIdInVps( getLayerId() ) ) > getTemporalId() ) 3056 ) 3057 { 3058 refCmpCurLIdAvailFlag = true; 3059 } 3060 } 3061 if( !refCmpCurLIdAvailFlag ) 3062 { 3063 allRefCmpLayersAvailFlag = false; 3064 } 3065 } 3066 3067 if( !allRefCmpLayersAvailFlag ) 3068 { 3069 m_inCmpPredAvailFlag = false; 3070 } 3071 else 3072 { 3073 TComSps3dExtension* sps3dExt = getSPS()->getSps3dExtension(); 3074 if( !getIsDepth() ) 3075 { 3076 m_inCmpPredAvailFlag = sps3dExt->getViewSynthesisPredFlag( getIsDepth() ) || 3077 sps3dExt->getDepthBasedBlkPartFlag( getIsDepth() ) || 3078 sps3dExt->getDepthRefinementFlag ( getIsDepth() ); 3079 } 3080 else 3081 { 3082 m_inCmpPredAvailFlag = sps3dExt->getIntraContourFlag( getIsDepth() ) || 3083 sps3dExt->getQtPredFlag( getIsDepth() ) || 3084 sps3dExt->getMpiFlag( getIsDepth() ); 3085 } 3086 } 3087 }; 3088 3089 #endif 3090 2878 Void deriveInCmpPredAndCpAvailFlag(); 3091 2879 Void init3dToolParameters(); 3092 #if HHI_INTER_COMP_PRED_K0052 3093 Void checkInCompPredRefLayers() 3094 { 3095 if ( getInCompPredFlag() ) 3096 { 3097 for (Int i = 0; i < getNumCurCmpLIds(); i++ ) 3098 { 3099 assert( getIvPic(!getIsDepth(), getInCmpRefViewIdcs( i ) ) != NULL ); 3100 // It is a requirement of bitstream conformance that there 3101 // is a picture in the DPB with PicOrderCntVal equal to the PicOrderCntVal of the current picture, 3102 // and a nuh_layer_id value equal to ViewCompLayerId[ inCmpRefViewIdcs[ i ] ][ !DepthFlag ]. 3103 } 3104 } 3105 }; 3106 3107 #endif 2880 Void checkInCompPredRefLayers();; 2881 3108 2882 Bool getIvMvPredFlag ( ) { return m_ivMvPredFlag ; }; 3109 2883 Bool getIvMvScalingFlag ( ) { return m_ivMvScalingFlag ; }; … … 3117 2891 Bool getQtPredFlag ( ) { return m_qtPredFlag ; }; 3118 2892 Bool getInterSdcFlag ( ) { return m_interSdcFlag ; }; 3119 #if SEC_DEPTH_INTRA_SKIP_MODE_K00333120 2893 Bool getDepthIntraSkipFlag ( ) { return m_depthIntraSkipFlag ; }; 3121 #else3122 Bool getIntraSingleFlag ( ) { return m_intraSingleFlag ; };3123 #endif3124 2894 3125 2895 Int getMpiSubPbSize ( ) { return m_mpiSubPbSize ; }; -
trunk/source/Lib/TLibCommon/TComWedgelet.cpp
r1179 r1196 177 177 } 178 178 179 #if SHARP_DMM_CLEAN_K0042180 179 Void TComWedgelet::generateWedgePatternByRotate(const TComWedgelet &rcWedge, Int rotate) 181 180 { … … 210 209 m_uiHeight = rcWedge.m_uiHeight; 211 210 } 212 #endif213 211 214 212 Void TComWedgelet::xGenerateWedgePattern() … … 228 226 xDrawEdgeLine( uhXs, uhYs, uhXe, uhYe, pbTempPattern, iTempStride ); 229 227 230 #if SHARP_DMM_CLEAN_K0042231 228 Int shift = (m_eWedgeRes == HALF_PEL) ? 1 : 0; 232 229 Int endPos = uhYe>>shift; … … 242 239 m_pbPattern[k] = pbTempPattern[k]; 243 240 }; 244 #else245 switch( m_uhOri )246 {247 case( 0 ): { for( UInt iX = 0; iX < uhXs; iX++ ) { UInt iY = 0; while( pbTempPattern[(iY * iTempStride) + iX] == false ) { pbTempPattern[(iY * iTempStride) + iX] = true; iY++; } } } break;248 case( 1 ): { for( UInt iY = 0; iY < uhYs; iY++ ) { UInt iX = uiTempBlockSize-1; while( pbTempPattern[(iY * iTempStride) + iX] == false ) { pbTempPattern[(iY * iTempStride) + iX] = true; iX--; } } } break;249 case( 2 ): { for( UInt iX = uiTempBlockSize-1; iX > uhXs; iX-- ) { UInt iY = uiTempBlockSize-1; while( pbTempPattern[(iY * iTempStride) + iX] == false ) { pbTempPattern[(iY * iTempStride) + iX] = true; iY--; } } } break;250 case( 3 ): { for( UInt iY = uiTempBlockSize-1; iY > uhYs; iY-- ) { UInt iX = 0; while( pbTempPattern[(iY * iTempStride) + iX] == false ) { pbTempPattern[(iY * iTempStride) + iX] = true; iX++; } } } break;251 case( 4 ):252 {253 if( (uhXs+uhXe) < uiTempBlockSize ) { for( UInt iY = 0; iY < uiTempBlockSize; iY++ ) { UInt iX = 0; while( pbTempPattern[(iY * iTempStride) + iX] == false ) { pbTempPattern[(iY * iTempStride) + iX] = true; iX++; } } }254 else { for( UInt iY = 0; iY < uiTempBlockSize; iY++ ) { UInt iX = uiTempBlockSize-1; while( pbTempPattern[(iY * iTempStride) + iX] == false ) { pbTempPattern[(iY * iTempStride) + iX] = true; iX--; } } }255 }256 break;257 case( 5 ):258 {259 if( (uhYs+uhYe) < uiTempBlockSize ) { for( UInt iX = 0; iX < uiTempBlockSize; iX++ ) { UInt iY = 0; while( pbTempPattern[(iY * iTempStride) + iX] == false ) { pbTempPattern[(iY * iTempStride) + iX] = true; iY++; } } }260 else { for( UInt iX = 0; iX < uiTempBlockSize; iX++ ) { UInt iY = uiTempBlockSize-1; while( pbTempPattern[(iY * iTempStride) + iX] == false ) { pbTempPattern[(iY * iTempStride) + iX] = true; iY--; } } }261 }262 }263 264 clear();265 switch( m_eWedgeRes )266 {267 case( FULL_PEL ): { for( UInt k = 0; k < (m_uiWidth * m_uiHeight); k++ ) { m_pbPattern[k] = pbTempPattern[k]; }; } break;268 case( HALF_PEL ): // sub-sampling by factor 2269 {270 Int iStride = getStride();271 272 UInt uiOffX, uiOffY;273 switch( m_uhOri )274 {275 case( 0 ): { uiOffX = 0; uiOffY = 0; } break;276 case( 1 ): { uiOffX = 1; uiOffY = 0; } break;277 case( 2 ): { uiOffX = 1; uiOffY = 1; } break;278 case( 3 ): { uiOffX = 0; uiOffY = 1; } break;279 case( 4 ):280 {281 if( (uhXs+uhXe) < uiTempBlockSize ) { uiOffX = 0; uiOffY = 0; }282 else { uiOffX = 1; uiOffY = 0; }283 }284 break;285 case( 5 ):286 {287 if( (uhYs+uhYe) < uiTempBlockSize ) { uiOffX = 0; uiOffY = 0; }288 else { uiOffX = 0; uiOffY = 1; }289 }290 break;291 default: { uiOffX = 0; uiOffY = 0; } break;292 }293 294 for(Int iY = 0; iY < m_uiHeight; iY++)295 {296 for(Int iX = 0; iX < m_uiWidth; iX++)297 {298 m_pbPattern[(iY * iStride) + iX] = pbTempPattern[(((iY<<1)+uiOffY) * iTempStride) + ((iX<<1)+uiOffX)];299 }300 }301 }302 break;303 }304 #endif305 241 306 242 if( pbTempPattern ) … … 345 281 for( Int x = x0; x <= x1; x++ ) 346 282 { 347 #if SHARP_DMM_CLEAN_K0042348 283 Int shift = (m_eWedgeRes == HALF_PEL) ? 1 : 0; 349 284 Int stride = iPatternStride >> shift; 350 285 if( steep ) { pbPattern[((x>>shift) * stride) + (y>>shift)] = true; } 351 286 else { pbPattern[((y>>shift) * stride) + (x>>shift)] = true; } 352 #else353 if( steep ) { pbPattern[(x * iPatternStride) + y] = true; }354 else { pbPattern[(y * iPatternStride) + x] = true; }355 #endif356 287 357 288 error += deltaerr; -
trunk/source/Lib/TLibCommon/TComWedgelet.h
r1179 r1196 124 124 Bool* getScaledPattern(UInt uiWidth); 125 125 126 #if SHARP_DMM_CLEAN_K0042127 126 Void generateWedgePatternByRotate(const TComWedgelet &rcWedge, Int rotate); 128 #endif129 127 Void setWedgelet( UChar uhXs, UChar uhYs, UChar uhXe, UChar uhYe, UChar uhOri, WedgeResolution eWedgeRes, Bool bIsCoarse = false ); 130 128 Void findClosestAngle(); -
trunk/source/Lib/TLibCommon/TypeDef.h
r1179 r1196 65 65 #define H_3D ( HEVC_EXT == 2) 66 66 67 #if H_MV 68 #define SONY_MV_V_CONST_C0078 1 // Control disparity vector search range via configuration file 69 #define H_MV_FIX_CONF_WINDOW 1 70 #endif 71 72 #define NTT_BUG_FIX_TK54 1 73 #define BUG_FIX_TK65 1 74 75 #define MTK_I0093 1 76 77 #define RWTH_DBBP_NO_SATD_K0028 1 67 78 68 ///////////////////////////////////////////////////////////////////////////////////////// 79 69 /////////////////////////////////// MAJOR DEFINES /////////////////////////////////// … … 85 75 86 76 #if H_3D 87 #define SEC_DEPTH_INTRA_SKIP_MODE_K0033 1 // Depth intra skip mode88 89 #if SEC_DEPTH_INTRA_SKIP_MODE_K003390 #define NEIGHBORING_PIX_AVAILABILITY_FIX 191 #endif92 93 94 77 #define H_3D_QTLPC 1 // OL_QTLIMIT_PREDCODING_B0068 //JCT3V-B0068 95 78 // HHI_QTLPC_RAU_OFF_C0160 JCT3V-C0160 change 2: quadtree limitation and predictive coding switched off in random access units … … 129 112 // SHARP_ARP_CHROMA_I0104 130 113 // MTK_I0072_IVARP_SCALING_FIX 131 #define SEC_ARP_VIEW_REF_CHECK_J0037 1 // Signaling iv_res_pred_weight_idx when the current slice has both view and temporal reference picture(s), JCT3V-J0037 item1 132 133 #define SEC_ARP_REM_ENC_RESTRICT_K0035 1 // Removal of encoder restriction of ARP, JCT3V-K0035 114 // SEC_ARP_VIEW_REF_CHECK_J0037 Signaling iv_res_pred_weight_idx when the current slice has both view and temporal reference picture(s), JCT3V-J0037 item1 115 // SEC_ARP_REM_ENC_RESTRICT_K0035 Removal of encoder restriction of ARP, JCT3V-K0035 134 116 135 117 #define H_3D_IC 1 // Illumination Compensation, JCT3V-B0045, JCT3V-C0046, JCT3V-D0060 … … 200 182 // SEC_ADAPT_DISABLE_IVMP Disabling IVMP merge candidates when IC is enabled, JCT3V-H0070 201 183 // SEC_SIMP_SHIFTED_DV_I0086 Simplification of Shifted DV candidate, JCT3V-I0086 202 203 #define SEC_SHIFTED_IVMC_POS_K0036 1 // Position Derivation for Shifted-IVMC, JCT3V-K0036 184 // SEC_SHIFTED_IVMC_POS_K0036 Position Derivation for Shifted-IVMC, JCT3V-K0036 204 185 205 186 206 187 #define H_3D_TMVP 1 // QC_TMVP_C0047 207 188 // Sony_M23639 208 #if H_3D_TMVP 209 #define H_3D_TMVP_SCALING_FIX_K0053 1 // QC/CY for K0053 210 #endif 189 // H_3D_TMVP_SCALING_FIX_K0053 1 // QC/CY for K0053 190 211 191 212 192 #define H_3D_DIM 1 // DIM, Depth intra modes, includes: … … 249 229 // MTK_DLT_CODING_FIX_H0091 250 230 // HS_DMM_SIGNALLING_I0120 251 // SHARP_DMM1_I0110 //LUT size reduction for DMM1 proposed in JCT3V-I0110231 // SHARP_DMM1_I0110 LUT size reduction for DMM1 proposed in JCT3V-I0110 252 232 // FAST_SDC_OFFSET_DECISION_I0084 253 233 // SEPARATE_FLAG_I0085 … … 256 236 // MTK_DMM_SIM_J0035 257 237 // MTK_J0033 258 // SHARP_DLT_SIMP_J0029 1 // DLT(DepthValue2Idx[]) table derivation cleanup 259 260 #if !SEC_DEPTH_INTRA_SKIP_MODE_K0033 261 #define H_3D_SINGLE_DEPTH 1 // Single depth mode proposed in JCT3V-I0095 262 // HS_SP_SIMP_J0066 263 // SINGLE_DEPTH_SIMP_J0115 1 264 // MTK_SINGLE_DEPTH_VPS_FLAG_J0060 1 // Add VPS control flags and remove slice header control flag for single depth, JCT3V-J0060 265 #endif 238 // SHARP_DLT_SIMP_J0029 DLT(DepthValue2Idx[]) table derivation cleanup 239 // SHARP_DMM_CLEAN_K0042 1 // Generate DMM pattern with rotation 240 266 241 267 242 #define H_3D_INTER_SDC 1 // INTER SDC, Inter simplified depth coding … … 269 244 // SEC_INTER_SDC_G0101 Improved inter SDC with multiple DC candidates 270 245 271 #define H_3D_SPIVMP 1 // H_3D_SPIVMP //JCT3V-F0110: Sub-PU level inter-view motion prediction246 #define H_3D_SPIVMP 1 // H_3D_SPIVMP JCT3V-F0110: Sub-PU level inter-view motion prediction 272 247 // SEC_SPIVMP_MCP_SIZE_G0077, Apply SPIVMP only to 2Nx2N partition, JCT3V-G0077 273 248 // QC_SPIVMP_MPI_G0119 Sub-PU level MPI merge candidate … … 280 255 // SEC_DBBP_FILTERING_H0104 281 256 // MTK_DBBP_SIGNALING_H0094 282 // H_3D_FIX_DBBP_IVMP 283 // SEC_DBBP_EXPLICIT_SIG_I0077 1 //Remove the partition derivation and signal dbbp_flag only when the partition mode is 2NxN/Nx2N, JCT3V-I0077257 // H_3D_FIX_DBBP_IVMP Fix . Enable IVMP is always disabled, when DBBP is enabled. The original intention is to disable Sub-PU IVMP when DBBP is enabled, not to disable IVMP itself. 258 // SEC_DBBP_EXPLICIT_SIG_I0077 Remove the partition derivation and signal dbbp_flag only when the partition mode is 2NxN/Nx2N, JCT3V-I0077 284 259 // Disallow DBBP in 8x8 CU, JCT3V-I0078 285 // SHARP_DBBP_SIMPLE_FLTER_I0109 1 // Simple condition and one dimensional filter for DBBP 286 // SEC_DBBP_DMM4_THRESHOLD_I0076 Simplification of threshold derivation for DBBP and DMM4, JCT3V-I0076 287 // SEC_DBBP_VIEW_REF_CHECK_J0037 1 // Signaling dbbp_flag when the current slice has view reference picture(s), JCT3V-J0037 item4 288 #define HS_DBBP_CLEAN_K0048 1 260 // SHARP_DBBP_SIMPLE_FLTER_I0109 Simple condition and one dimensional filter for DBBP 261 // SEC_DBBP_DMM4_THRESHOLD_I0076 Simplification of threshold derivation for DBBP and DMM4, JCT3V-I0076 262 // SEC_DBBP_VIEW_REF_CHECK_J0037 Signaling dbbp_flag when the current slice has view reference picture(s), JCT3V-J0037 item4 263 // RWTH_DBBP_NO_SATD_K0028 264 // HS_DBBP_CLEAN_K0048 289 265 290 266 #define H_3D_DDD 1 // Disparity derived depth coding 291 267 // LGE_DDD_REMOVAL_J0042_J0030 DDD removal 292 268 269 #define H_3D_DIS 1 // Depth intra skip 270 // SEC_DEPTH_INTRA_SKIP_MODE_K0033 Depth intra skip mode 271 293 272 #define H_3D_FCO 0 // Flexible coding order for 3D 294 #if H_3D_FCO295 #define H_3D_FCO 1296 #endif297 273 298 274 #define H_3D_FAST_INTRA_SDC 1 // I0123 … … 300 276 // OTHERS 301 277 // MTK_SONY_PROGRESSIVE_MV_COMPRESSION_E0170 // Progressive MV Compression, JCT3V-E0170 302 #define H_3D_REN_MAX_DEV_OUT 0 // Output maximal possible shift deviation 278 303 279 #define H_3D_FAST_TEXTURE_ENCODING 1 // Fast merge mode decision and early CU determination for texture component of dependent view, JCT3V-E0173 304 280 // MTK_FAST_TEXTURE_ENCODING_E0173 305 281 #if H_3D_DIM 306 #define H_3D_FAST_DEPTH_INTRA 1 // Fast DMM and RBC ModeSelection282 #define H_3D_FAST_DEPTH_INTRA 1 // Fast DMM Selection 307 283 // SCU_HS_FAST_DEPTH_INTRA_E0238_HHIFIX 308 284 #endif 309 285 310 286 //HLS 311 //HHI_DEPENDENCY_SIGNALLING_I1_J0107 312 //HHI_TOOL_PARAMETERS_I2_J0107 313 //HHI_VPS_3D_EXTENSION_I3_J0107 287 // HHI_DEPENDENCY_SIGNALLING_I1_J0107 288 // HHI_TOOL_PARAMETERS_I2_J0107 289 // HHI_VPS_3D_EXTENSION_I3_J0107 290 // HHI_INTER_COMP_PRED_K0052 291 // HHI_RES_PRED_K0052 292 // HHI_CAM_PARA_K0052 293 // H_3D_DIRECT_DEP_TYPE 314 294 315 295 // Rate Control … … 319 299 #endif // H_3D 320 300 321 322 323 301 ///////////////////////////////////////////////////////////////////////////////////////// 324 302 /////////////////////////////////// DERIVED DEFINES /////////////////////////////////// 325 303 ///////////////////////////////////////////////////////////////////////////////////////// 326 304 327 // Fixes328 329 #define FIX_TICKET_95 1 // pps_scaling_list_ref_layer_id parsing330 331 305 #if H_3D 332 306 #define H_3D_DISABLE_CHROMA 1 333 #define HHI_VIEW_ID_LIST_I5_J0107 0334 #define HHI_INTER_COMP_PRED_K0052 1335 #define HHI_RES_PRED_K0052 1336 #define HHI_CAM_PARA_K0052 1337 #define HHI_MOVE_SYN_K0052 1338 #define H_3D_ANNEX_SELECTION_FIX 1339 #define H_3D_TMVP_FIX_TICKET_97 1340 #define H_3D_DIRECT_DEP_TYPE 1341 #define H_3D_FIX_TMVP_SCALING_VIEW_ID 1342 #endif343 #define H_MV_FIX_REF_LAYER_PIC_FLAG 1344 #define H_MV_FIX_NUM_VIEWS 1345 307 #define H_3D_OUTPUT_ACTIVE_TOOLS 0 346 347 #if !SEC_DEPTH_INTRA_SKIP_MODE_K0033 348 ///// ***** SINGLE DEPTH MODE ********* 349 #if H_3D_SINGLE_DEPTH 350 #define SINGLE_DEPTH_MODE_CAND_LIST_SIZE 2 // size of the sample candidate list 351 352 #endif 308 #define H_3D_REN_MAX_DEV_OUT 0 353 309 #endif 354 310 … … 384 340 // HHI_DEPTH_INTRA_SEARCH_RAU_C0160 385 341 // LG_ZEROINTRADEPTHRESI_A0087 386 #define SHARP_DMM_CLEAN_K0042 1 // Generate DMM pattern with rotation387 388 #define TICKET083_IVPFLAG_FIX 1389 #define SHARP_SUBBLOCK_CLEAN_K0044 1 // Remove unused bipred restriction390 342 391 343 #endif … … 434 386 // TBD: Check if integration is necessary. 435 387 436 #define H_MV_HLS_FIX 1 388 437 389 #define H_MV_HLS_PTL_LIMITS 0 438 390 #define H_MV_HLS7_GEN 0 // General changes (not tested) 439 #define H_MV_ALIGN_HM_15 1440 391 441 392 // POC -
trunk/source/Lib/TLibDecoder/TDecCAVLC.cpp
r1179 r1196 39 39 #include "SEIread.h" 40 40 #include "TDecSlice.h" 41 #if H_3D _ANNEX_SELECTION_FIX41 #if H_3D 42 42 #include "TDecTop.h" 43 43 #endif … … 93 93 TDecCavlc::TDecCavlc() 94 94 { 95 #if !HHI_CAM_PARA_K005296 #if H_3D97 m_aaiTempScale = new Int* [ MAX_NUM_LAYERS ];98 m_aaiTempOffset = new Int* [ MAX_NUM_LAYERS ];99 for( UInt uiVId = 0; uiVId < MAX_NUM_LAYERS; uiVId++ )100 {101 m_aaiTempScale [ uiVId ] = new Int [ MAX_NUM_LAYERS ];102 m_aaiTempOffset [ uiVId ] = new Int [ MAX_NUM_LAYERS ];103 }104 #endif105 #endif106 95 } 107 96 108 97 TDecCavlc::~TDecCavlc() 109 98 { 110 #if !HHI_CAM_PARA_K0052111 #if H_3D112 for( UInt uiVId = 0; uiVId < MAX_NUM_LAYERS; uiVId++ )113 {114 delete [] m_aaiTempScale [ uiVId ];115 delete [] m_aaiTempOffset [ uiVId ];116 }117 delete [] m_aaiTempScale;118 delete [] m_aaiTempOffset;119 #endif120 #endif121 99 } 122 100 … … 1048 1026 READ_FLAG( uiCode, "qt_pred_flag" ); sps3dExt->setQtPredFlag( d, uiCode == 1 ); 1049 1027 READ_FLAG( uiCode, "inter_sdc_flag" ); sps3dExt->setInterSdcFlag( d, uiCode == 1 ); 1050 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331051 1028 READ_FLAG( uiCode, "intra_skip_flag" ); sps3dExt->setDepthIntraSkipFlag( d, uiCode == 1 ); 1052 #else1053 READ_FLAG( uiCode, "intra_single_flag" ); sps3dExt->setIntraSingleFlag( d, uiCode == 1 );1054 #endif1055 1029 } 1056 1030 } … … 1063 1037 READ_FLAG( uiCode, "poc_reset_info_present_flag" ); pcPPS->setPocResetInfoPresentFlag( uiCode == 1 ); 1064 1038 READ_FLAG( uiCode, "pps_infer_scaling_list_flag" ); pcPPS->setPpsInferScalingListFlag( uiCode == 1 ); 1065 #if FIX_TICKET_951066 1039 if (pcPPS->getPpsInferScalingListFlag()) 1067 1040 { 1068 1041 READ_CODE( 6, uiCode, "pps_scaling_list_ref_layer_id" ); pcPPS->setPpsScalingListRefLayerId( uiCode ); 1069 1042 } 1070 #else1071 READ_CODE( 6, uiCode, "pps_scaling_list_ref_layer_id" ); pcPPS->setPpsScalingListRefLayerId( uiCode );1072 #endif1073 1043 1074 1044 UInt numRefLocOffsets;; … … 1336 1306 } 1337 1307 1338 #if HHI_INTER_COMP_PRED_K00521339 1308 #if H_3D 1340 1309 pcVPS->initViewCompLayer( ); 1341 #endif1342 1310 #endif 1343 1311 … … 1929 1897 Void TDecCavlc::parseVPS3dExtension( TComVPS* pcVPS ) 1930 1898 { 1931 #if HHI_CAM_PARA_K00521932 1899 UInt uiCode; 1933 1900 READ_UVLC( uiCode, "cp_precision"); pcVPS->setCpPrecision( uiCode ) ; … … 1959 1926 } 1960 1927 pcVPS->deriveCpPresentFlag(); 1961 #else1962 UInt uiCode;1963 1964 UInt uiCamParPrecision = 0;1965 Bool bCamParSlice = false;1966 Bool bCamParPresentFlag = false;1967 1968 READ_UVLC( uiCamParPrecision, "cp_precision" );1969 #if HHI_VIEW_ID_LIST_I5_J01071970 for (Int n = 1; n < pcVPS->getNumViews(); n++)1971 {1972 Int viewIndex = pcVPS->getViewOIdxList( n );1973 #else1974 for (UInt viewIndex=1; viewIndex<pcVPS->getNumViews(); viewIndex++)1975 {1976 #endif1977 pcVPS->setCamParPresent ( viewIndex, false );1978 pcVPS->setHasCamParInSliceHeader( viewIndex, false );1979 READ_FLAG( uiCode, "cp_present_flag[i]" ); bCamParPresentFlag = ( uiCode == 1);1980 if ( bCamParPresentFlag )1981 {1982 READ_FLAG( uiCode, "cp_in_slice_segment_header_flag[i]" ); bCamParSlice = ( uiCode == 1);1983 if ( !bCamParSlice )1984 {1985 #if HHI_VIEW_ID_LIST_I5_J01071986 for( UInt m = 0; m < n; n++ )1987 {1988 Int uiBaseIndex = pcVPS->getViewOIdxList ( m );1989 Int iCode;1990 READ_SVLC( iCode, "vps_cp_scale" ); m_aaiTempScale [ uiBaseIndex ][ viewIndex ] = iCode;1991 READ_SVLC( iCode, "vps_cp_off" ); m_aaiTempOffset [ uiBaseIndex ][ viewIndex ] = iCode;1992 READ_SVLC( iCode, "vps_cp_inv_scale_plus_scale" ); m_aaiTempScale [ viewIndex ][ uiBaseIndex ] = iCode - m_aaiTempScale [ uiBaseIndex ][ viewIndex ];1993 READ_SVLC( iCode, "vps_cp_inv_off_plus_off" ); m_aaiTempOffset [ viewIndex ][ uiBaseIndex ] = iCode - m_aaiTempOffset[ uiBaseIndex ][ viewIndex ];1994 }1995 }1996 pcVPS->initCamParaVPS( viewIndex, bCamParPresentFlag, uiCamParPrecision, bCamParSlice, m_aaiTempScale, m_aaiTempOffset );1997 #else1998 for( UInt uiBaseIndex = 0; uiBaseIndex < viewIndex; uiBaseIndex++ )1999 {2000 Int iCode;2001 READ_SVLC( iCode, "vps_cp_scale" ); m_aaiTempScale [ uiBaseIndex ][ viewIndex ] = iCode;2002 READ_SVLC( iCode, "vps_cp_off" ); m_aaiTempOffset [ uiBaseIndex ][ viewIndex ] = iCode;2003 READ_SVLC( iCode, "vps_cp_inv_scale_plus_scale" ); m_aaiTempScale [ viewIndex ][ uiBaseIndex ] = iCode - m_aaiTempScale [ uiBaseIndex ][ viewIndex ];2004 READ_SVLC( iCode, "vps_cp_inv_off_plus_off" ); m_aaiTempOffset [ viewIndex ][ uiBaseIndex ] = iCode - m_aaiTempOffset[ uiBaseIndex ][ viewIndex ];2005 }2006 }2007 pcVPS->initCamParaVPS( viewIndex, bCamParPresentFlag, uiCamParPrecision, bCamParSlice, m_aaiTempScale, m_aaiTempOffset );2008 #endif2009 }2010 }2011 #endif2012 1928 } 2013 1929 #endif … … 2070 1986 #endif 2071 1987 rpcSlice->setSPS(sps); 2072 #if !HHI_INTER_COMP_PRED_K00522073 #if H_3D2074 rpcSlice->init3dToolParameters();2075 #endif2076 #endif2077 1988 rpcSlice->setPPS(pps); 2078 1989 if( pps->getDependentSliceSegmentsEnabledFlag() && ( !firstSliceSegmentInPic )) … … 2468 2379 } 2469 2380 } 2470 #if HHI_INTER_COMP_PRED_K00522471 2381 #if H_3D 2472 2382 if ( getDecTop()->decProcAnnexI() ) … … 2481 2391 #endif 2482 2392 #endif 2483 #endif2484 2393 if(sps->getUseSAO()) 2485 2394 { … … 2488 2397 if( rpcSlice->getSPS()->getChromaFormatIdc() != 0 ) 2489 2398 { 2490 READ_FLAG(uiCode, "slice_sao_chroma_flag"); rpcSlice->setSaoEnabledFlagChroma((Bool)uiCode);2491 }2399 READ_FLAG(uiCode, "slice_sao_chroma_flag"); rpcSlice->setSaoEnabledFlagChroma((Bool)uiCode); 2400 } 2492 2401 else 2493 2402 { 2494 2403 rpcSlice->setSaoEnabledFlagChroma( false ); 2495 2404 } 2496 2497 2405 #else 2498 2406 READ_FLAG(uiCode, "slice_sao_chroma_flag"); rpcSlice->setSaoEnabledFlagChroma((Bool)uiCode); … … 2662 2570 } 2663 2571 #if H_3D_IC 2664 #if H_3D_ANNEX_SELECTION_FIX2665 2572 else if( rpcSlice->getViewIndex() && ( rpcSlice->getSliceType() == P_SLICE || rpcSlice->getSliceType() == B_SLICE ) 2666 2573 && !rpcSlice->getIsDepth() && vps->getNumRefListLayers( layerId ) > 0 2667 2574 && getDecTop()->decProcAnnexI() 2668 2575 ) 2669 #else2670 else if( rpcSlice->getViewIndex() && ( rpcSlice->getSliceType() == P_SLICE || rpcSlice->getSliceType() == B_SLICE ) && !rpcSlice->getIsDepth() && vps->getNumRefListLayers( layerId ) > 0 )2671 #endif2672 2576 { 2673 2577 UInt uiCodeTmp = 0; … … 2766 2670 rpcSlice->setLFCrossSliceBoundaryFlag( (uiCode==1)?true:false); 2767 2671 2768 #if HHI_CAM_PARA_K00522769 2672 #if H_3D 2770 2673 if ( getDecTop()->decProcAnnexI() ) … … 2784 2687 } 2785 2688 #endif 2786 #endif2787 2689 } 2788 2690 … … 2808 2710 } 2809 2711 2810 #if !HHI_CAM_PARA_K00522811 #if H_3D2812 #if H_3D_FCO2813 if( rpcSlice->getVPS()->hasCamParInSliceHeader( rpcSlice->getViewIndex() ) && rpcSlice->getIsDepth() )2814 #else2815 if( rpcSlice->getVPS()->hasCamParInSliceHeader( rpcSlice->getViewIndex() ) && !rpcSlice->getIsDepth() )2816 #endif2817 {2818 UInt uiViewIndex = rpcSlice->getViewIndex();2819 for( UInt uiBaseIndex = 0; uiBaseIndex < uiViewIndex; uiBaseIndex++ )2820 {2821 READ_SVLC( iCode, "cp_scale" ); m_aaiTempScale [ uiBaseIndex ][ uiViewIndex ] = iCode;2822 READ_SVLC( iCode, "cp_off" ); m_aaiTempOffset[ uiBaseIndex ][ uiViewIndex ] = iCode;2823 READ_SVLC( iCode, "cp_inv_scale_plus_scale" ); m_aaiTempScale [ uiViewIndex ][ uiBaseIndex ] = iCode - m_aaiTempScale [ uiBaseIndex ][ uiViewIndex ];2824 READ_SVLC( iCode, "cp_inv_off_plus_off" ); m_aaiTempOffset[ uiViewIndex ][ uiBaseIndex ] = iCode - m_aaiTempOffset[ uiBaseIndex ][ uiViewIndex ];2825 }2826 rpcSlice->setCamparaSlice( m_aaiTempScale, m_aaiTempOffset );2827 }2828 #endif2829 #endif2830 2712 2831 2713 if(pps->getSliceHeaderExtensionPresentFlag()) … … 3100 2982 assert(0); 3101 2983 } 3102 3103 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 2984 #if H_3D 3104 2985 Void TDecCavlc::parseDIS( TComDataCU* /*pcCU*/, UInt /*uiAbsPartIdx*/, UInt /*uiDepth*/ ) 3105 2986 { 3106 2987 assert(0); 3107 2988 } 3108 #else3109 #if H_3D_SINGLE_DEPTH3110 Void TDecCavlc::parseSingleDepthMode( TComDataCU* /*pcCU*/, UInt /*uiAbsPartIdx*/, UInt /*uiDepth*/ )3111 {3112 assert(0);3113 }3114 #endif3115 2989 #endif 3116 2990 -
trunk/source/Lib/TLibDecoder/TDecCAVLC.h
r1179 r1196 52 52 // Class definition 53 53 // ==================================================================================================================== 54 #if H_3D _ANNEX_SELECTION_FIX54 #if H_3D 55 55 class TDecTop; 56 56 #endif 57 58 57 /// CAVLC decoder class 59 58 class TDecCavlc : public SyntaxElementParser, public TDecEntropyIf … … 66 65 void parseShortTermRefPicSet (TComSPS* pcSPS, TComReferencePictureSet* pcRPS, Int idx); 67 66 68 69 #if !HHI_CAM_PARA_K005270 67 #if H_3D 71 Int** m_aaiTempScale;72 Int** m_aaiTempOffset;73 #endif74 #endif75 #if H_3D_ANNEX_SELECTION_FIX76 68 TDecTop* m_decTop; 77 69 #endif … … 118 110 Void parsePPS ( TComPPS* pcPPS); 119 111 #endif 120 #if H_3D _ANNEX_SELECTION_FIX112 #if H_3D 121 113 Void setDecTop ( TDecTop* decTop ) { m_decTop = decTop; }; 122 114 #endif … … 136 128 137 129 Void parseSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 138 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033130 #if H_3D 139 131 Void parseDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 140 #else141 #if H_3D_SINGLE_DEPTH142 Void parseSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );143 #endif144 132 #endif 145 133 Void parseCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); … … 182 170 Void parseScalingList ( TComScalingList* scalingList ); 183 171 Void xDecodeScalingList ( TComScalingList *scalingList, UInt sizeId, UInt listId); 184 185 #if H_3D_ANNEX_SELECTION_FIX 172 #if H_3D 186 173 TDecTop* getDecTop() { return m_decTop; }; 187 174 #endif -
trunk/source/Lib/TLibDecoder/TDecCu.cpp
r1179 r1196 310 310 #if H_3D_NBDV 311 311 DisInfo DvInfo; 312 #if !SEC_ARP_REM_ENC_RESTRICT_K0035313 DvInfo.bDV = false;314 #endif315 312 DvInfo.m_acNBDV.setZero(); 316 313 DvInfo.m_aVIdxCan = 0; … … 347 344 if( pcCU->getSlice()->getIsDepth()) 348 345 { 349 #if SEC_ARP_REM_ENC_RESTRICT_K0035350 346 m_ppcCU[uiDepth]->getDispforDepth(0, 0, &DvInfo); 351 #else352 DvInfo.bDV = m_ppcCU[uiDepth]->getDispforDepth(0, 0, &DvInfo);353 #endif354 347 } 355 348 else … … 359 352 if( pcCU->getSlice()->getDepthBasedBlkPartFlag() ) //Notes from QC: please check the condition for DoNBDV. Remove this comment once it is done. 360 353 { 361 #if SEC_ARP_REM_ENC_RESTRICT_K0035362 354 m_ppcCU[uiDepth]->getDisMvpCandNBDV(&DvInfo, true); 363 #else364 DvInfo.bDV = m_ppcCU[uiDepth]->getDisMvpCandNBDV(&DvInfo, true);365 #endif366 355 } 367 356 else 368 357 #endif 369 358 { 370 #if SEC_ARP_REM_ENC_RESTRICT_K0035371 359 m_ppcCU[uiDepth]->getDisMvpCandNBDV(&DvInfo); 372 #else373 DvInfo.bDV = m_ppcCU[uiDepth]->getDisMvpCandNBDV(&DvInfo);374 #endif375 360 } 376 361 #if H_3D_IV_MERGE … … 545 530 return; 546 531 } 547 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033532 #if H_3D 548 533 m_pcEntropyDecoder->decodeDIS( pcCU, uiAbsPartIdx, uiDepth ); 549 534 if(!pcCU->getDISFlag(uiAbsPartIdx)) 550 535 { 551 #else552 #if H_3D_SINGLE_DEPTH553 m_pcEntropyDecoder->decodeSingleDepthMode( pcCU, uiAbsPartIdx, uiDepth );554 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx))555 {556 #endif557 536 #endif 558 537 m_pcEntropyDecoder->decodePredMode( pcCU, uiAbsPartIdx, uiDepth ); 559 538 m_pcEntropyDecoder->decodePartSize( pcCU, uiAbsPartIdx, uiDepth ); 560 539 561 #if !HHI_MOVE_SYN_K0052562 #if H_3D_DIM_SDC563 m_pcEntropyDecoder->decodeSDCFlag( pcCU, uiAbsPartIdx, uiDepth );564 #endif565 #endif566 540 if (pcCU->isIntra( uiAbsPartIdx ) && pcCU->getPartitionSize( uiAbsPartIdx ) == SIZE_2Nx2N ) 567 541 { … … 570 544 if(pcCU->getIPCMFlag(uiAbsPartIdx)) 571 545 { 572 #if HHI_MOVE_SYN_K0052573 546 #if H_3D_DIM_SDC 574 547 m_pcEntropyDecoder->decodeSDCFlag( pcCU, uiAbsPartIdx, uiDepth ); 575 #endif576 548 #endif 577 549 xFinishDecodeCU( pcCU, uiAbsPartIdx, uiDepth, ruiIsLast ); … … 593 565 m_pcEntropyDecoder->decodeCoeff( pcCU, uiAbsPartIdx, uiDepth, uiCurrWidth, uiCurrHeight, bCodeDQP ); 594 566 setdQPFlag( bCodeDQP ); 595 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 596 } 597 #else 598 #if H_3D_SINGLE_DEPTH 599 } 600 #endif 567 #if H_3D 568 } 601 569 #endif 602 570 xFinishDecodeCU( pcCU, uiAbsPartIdx, uiDepth, ruiIsLast ); … … 625 593 UInt uiTPelY = pcCU->getCUPelY() + g_auiRasterToPelY[ g_auiZscanToRaster[uiAbsPartIdx] ]; 626 594 UInt uiBPelY = uiTPelY + (g_uiMaxCUHeight>>uiDepth) - 1; 627 595 628 596 UInt uiCurNumParts = pcPic->getNumPartInCU() >> (uiDepth<<1); 629 597 TComSlice * pcSlice = pcCU->getPic()->getSlice(pcCU->getPic()->getCurrSliceIdx()); … … 633 601 bBoundary = true; 634 602 } 635 603 636 604 if( ( ( uiDepth < pcCU->getDepth( uiAbsPartIdx ) ) && ( uiDepth < g_uiMaxCUDepth - g_uiAddCUDepth ) ) || bBoundary ) 637 605 { … … 643 611 uiLPelX = pcCU->getCUPelX() + g_auiRasterToPelX[ g_auiZscanToRaster[uiIdx] ]; 644 612 uiTPelY = pcCU->getCUPelY() + g_auiRasterToPelY[ g_auiZscanToRaster[uiIdx] ]; 645 613 646 614 Bool binSlice = (pcCU->getSCUAddr()+uiIdx+uiQNumParts>pcSlice->getSliceSegmentCurStartCUAddr())&&(pcCU->getSCUAddr()+uiIdx<pcSlice->getSliceSegmentCurEndCUAddr()); 647 615 if(binSlice&&( uiLPelX < pcSlice->getSPS()->getPicWidthInLumaSamples() ) && ( uiTPelY < pcSlice->getSPS()->getPicHeightInLumaSamples() ) ) … … 649 617 xDecompressCU(pcCU, uiIdx, uiNextDepth ); 650 618 } 651 619 652 620 uiIdx += uiQNumParts; 653 621 } … … 657 625 // Residual reconstruction 658 626 m_ppcYuvResi[uiDepth]->clear(); 659 627 660 628 m_ppcCU[uiDepth]->copySubCU( pcCU, uiAbsPartIdx, uiDepth ); 661 629 662 630 switch( m_ppcCU[uiDepth]->getPredictionMode(0) ) 663 631 { 664 632 case MODE_INTER: 665 633 #if H_3D_DBBP 666 667 668 669 670 671 634 if( m_ppcCU[uiDepth]->getDBBPFlag(0) ) 635 { 636 xReconInterDBBP( m_ppcCU[uiDepth], uiAbsPartIdx, uiDepth ); 637 } 638 else 639 { 672 640 #endif 673 641 #if H_3D_INTER_SDC … … 679 647 { 680 648 #endif 681 xReconInter( m_ppcCU[uiDepth], uiDepth );649 xReconInter( m_ppcCU[uiDepth], uiDepth ); 682 650 #if H_3D_INTER_SDC 683 651 } 684 652 #endif 685 653 #if H_3D_DBBP 686 687 #endif 688 689 690 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033691 692 693 694 654 } 655 #endif 656 break; 657 case MODE_INTRA: 658 #if H_3D 659 if( m_ppcCU[uiDepth]->getDISFlag(0) ) 660 { 661 xReconDIS( m_ppcCU[uiDepth], 0, uiDepth ); 662 } 695 663 #if H_3D_DIM_SDC 696 else if( m_ppcCU[uiDepth]->getSDCFlag(0) ) 697 { 698 xReconIntraSDC( m_ppcCU[uiDepth], 0, uiDepth ); 699 } 700 #endif 701 else 702 #else 703 #if H_3D_SINGLE_DEPTH 704 if( m_ppcCU[uiDepth]->getSingleDepthFlag(0) ) 705 xReconIntraSingleDepth( m_ppcCU[uiDepth], 0, uiDepth ); 706 #if H_3D_DIM_SDC 707 else if( m_ppcCU[uiDepth]->getSDCFlag(0) ) 708 xReconIntraSDC( m_ppcCU[uiDepth], 0, uiDepth ); 709 #endif 710 else 711 #else 712 #if H_3D_DIM_SDC 713 if( m_ppcCU[uiDepth]->getSDCFlag(0) ) 714 xReconIntraSDC( m_ppcCU[uiDepth], 0, uiDepth ); 715 else 716 #endif 717 #endif 664 else if( m_ppcCU[uiDepth]->getSDCFlag(0) ) 665 { 666 xReconIntraSDC( m_ppcCU[uiDepth], 0, uiDepth ); 667 } 668 #endif 669 else 718 670 #endif 719 671 xReconIntraQT( m_ppcCU[uiDepth], uiDepth ); 720 721 722 723 672 break; 673 default: 674 assert(0); 675 break; 724 676 } 725 677 if ( m_ppcCU[uiDepth]->isLosslessCoded(0) && (m_ppcCU[uiDepth]->getIPCMFlag(0) == false)) … … 727 679 xFillPCMBuffer(m_ppcCU[uiDepth], uiDepth); 728 680 } 729 681 730 682 xCopyToPic( m_ppcCU[uiDepth], pcPic, uiAbsPartIdx, uiDepth ); 731 683 } … … 751 703 } 752 704 753 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033705 #if H_3D 754 706 Void TDecCu::xReconDIS( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 755 707 { … … 828 780 } 829 781 } 830 #else 831 #if H_3D_SINGLE_DEPTH 832 Void TDecCu::xReconIntraSingleDepth( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 833 { 834 UInt uiWidth = pcCU->getWidth ( 0 ); 835 UInt uiHeight = pcCU->getHeight ( 0 ); 836 837 TComYuv* pcRecoYuv = m_ppcYuvReco[uiDepth]; 838 839 UInt uiStride = pcRecoYuv->getStride (); 840 Pel* piReco = pcRecoYuv->getLumaAddr( uiAbsPartIdx ); 841 842 843 AOF( uiWidth == uiHeight ); 844 AOF( uiAbsPartIdx == 0 ); 845 846 //construction of depth candidates 847 Pel testDepth; 848 Pel DepthNeighbours[2]; 849 Int index =0; 850 for( Int i = 0; (i < 2) && (index<SINGLE_DEPTH_MODE_CAND_LIST_SIZE) ; i++ ) 851 { 852 if(!pcCU->getNeighDepth (0, uiAbsPartIdx, &testDepth, i)) 853 { 854 continue; 855 } 856 DepthNeighbours[index]=testDepth; 857 index++; 858 } 859 860 if(index==0) 861 { 862 DepthNeighbours[index]=1<<(g_bitDepthY-1); 863 index++; 864 } 865 866 if(index==1) 867 { 868 DepthNeighbours[index]=ClipY(DepthNeighbours[0] + 1 ); 869 index++; 870 } 871 872 for( UInt uiY = 0; uiY < uiHeight; uiY++ ) 873 { 874 for( UInt uiX = 0; uiX < uiWidth; uiX++ ) 875 { 876 piReco[ uiX ] =DepthNeighbours[(Int)pcCU->getSingleDepthValue(uiAbsPartIdx)]; 877 } 878 piReco += uiStride; 879 } 880 881 // clear UV 882 UInt uiStrideC = pcRecoYuv->getCStride(); 883 Pel *pRecCb = pcRecoYuv->getCbAddr(); 884 Pel *pRecCr = pcRecoYuv->getCrAddr(); 885 886 for (Int y=0; y<uiHeight/2; y++) 887 { 888 for (Int x=0; x<uiWidth/2; x++) 889 { 890 pRecCb[x] = 1<<(g_bitDepthC-1); 891 pRecCr[x] = 1<<(g_bitDepthC-1); 892 } 893 894 pRecCb += uiStrideC; 895 pRecCr += uiStrideC; 896 } 897 } 898 #endif 899 #endif 900 782 #endif 901 783 #if H_3D_INTER_SDC 902 784 Void TDecCu::xReconInterSDC( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) … … 962 844 // compute mask by segmenting depth block 963 845 Bool pMask[MAX_CU_SIZE*MAX_CU_SIZE]; 964 #if HS_DBBP_CLEAN_K0048965 846 Bool bValidMask = m_pcPrediction->getSegmentMaskFromDepth(pDepthPels, uiDepthStride, pcCU->getWidth(0), pcCU->getHeight(0), pMask, pcCU); 966 #else967 Bool bValidMask = m_pcPrediction->getSegmentMaskFromDepth(pDepthPels, uiDepthStride, pcCU->getWidth(0), pcCU->getHeight(0), pMask);968 #endif969 847 AOF(bValidMask); 970 848 971 D BBPTmpData* pDBBPTmpData = pcCU->getDBBPTmpData();849 DbbpTmpData* pDBBPTmpData = pcCU->getDBBPTmpData(); 972 850 TComYuv* apSegPredYuv[2] = { m_ppcYuvReco[uiDepth], m_ppcYuvRecoDBBP[uiDepth] }; 973 851 -
trunk/source/Lib/TLibDecoder/TDecCu.h
r1179 r1196 123 123 Void setdQPFlag ( Bool b ) { m_bDecodeDQP = b; } 124 124 Void xFillPCMBuffer (TComDataCU* pCU, UInt depth); 125 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033125 #if H_3D 126 126 Void xReconDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 127 #else128 #if H_3D_SINGLE_DEPTH129 Void xReconIntraSingleDepth( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );130 #endif131 127 #endif 132 128 #if H_3D_DIM_SDC -
trunk/source/Lib/TLibDecoder/TDecEntropy.cpp
r1179 r1196 52 52 m_pcEntropyDecoderIf->parseSkipFlag( pcCU, uiAbsPartIdx, uiDepth ); 53 53 } 54 55 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 54 #if H_3D 56 55 Void TDecEntropy::decodeDIS( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 57 56 { … … 63 62 m_pcEntropyDecoderIf->parseDIS( pcCU, uiAbsPartIdx, uiDepth ); 64 63 } 65 #else66 #if H_3D_SINGLE_DEPTH67 Void TDecEntropy::decodeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth )68 {69 if( !pcCU->getSlice()->getIntraSingleFlag() )70 {71 return;72 }73 74 m_pcEntropyDecoderIf->parseSingleDepthMode( pcCU, uiAbsPartIdx, uiDepth );75 }76 #endif77 64 #endif 78 65 … … 161 148 { 162 149 m_pcEntropyDecoderIf->parsePartSize( pcCU, uiAbsPartIdx, uiDepth ); 163 #if !HHI_MOVE_SYN_K0052164 #if H_3D_DBBP165 if( pcCU->getSlice()->getDepthBasedBlkPartFlag() && (pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_2NxN || pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_Nx2N) && pcCU->getWidth(uiAbsPartIdx) > 8 && pcCU->getSlice()->getDefaultRefViewIdxAvailableFlag() )166 {167 decodeDBBPFlag(pcCU, uiAbsPartIdx, uiDepth);168 }169 #endif170 #endif171 150 } 172 151 … … 176 155 { 177 156 decodeIntraDirModeLuma ( pcCU, uiAbsPartIdx, uiDepth ); 178 #if H HI_MOVE_SYN_K0052157 #if H_3D_DIM_SDC 179 158 decodeSDCFlag ( pcCU, uiAbsPartIdx, uiDepth ); 180 #endif181 #if H_3D_DIM_SDC182 159 #if H_3D_DISABLE_CHROMA 183 #if !HHI_MOVE_SYN_K0052184 if(!pcCU->getSDCFlag(uiAbsPartIdx) && !pcCU->getSlice()->getIsDepth() )185 #else186 160 if(!pcCU->getSDCFlag(uiAbsPartIdx) && pcCU->getSlice()->getSPS()->getChromaFormatIdc() != 0 ) 187 #endif188 161 #else 189 162 if(!pcCU->getSDCFlag(uiAbsPartIdx)) … … 247 220 #endif 248 221 #if H_3D_SPIVMP 249 Bool bSPIVMPFlag[MRG_MAX_NUM_CANDS_MEM]; 250 TComMvField* pcMvFieldSP; 251 UChar* puhInterDirSP; 252 pcMvFieldSP = new TComMvField[pcCU->getPic()->getPicSym()->getNumPartition()*2]; 253 puhInterDirSP = new UChar[pcCU->getPic()->getPicSym()->getNumPartition()]; 222 Bool bSPIVMPFlag[MRG_MAX_NUM_CANDS_MEM]; 223 TComMvField* pcMvFieldSP = new TComMvField[pcCU->getPic()->getPicSym()->getNumPartition()*2]; 224 UChar* puhInterDirSP = new UChar[pcCU->getPic()->getPicSym()->getNumPartition()]; 254 225 #endif 255 226 for ( UInt ui = 0; ui < pcCU->getSlice()->getMaxNumMergeCand(); ui++ ) … … 265 236 pcSubCU->copyDVInfoFrom( pcCU, uiAbsPartIdx); 266 237 #endif 267 #if H HI_MOVE_SYN_K0052238 #if H_3D 268 239 for ( UInt uiPartIdx = 0, uiSubPartIdx = uiAbsPartIdx; uiPartIdx < uiNumPU; uiPartIdx++, uiSubPartIdx += uiPUOffset ) 269 240 { … … 475 446 decodeMergeIndex( pcCU, uiPartIdx, uiSubPartIdx, uiDepth ); 476 447 UInt uiMergeIndex = pcCU->getMergeIndex(uiSubPartIdx); 477 #if H_3D_ARP478 decodeARPW ( pcCU, uiAbsPartIdx, uiDepth );479 #endif480 #if H_3D_IC481 decodeICFlag( pcCU, uiAbsPartIdx, uiDepth );482 #endif483 #if H_3D_DBBP484 if ( pcCU->getSlice()->getPPS()->getLog2ParallelMergeLevelMinus2() && ePartSize != SIZE_2Nx2N && pcSubCU->getWidth( 0 ) <= 8 && pcCU->getDBBPFlag(uiAbsPartIdx) == false )485 #else486 448 if ( pcCU->getSlice()->getPPS()->getLog2ParallelMergeLevelMinus2() && ePartSize != SIZE_2Nx2N && pcSubCU->getWidth( 0 ) <= 8 ) 487 #endif488 449 { 489 450 pcSubCU->setPartSizeSubParts( SIZE_2Nx2N, 0, uiDepth ); 490 451 if ( !isMerged ) 491 452 { 492 #if H_3D_VSP493 Int vspFlag[MRG_MAX_NUM_CANDS_MEM];494 memset(vspFlag, 0, sizeof(Int)*MRG_MAX_NUM_CANDS_MEM);495 #if H_3D_SPIVMP496 memset(bSPIVMPFlag, false, sizeof(Bool)*MRG_MAX_NUM_CANDS_MEM);497 #endif498 pcSubCU->initAvailableFlags();499 pcSubCU->getInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand);500 pcSubCU->xGetInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours501 #if H_3D_SPIVMP502 , pcMvFieldSP, puhInterDirSP503 #endif504 , numValidMergeCand );505 pcSubCU->buildMCL( cMvFieldNeighbours, uhInterDirNeighbours, vspFlag506 #if H_3D_SPIVMP507 , bSPIVMPFlag508 #endif509 , numValidMergeCand );510 pcCU->setVSPFlagSubParts( vspFlag[uiMergeIndex], uiSubPartIdx, uiPartIdx, uiDepth );511 512 #else513 #if H_3D514 pcSubCU->initAvailableFlags();515 pcSubCU->getInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand);516 pcSubCU->xGetInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand );517 518 #else519 453 pcSubCU->getInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand ); 520 #endif521 #endif522 454 isMerged = true; 523 455 } … … 527 459 { 528 460 uiMergeIndex = pcCU->getMergeIndex(uiSubPartIdx); 529 #if H_3D_VSP530 Int vspFlag[MRG_MAX_NUM_CANDS_MEM];531 memset(vspFlag, 0, sizeof(Int)*MRG_MAX_NUM_CANDS_MEM);532 #if H_3D_SPIVMP533 memset(bSPIVMPFlag, false, sizeof(Bool)*MRG_MAX_NUM_CANDS_MEM);534 #endif535 pcSubCU->initAvailableFlags();536 461 pcSubCU->getInterMergeCandidates( uiSubPartIdx-uiAbsPartIdx, uiPartIdx, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand, uiMergeIndex ); 537 pcSubCU->xGetInterMergeCandidates( uiSubPartIdx-uiAbsPartIdx, uiPartIdx, cMvFieldNeighbours, uhInterDirNeighbours538 #if H_3D_SPIVMP539 , pcMvFieldSP, puhInterDirSP540 #endif541 ,numValidMergeCand, uiMergeIndex );542 pcSubCU->buildMCL( cMvFieldNeighbours, uhInterDirNeighbours, vspFlag543 #if H_3D_SPIVMP544 , bSPIVMPFlag545 #endif546 ,numValidMergeCand );547 pcCU->setVSPFlagSubParts( vspFlag[uiMergeIndex], uiSubPartIdx, uiPartIdx, uiDepth );548 #else549 #if H_3D550 pcSubCU->initAvailableFlags();551 pcSubCU->getInterMergeCandidates( uiSubPartIdx-uiAbsPartIdx, uiPartIdx, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand, uiMergeIndex );552 pcSubCU->xGetInterMergeCandidates( uiSubPartIdx-uiAbsPartIdx, uiPartIdx, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand, uiMergeIndex );553 #else554 pcSubCU->getInterMergeCandidates( uiSubPartIdx-uiAbsPartIdx, uiPartIdx, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand, uiMergeIndex );555 #endif556 #endif557 462 } 558 463 pcCU->setInterDirSubParts( uhInterDirNeighbours[uiMergeIndex], uiSubPartIdx, uiPartIdx, uiDepth ); … … 567 472 pcCU->getCUMvField( RefPicList( uiRefListIdx ) )->setAllMvd( cTmpMv, ePartSize, uiSubPartIdx, uiDepth, uiPartIdx ); 568 473 pcCU->getCUMvField( RefPicList( uiRefListIdx ) )->setAllMvField( cMvFieldNeighbours[ 2*uiMergeIndex + uiRefListIdx ], ePartSize, uiSubPartIdx, uiDepth, uiPartIdx ); 569 #if H_3D_VSP 570 #if H_3D_DBBP 571 if( pcCU->getVSPFlag( uiSubPartIdx ) != 0 && !pcCU->getDBBPFlag( uiAbsPartIdx ) ) 572 #else 573 if( pcCU->getVSPFlag( uiSubPartIdx ) != 0 ) 574 #endif 575 { 576 if ( uhInterDirNeighbours[ uiMergeIndex ] & (1<<uiRefListIdx) ) 577 { 578 UInt dummy; 579 Int vspSize; 580 Int width, height; 581 pcCU->getPartIndexAndSize( uiPartIdx, dummy, width, height, uiSubPartIdx, pcCU->getTotalNumPart()==256 ); 582 pcCU->setMvFieldPUForVSP( pcCU, uiSubPartIdx, width, height, RefPicList( uiRefListIdx ), cMvFieldNeighbours[ 2*uiMergeIndex + uiRefListIdx ].getRefIdx(), vspSize ); 583 pcCU->setVSPFlag( uiSubPartIdx, vspSize ); 584 } 585 } 586 #endif 587 } 588 } 589 #if H_3D_SPIVMP 590 pcCU->setSPIVMPFlagSubParts(bSPIVMPFlag[uiMergeIndex], uiSubPartIdx, uiPartIdx, uiDepth ); 591 if (bSPIVMPFlag[uiMergeIndex] != 0) 592 { 593 Int iWidth, iHeight; 594 UInt uiIdx; 595 pcCU->getPartIndexAndSize( uiPartIdx, uiIdx, iWidth, iHeight, uiSubPartIdx, true ); 596 597 UInt uiSPAddr; 598 599 Int iNumSPInOneLine, iNumSP, iSPWidth, iSPHeight; 600 601 pcCU->getSPPara(iWidth, iHeight, iNumSP, iNumSPInOneLine, iSPWidth, iSPHeight); 602 603 for (Int iPartitionIdx = 0; iPartitionIdx < iNumSP; iPartitionIdx++) 604 { 605 pcCU->getSPAbsPartIdx(uiSubPartIdx, iSPWidth, iSPHeight, iPartitionIdx, iNumSPInOneLine, uiSPAddr); 606 pcCU->setInterDirSP(puhInterDirSP[iPartitionIdx], uiSPAddr, iSPWidth, iSPHeight); 607 pcCU->getCUMvField( REF_PIC_LIST_0 )->setMvFieldSP(pcCU, uiSPAddr, pcMvFieldSP[2*iPartitionIdx], iSPWidth, iSPHeight); 608 pcCU->getCUMvField( REF_PIC_LIST_1 )->setMvFieldSP(pcCU, uiSPAddr, pcMvFieldSP[2*iPartitionIdx + 1], iSPWidth, iSPHeight); 609 } 610 } 611 #endif 474 } 475 } 612 476 } 613 477 else … … 623 487 } 624 488 } 625 #if H_3D_ARP626 decodeARPW ( pcCU, uiAbsPartIdx, uiDepth );627 #endif628 #if H_3D_IC629 decodeICFlag( pcCU, uiAbsPartIdx, uiDepth );630 #endif631 489 } 632 490 if ( (pcCU->getInterDir(uiSubPartIdx) == 3) && pcSubCU->isBipredRestriction(uiPartIdx) ) … … 706 564 } 707 565 708 #if H HI_MOVE_SYN_K0052566 #if H_3D 709 567 Void TDecEntropy::decodeMVPIdxPU( TComDataCU* pcSubCU, UInt uiPartAddr, UInt uiDepth, UInt uiPartIdx, RefPicList eRefList ) 710 568 { … … 753 611 pcSubCU->getCUMvField( eRefList )->setAllMv(cMv, ePartSize, uiPartAddr, 0, uiPartIdx); 754 612 } 755 756 613 #else 757 614 Void TDecEntropy::decodeMVPIdxPU( TComDataCU* pcSubCU, UInt uiPartAddr, UInt uiDepth, UInt uiPartIdx, RefPicList eRefList ) … … 798 655 } 799 656 #endif 657 800 658 Void TDecEntropy::xDecodeTransform( TComDataCU* pcCU, UInt offsetLuma, UInt offsetChroma, UInt uiAbsPartIdx, UInt uiDepth, UInt width, UInt height, UInt uiTrIdx, Bool& bCodeDQP, Int quadtreeTULog2MinSizeInCU) 801 659 { … … 869 727 if (pcCU->getSlice()->getSPS()->getChromaFormatIdc() != 0 ) 870 728 { 871 if( bFirstCbfOfCU || pcCU->getCbf( uiAbsPartIdx, TEXT_CHROMA_U, uiTrDepth - 1 ) )872 {873 m_pcEntropyDecoderIf->parseQtCbf( pcCU, uiAbsPartIdx, TEXT_CHROMA_U, uiTrDepth, uiDepth );874 }875 if( bFirstCbfOfCU || pcCU->getCbf( uiAbsPartIdx, TEXT_CHROMA_V, uiTrDepth - 1 ) )876 {877 m_pcEntropyDecoderIf->parseQtCbf( pcCU, uiAbsPartIdx, TEXT_CHROMA_V, uiTrDepth, uiDepth );878 }879 }880 else881 {729 if( bFirstCbfOfCU || pcCU->getCbf( uiAbsPartIdx, TEXT_CHROMA_U, uiTrDepth - 1 ) ) 730 { 731 m_pcEntropyDecoderIf->parseQtCbf( pcCU, uiAbsPartIdx, TEXT_CHROMA_U, uiTrDepth, uiDepth ); 732 } 733 if( bFirstCbfOfCU || pcCU->getCbf( uiAbsPartIdx, TEXT_CHROMA_V, uiTrDepth - 1 ) ) 734 { 735 m_pcEntropyDecoderIf->parseQtCbf( pcCU, uiAbsPartIdx, TEXT_CHROMA_V, uiTrDepth, uiDepth ); 736 } 737 } 738 else 739 { 882 740 if( bFirstCbfOfCU || pcCU->getCbf( uiAbsPartIdx, TEXT_CHROMA_U, uiTrDepth - 1 ) ) 883 741 { … … 1131 989 { 1132 990 pcCU->setSDCFlagSubParts( false, uiAbsPartIdx, uiDepth ); 1133 #if HHI_MOVE_SYN_K00521134 991 if ( pcCU->isSkipped( uiAbsPartIdx ) ) 1135 992 { 1136 993 return; 1137 994 } 1138 #endif1139 995 1140 996 … … 1157 1013 Void TDecEntropy::decodeDBBPFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 1158 1014 { 1159 #if HHI_MOVE_SYN_K00521160 1015 if( pcCU->getSlice()->getDepthBasedBlkPartFlag() && (pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_2NxN || pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_Nx2N) && pcCU->getWidth(uiAbsPartIdx) > 8 && pcCU->getSlice()->getDefaultRefViewIdxAvailableFlag() ) 1161 1016 { 1162 #endif1163 1017 m_pcEntropyDecoderIf->parseDBBPFlag( pcCU, uiAbsPartIdx, uiDepth ); 1164 #if HHI_MOVE_SYN_K0052 1165 } 1166 #endif 1018 } 1167 1019 } 1168 1020 #endif -
trunk/source/Lib/TLibDecoder/TDecEntropy.h
r1179 r1196 85 85 public: 86 86 virtual Void parseSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0; 87 #if SEC_DEPTH_INTRA_SKIP_MODE_K003387 #if H_3D 88 88 virtual Void parseDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0; 89 #else90 #if H_3D_SINGLE_DEPTH91 virtual Void parseSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0;92 #endif93 89 #endif 94 90 virtual Void parseCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0; … … 152 148 Void decodeMvdPU ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth, UInt uiPartIdx, RefPicList eRefList ); 153 149 Void decodeMVPIdxPU ( TComDataCU* pcSubCU, UInt uiPartAddr, UInt uiDepth, UInt uiPartIdx, RefPicList eRefList ); 154 #if HHI_MOVE_SYN_K0052 155 Void decodeMvsAMVP ( TComDataCU* pcSubCU, UInt uiPartAddr, UInt uiDepth, UInt uiPartIdx, RefPicList eRefList ); 156 #endif 150 #if H_3D 151 Void decodeMvsAMVP ( TComDataCU* pcSubCU, UInt uiPartAddr, UInt uiDepth, UInt uiPartIdx, 152 RefPicList eRefList ); 153 #endif 157 154 Void setEntropyDecoder ( TDecEntropyIf* p ); 158 155 Void setBitstream ( TComInputBitstream* p ) { m_pcEntropyDecoderIf->setBitstream(p); } … … 177 174 Void decodeSplitFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 178 175 Void decodeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 179 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033176 #if H_3D 180 177 Void decodeDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) ; 181 #else182 #if H_3D_SINGLE_DEPTH183 Void decodeSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) ;184 #endif185 178 #endif 186 179 Void decodeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); -
trunk/source/Lib/TLibDecoder/TDecGop.h
r1179 r1196 63 63 // Class definition 64 64 // ==================================================================================================================== 65 #if H_3D _ANNEX_SELECTION_FIX65 #if H_3D 66 66 class TDecTop; 67 67 #endif … … 83 83 TDecSlice* m_pcSliceDecoder; 84 84 TComLoopFilter* m_pcLoopFilter; 85 #if H_3D _ANNEX_SELECTION_FIX85 #if H_3D 86 86 TDecTop* m_decTop; 87 87 #endif -
trunk/source/Lib/TLibDecoder/TDecSbac.cpp
r1179 r1196 52 52 , m_cCUSplitFlagSCModel ( 1, 1, NUM_SPLIT_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels ) 53 53 , m_cCUSkipFlagSCModel ( 1, 1, NUM_SKIP_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels) 54 #if SEC_DEPTH_INTRA_SKIP_MODE_K003354 #if H_3D 55 55 , m_cCUDISFlagSCModel ( 1, 1, NUM_DIS_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels) 56 56 , m_cCUDISTypeSCModel ( 1, 1, NUM_DIS_TYPE_CTX , m_contextModels + m_numContextModels, m_numContextModels) 57 #else58 #if H_3D_SINGLE_DEPTH59 , m_cCUSingleDepthFlagSCModel ( 1, 1, NUM_SINGLEDEPTH_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels)60 , m_cSingleDepthValueSCModel ( 1, 1, NUM_SINGLE_DEPTH_VALUE_DATA_CTX , m_contextModels + m_numContextModels, m_numContextModels)61 #endif62 57 #endif 63 58 , m_cCUMergeFlagExtSCModel ( 1, 1, NUM_MERGE_FLAG_EXT_CTX , m_contextModels + m_numContextModels, m_numContextModels) … … 141 136 m_cCUSplitFlagSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_SPLIT_FLAG ); 142 137 m_cCUSkipFlagSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_SKIP_FLAG ); 143 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033138 #if H_3D 144 139 m_cCUDISFlagSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_DIS_FLAG ); 145 140 m_cCUDISTypeSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_DIS_TYPE ); 146 #else147 #if H_3D_SINGLE_DEPTH148 m_cCUSingleDepthFlagSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_SINGLEDEPTH_FLAG );149 m_cSingleDepthValueSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA );150 #endif151 141 #endif 152 142 m_cCUMergeFlagExtSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_MERGE_FLAG_EXT ); … … 217 207 m_cCUSplitFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SPLIT_FLAG ); 218 208 m_cCUSkipFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SKIP_FLAG ); 219 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033209 #if H_3D 220 210 m_cCUDISFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_DIS_FLAG ); 221 211 m_cCUDISTypeSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_DIS_TYPE ); 222 #else223 #if H_3D_SINGLE_DEPTH224 m_cCUSingleDepthFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLEDEPTH_FLAG );225 m_cSingleDepthValueSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA );226 #endif227 212 #endif 228 213 m_cCUMergeFlagExtSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_MERGE_FLAG_EXT ); … … 461 446 UInt uiSymbol; 462 447 463 448 m_pcTDecBinIf->decodeBinTrm(uiSymbol); 464 449 465 450 #if H_MV_ENC_DEC_TRAC 466 467 #endif 468 469 451 DTRACE_CU("pcm_flag", uiSymbol) 452 #endif 453 if (uiSymbol) 454 { 470 455 Bool bIpcmFlag = true; 471 456 … … 500 485 piPCMSample += uiWidth; 501 486 } 502 503 504 487 #if H_3D_DISABLE_CHROMA 505 488 if( pcCU->getSlice()->getSPS()->getChromaFormatIdc() != 0 ) 506 489 { 507 490 #endif 508 piPCMSample = pcCU->getPCMSampleCb() + uiChromaOffset;509 uiWidth = pcCU->getWidth(uiAbsPartIdx)/2;510 uiHeight = pcCU->getHeight(uiAbsPartIdx)/2;511 uiSampleBits = pcCU->getSlice()->getSPS()->getPCMBitDepthChroma();512 513 for(uiY = 0; uiY < uiHeight; uiY++)514 {515 for(uiX = 0; uiX < uiWidth; uiX++)516 {517 UInt uiSample;518 m_pcTDecBinIf->xReadPCMCode(uiSampleBits, uiSample);519 piPCMSample[uiX] = uiSample;520 }521 piPCMSample += uiWidth;522 }523 524 piPCMSample = pcCU->getPCMSampleCr() + uiChromaOffset;525 uiWidth = pcCU->getWidth(uiAbsPartIdx)/2;526 uiHeight = pcCU->getHeight(uiAbsPartIdx)/2;527 uiSampleBits = pcCU->getSlice()->getSPS()->getPCMBitDepthChroma();528 529 for(uiY = 0; uiY < uiHeight; uiY++)530 {531 for(uiX = 0; uiX < uiWidth; uiX++)532 {533 UInt uiSample;534 m_pcTDecBinIf->xReadPCMCode(uiSampleBits, uiSample);535 piPCMSample[uiX] = uiSample;536 }537 piPCMSample += uiWidth;538 }491 piPCMSample = pcCU->getPCMSampleCb() + uiChromaOffset; 492 uiWidth = pcCU->getWidth(uiAbsPartIdx)/2; 493 uiHeight = pcCU->getHeight(uiAbsPartIdx)/2; 494 uiSampleBits = pcCU->getSlice()->getSPS()->getPCMBitDepthChroma(); 495 496 for(uiY = 0; uiY < uiHeight; uiY++) 497 { 498 for(uiX = 0; uiX < uiWidth; uiX++) 499 { 500 UInt uiSample; 501 m_pcTDecBinIf->xReadPCMCode(uiSampleBits, uiSample); 502 piPCMSample[uiX] = uiSample; 503 } 504 piPCMSample += uiWidth; 505 } 506 507 piPCMSample = pcCU->getPCMSampleCr() + uiChromaOffset; 508 uiWidth = pcCU->getWidth(uiAbsPartIdx)/2; 509 uiHeight = pcCU->getHeight(uiAbsPartIdx)/2; 510 uiSampleBits = pcCU->getSlice()->getSPS()->getPCMBitDepthChroma(); 511 512 for(uiY = 0; uiY < uiHeight; uiY++) 513 { 514 for(uiX = 0; uiX < uiWidth; uiX++) 515 { 516 UInt uiSample; 517 m_pcTDecBinIf->xReadPCMCode(uiSampleBits, uiSample); 518 piPCMSample[uiX] = uiSample; 519 } 520 piPCMSample += uiWidth; 521 } 539 522 #if H_3D_DISABLE_CHROMA 540 523 } 541 524 #endif 542 543 544 525 m_pcTDecBinIf->start(); 545 526 } … … 594 575 #endif 595 576 } 596 597 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 577 #if H_3D 598 578 Void TDecSbac::parseDIS( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 599 579 { … … 639 619 } 640 620 } 641 #else 642 #if H_3D_SINGLE_DEPTH 643 Void TDecSbac::parseSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 644 { 645 pcCU->setSingleDepthFlagSubParts( false, uiAbsPartIdx, uiDepth ); 646 UInt uiSymbol = 0; 647 m_pcTDecBinIf->decodeBin( uiSymbol, m_cCUSingleDepthFlagSCModel.get( 0, 0, 0 ) ); 648 if( uiSymbol ) 649 { 650 pcCU->setSingleDepthFlagSubParts( true, uiAbsPartIdx, uiDepth ); 651 pcCU->setSkipFlagSubParts( false, uiAbsPartIdx, uiDepth ); 652 pcCU->setSDCFlagSubParts( false, uiAbsPartIdx, uiDepth ); 653 pcCU->setPredModeSubParts( MODE_INTRA, uiAbsPartIdx, uiDepth ); 654 pcCU->setPartSizeSubParts( SIZE_2Nx2N, uiAbsPartIdx, uiDepth ); 655 pcCU->setLumaIntraDirSubParts (DC_IDX, uiAbsPartIdx, uiDepth ); 656 pcCU->setSizeSubParts( g_uiMaxCUWidth>>uiDepth, g_uiMaxCUHeight>>uiDepth, uiAbsPartIdx, uiDepth ); 657 pcCU->setMergeFlagSubParts( false , uiAbsPartIdx, 0, uiDepth ); 658 pcCU->setTrIdxSubParts(0, uiAbsPartIdx, uiDepth); 659 pcCU->setCbfSubParts(0, 1, 1, uiAbsPartIdx, uiDepth); 660 661 UInt absValDeltaDC = 0; 662 663 UInt uiUnaryIdx = 0; 664 UInt uiNumCand = SINGLE_DEPTH_MODE_CAND_LIST_SIZE; 665 if ( uiNumCand > 1 ) 666 { 667 for( ; uiUnaryIdx < uiNumCand - 1; ++uiUnaryIdx ) 668 { 669 UInt uiSymbol2 = 0; 670 if ( uiUnaryIdx==0 ) 671 { 672 m_pcTDecBinIf->decodeBin( uiSymbol2, m_cSingleDepthValueSCModel.get( 0, 0, 0 ) ); 673 } 674 else 675 { 676 m_pcTDecBinIf->decodeBinEP( uiSymbol2); 677 } 678 if( uiSymbol2 == 0 ) 679 { 680 break; 681 } 682 } 683 } 684 absValDeltaDC = uiUnaryIdx; 685 pcCU->setSingleDepthValueSubParts((Pel)absValDeltaDC,uiAbsPartIdx, 0, uiDepth); 686 } 687 } 688 #endif 689 #endif 690 621 #endif 691 622 /** parse merge flag 692 623 * \param pcCU … … 772 703 #if H_3D_QTLPC 773 704 Bool bParseSplitFlag = true; 774 775 776 705 Bool bLimQtPredFlag = pcCU->getPic()->getSlice(0)->getQtPredFlag(); 777 706 TComPic *pcTexture = pcCU->getSlice()->getTexturePic(); … … 810 739 #endif 811 740 pcCU->setDepthSubParts( uiDepth + uiSymbol, uiAbsPartIdx ); 812 741 813 742 return; 814 743 } … … 827 756 #if H_3D_QTLPC 828 757 Bool bParsePartSize = true; 829 758 830 759 Bool bLimQtPredFlag = pcCU->getPic()->getSlice(0)->getQtPredFlag(); 831 760 TComPic *pcTexture = pcCU->getSlice()->getTexturePic(); … … 859 788 #endif 860 789 861 790 862 791 if ( pcCU->isIntra( uiAbsPartIdx ) ) 863 792 { … … 866 795 { 867 796 #endif 868 uiSymbol = 1;797 uiSymbol = 1; 869 798 if( uiDepth == g_uiMaxCUDepth - g_uiAddCUDepth ) 870 799 { … … 899 828 { 900 829 #endif 901 UInt uiMaxNumBits = 2; 902 if( uiDepth == g_uiMaxCUDepth - g_uiAddCUDepth && !( (g_uiMaxCUWidth>>uiDepth) == 8 && (g_uiMaxCUHeight>>uiDepth) == 8 ) ) 903 { 904 uiMaxNumBits ++; 905 } 906 for ( UInt ui = 0; ui < uiMaxNumBits; ui++ ) 907 { 908 m_pcTDecBinIf->decodeBin( uiSymbol, m_cCUPartSizeSCModel.get( 0, 0, ui) ); 909 if ( uiSymbol ) 910 { 911 break; 912 } 913 uiMode++; 914 } 915 eMode = (PartSize) uiMode; 916 if ( pcCU->getSlice()->getSPS()->getAMPAcc( uiDepth ) ) 917 { 918 if (eMode == SIZE_2NxN) 919 { 920 m_pcTDecBinIf->decodeBin(uiSymbol, m_cCUPartSizeSCModel.get( 0, 0, 3 )); 921 if (uiSymbol == 0) 830 UInt uiMaxNumBits = 2; 831 if( uiDepth == g_uiMaxCUDepth - g_uiAddCUDepth && !( (g_uiMaxCUWidth>>uiDepth) == 8 && (g_uiMaxCUHeight>>uiDepth) == 8 ) ) 832 { 833 uiMaxNumBits ++; 834 } 835 for ( UInt ui = 0; ui < uiMaxNumBits; ui++ ) 836 { 837 m_pcTDecBinIf->decodeBin( uiSymbol, m_cCUPartSizeSCModel.get( 0, 0, ui) ); 838 if ( uiSymbol ) 922 839 { 923 m_pcTDecBinIf->decodeBinEP(uiSymbol); 924 eMode = (uiSymbol == 0? SIZE_2NxnU : SIZE_2NxnD); 840 break; 925 841 } 926 } 927 else if (eMode == SIZE_Nx2N) 928 { 929 m_pcTDecBinIf->decodeBin(uiSymbol, m_cCUPartSizeSCModel.get( 0, 0, 3 )); 930 if (uiSymbol == 0) 842 uiMode++; 843 } 844 eMode = (PartSize) uiMode; 845 if ( pcCU->getSlice()->getSPS()->getAMPAcc( uiDepth ) ) 846 { 847 if (eMode == SIZE_2NxN) 931 848 { 932 m_pcTDecBinIf->decodeBinEP(uiSymbol); 933 eMode = (uiSymbol == 0? SIZE_nLx2N : SIZE_nRx2N); 849 m_pcTDecBinIf->decodeBin(uiSymbol, m_cCUPartSizeSCModel.get( 0, 0, 3 )); 850 if (uiSymbol == 0) 851 { 852 m_pcTDecBinIf->decodeBinEP(uiSymbol); 853 eMode = (uiSymbol == 0? SIZE_2NxnU : SIZE_2NxnD); 854 } 934 855 } 935 } 936 } 856 else if (eMode == SIZE_Nx2N) 857 { 858 m_pcTDecBinIf->decodeBin(uiSymbol, m_cCUPartSizeSCModel.get( 0, 0, 3 )); 859 if (uiSymbol == 0) 860 { 861 m_pcTDecBinIf->decodeBinEP(uiSymbol); 862 eMode = (uiSymbol == 0? SIZE_nLx2N : SIZE_nRx2N); 863 } 864 } 865 } 937 866 #if H_3D_QTLPC 938 867 } … … 1060 989 { 1061 990 #endif 1062 m_pcTDecBinIf->decodeBin( symbol, m_cCUIntraPredSCModel.get( 0, 0, 0) );1063 mpmPred[j] = symbol;991 m_pcTDecBinIf->decodeBin( symbol, m_cCUIntraPredSCModel.get( 0, 0, 0) ); 992 mpmPred[j] = symbol; 1064 993 #if H_MV_ENC_DEC_TRAC 1065 DTRACE_CU("prev_intra_luma_pred_flag", symbol)994 DTRACE_CU("prev_intra_luma_pred_flag", symbol) 1066 995 #endif 1067 996 #if H_3D_DIM … … 1075 1004 { 1076 1005 #endif 1077 Int preds[3] = {-1, -1, -1}; 1078 Int predNum = pcCU->getIntraDirLumaPredictor(absPartIdx+partOffset*j, preds); 1079 if (mpmPred[j]) 1080 { 1081 m_pcTDecBinIf->decodeBinEP( symbol ); 1082 if (symbol) 1006 Int preds[3] = {-1, -1, -1}; 1007 Int predNum = pcCU->getIntraDirLumaPredictor(absPartIdx+partOffset*j, preds); 1008 if (mpmPred[j]) 1083 1009 { 1084 1010 m_pcTDecBinIf->decodeBinEP( symbol ); 1085 symbol++; 1086 } 1011 if (symbol) 1012 { 1013 m_pcTDecBinIf->decodeBinEP( symbol ); 1014 symbol++; 1015 } 1087 1016 #if H_MV_ENC_DEC_TRAC 1088 DTRACE_CU("mpm_idx", symbol)1089 #endif 1090 intraPredMode = preds[symbol];1091 }1092 else1093 {1094 m_pcTDecBinIf->decodeBinsEP( symbol, 5 );1095 intraPredMode = symbol;1017 DTRACE_CU("mpm_idx", symbol) 1018 #endif 1019 intraPredMode = preds[symbol]; 1020 } 1021 else 1022 { 1023 m_pcTDecBinIf->decodeBinsEP( symbol, 5 ); 1024 intraPredMode = symbol; 1096 1025 #if H_MV_ENC_DEC_TRAC 1097 DTRACE_CU("rem_intra_luma_pred_mode", symbol)1026 DTRACE_CU("rem_intra_luma_pred_mode", symbol) 1098 1027 #endif 1099 //postponed sorting of MPMs (only in remaining branch)1100 if (preds[0] > preds[1])1101 {1102 std::swap(preds[0], preds[1]);1103 }1104 if (preds[0] > preds[2])1105 {1106 std::swap(preds[0], preds[2]);1107 }1108 if (preds[1] > preds[2])1109 {1110 std::swap(preds[1], preds[2]);1111 }1112 for ( Int i = 0; i < predNum; i++ )1113 {1114 intraPredMode += ( intraPredMode >= preds[i] );1115 }1116 }1117 pcCU->setLumaIntraDirSubParts( (UChar)intraPredMode, absPartIdx+partOffset*j, depth );1028 //postponed sorting of MPMs (only in remaining branch) 1029 if (preds[0] > preds[1]) 1030 { 1031 std::swap(preds[0], preds[1]); 1032 } 1033 if (preds[0] > preds[2]) 1034 { 1035 std::swap(preds[0], preds[2]); 1036 } 1037 if (preds[1] > preds[2]) 1038 { 1039 std::swap(preds[1], preds[2]); 1040 } 1041 for ( Int i = 0; i < predNum; i++ ) 1042 { 1043 intraPredMode += ( intraPredMode >= preds[i] ); 1044 } 1045 } 1046 pcCU->setLumaIntraDirSubParts( (UChar)intraPredMode, absPartIdx+partOffset*j, depth ); 1118 1047 #if H_3D_DIM 1119 1048 } … … 1133 1062 DTRACE_CU("intra_chroma_pred_mode", uiSymbol ) 1134 1063 #endif 1135 uiSymbol = DM_CHROMA_IDX;1064 uiSymbol = DM_CHROMA_IDX; 1136 1065 } 1137 1066 else … … 1143 1072 DTRACE_CU("intra_chroma_pred_mode", uiIPredMode ) 1144 1073 #endif 1145 UInt uiAllowedChromaDir[ NUM_CHROMA_MODE ];1074 UInt uiAllowedChromaDir[ NUM_CHROMA_MODE ]; 1146 1075 pcCU->getAllowedChromaDir( uiAbsPartIdx, uiAllowedChromaDir ); 1147 1076 uiSymbol = uiAllowedChromaDir[ uiIPredMode ]; -
trunk/source/Lib/TLibDecoder/TDecSbac.h
r1179 r1196 125 125 126 126 Void parseSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 127 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033127 #if H_3D 128 128 Void parseDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 129 #else130 #if H_3D_SINGLE_DEPTH131 Void parseSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth );132 #endif133 129 #endif 134 130 Void parseCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); … … 182 178 ContextModel3DBuffer m_cCUSplitFlagSCModel; 183 179 ContextModel3DBuffer m_cCUSkipFlagSCModel; 184 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033180 #if H_3D 185 181 ContextModel3DBuffer m_cCUDISFlagSCModel; 186 182 ContextModel3DBuffer m_cCUDISTypeSCModel; 187 #else188 #if H_3D_SINGLE_DEPTH189 ContextModel3DBuffer m_cCUSingleDepthFlagSCModel;190 ContextModel3DBuffer m_cSingleDepthValueSCModel;191 #endif192 183 #endif 193 184 ContextModel3DBuffer m_cCUMergeFlagExtSCModel; -
trunk/source/Lib/TLibDecoder/TDecTop.cpp
r1179 r1196 76 76 xDeleteArray( m_adBaseViewShiftLUT, MAX_NUM_LAYERS, MAX_NUM_LAYERS, 2 ); 77 77 xDeleteArray( m_aiBaseViewShiftLUT, MAX_NUM_LAYERS, MAX_NUM_LAYERS, 2 ); 78 #if HHI_CAM_PARA_K005279 78 xDeleteArray( m_receivedIdc, m_vps->getNumViews() ); 80 #else81 xDeleteArray( m_receivedIdc, m_uiMaxViewIndex + 1 );82 #endif83 79 } 84 80 … … 95 91 m_firstReceivedPoc = -2; 96 92 97 #if HHI_CAM_PARA_K005298 93 for (Int i = 0; i <= vps->getMaxLayersMinus1(); i++) 99 94 { … … 134 129 } 135 130 136 #else137 m_uiMaxViewIndex = -1;138 for (Int i = 0; i <= vps->getMaxLayersMinus1(); i++)139 {140 Int curViewIdx = m_vps->getViewIndex( m_vps->getLayerIdInNuh( i ));141 m_bCamParsVaryOverTime = m_bCamParsVaryOverTime || vps->hasCamParInSliceHeader( curViewIdx );142 m_uiMaxViewIndex = std::max( m_uiMaxViewIndex, curViewIdx ) ;143 }144 assert( m_receivedIdc == NULL );145 m_receivedIdc = new Int*[ m_uiMaxViewIndex + 1];146 for (Int i = 0; i <= m_uiMaxViewIndex; i++)147 {148 m_receivedIdc[i] = new Int[ m_uiMaxViewIndex + 1 ];149 }150 151 xResetReceivedIdc( true );152 153 for (Int viewIndex = 0; viewIndex <= m_uiMaxViewIndex ; viewIndex++ )154 {155 if (m_vps->getCamParPresent( viewIndex ) )156 {157 if( !m_vps->hasCamParInSliceHeader( viewIndex ) )158 {159 for (Int baseViewIndex = 0; baseViewIndex < viewIndex ; baseViewIndex++ )160 {161 m_receivedIdc [ baseViewIndex ][ viewIndex ] = -1;162 m_aaiCodedScale [ baseViewIndex ][ viewIndex ] = m_vps->getCodedScale (viewIndex) [ baseViewIndex ];163 m_aaiCodedOffset[ baseViewIndex ][ viewIndex ] = m_vps->getCodedOffset (viewIndex) [ baseViewIndex ];164 165 m_receivedIdc [ viewIndex ][ baseViewIndex ] = -1;166 m_aaiCodedScale [ viewIndex ][ baseViewIndex ] = m_vps->getInvCodedScale (viewIndex) [ baseViewIndex ];167 m_aaiCodedOffset[ viewIndex ][ baseViewIndex ] = m_vps->getInvCodedOffset(viewIndex) [ baseViewIndex ];168 xInitLUTs( baseViewIndex, viewIndex, m_aaiCodedScale[ baseViewIndex ][ viewIndex ], m_aaiCodedOffset[ baseViewIndex ][ viewIndex ], m_adBaseViewShiftLUT, m_aiBaseViewShiftLUT );169 xInitLUTs( viewIndex, baseViewIndex, m_aaiCodedScale[ viewIndex ][ baseViewIndex ], m_aaiCodedOffset[ viewIndex ][ baseViewIndex ], m_adBaseViewShiftLUT, m_aiBaseViewShiftLUT );170 }171 }172 }173 }174 }175 176 #endif177 131 178 132 … … 181 135 CamParsCollector::xResetReceivedIdc( Bool overWriteFlag ) 182 136 { 183 #if HHI_CAM_PARA_K0052184 137 for (Int i = 0; i < m_vps->getNumViews(); i++) 185 138 { 186 139 for (Int j = 0; j < m_vps->getNumViews(); j++) 187 140 { 188 #else189 for (Int i = 0; i <= m_uiMaxViewIndex; i++)190 {191 for (Int j = 0; j <= m_uiMaxViewIndex; j++)192 {193 #endif194 141 if ( overWriteFlag || ( m_receivedIdc[i][j] != -1 ) ) 195 142 { … … 232 179 CamParsCollector::xInitLUTs( UInt uiSourceView, UInt uiTargetView, Int iScale, Int iOffset, Double****& radLUT, Int****& raiLUT) 233 180 { 234 #if HHI_CAM_PARA_K0052235 181 Int iLog2DivLuma = m_uiBitDepthForLUT + m_vps->getCpPrecision() + 1 - m_iLog2Precision; AOF( iLog2DivLuma > 0 ); 236 #else237 Int iLog2DivLuma = m_uiBitDepthForLUT + m_vps->getCamParPrecision() + 1 - m_iLog2Precision; AOF( iLog2DivLuma > 0 );238 #endif239 182 Int iLog2DivChroma = iLog2DivLuma + 1; 240 183 … … 313 256 } 314 257 315 #if HHI_CAM_PARA_K0052316 258 UInt voiInVps = m_vps->getVoiInVps(pcSlice->getViewIndex()); 317 259 if( m_vps->getCpInSliceSegmentHeaderFlag( voiInVps ) ) // check consistency of slice parameters here … … 348 290 } 349 291 } 350 #else351 UInt uiViewIndex = pcSlice->getViewIndex();352 if( m_vps->getCamParPresent( uiViewIndex ) )353 {354 if( m_vps->hasCamParInSliceHeader( uiViewIndex ) ) // check consistency of slice parameters here355 {356 for( UInt uiBaseViewIndex = 0; uiBaseViewIndex < uiViewIndex; uiBaseViewIndex++ )357 {358 if ( m_receivedIdc[ uiViewIndex ][ uiBaseViewIndex ] != 0 )359 {360 AOF( m_aaiCodedScale [ uiViewIndex ][ uiBaseViewIndex ] == pcSlice->getInvCodedScale () [ uiBaseViewIndex ] );361 AOF( m_aaiCodedOffset[ uiViewIndex ][ uiBaseViewIndex ] == pcSlice->getInvCodedOffset() [ uiBaseViewIndex ] );362 }363 else364 {365 m_receivedIdc [ uiViewIndex ][ uiBaseViewIndex ] = 1;366 m_aaiCodedScale [ uiViewIndex ][ uiBaseViewIndex ] = pcSlice->getInvCodedScale () [ uiBaseViewIndex ];367 m_aaiCodedOffset[ uiViewIndex ][ uiBaseViewIndex ] = pcSlice->getInvCodedOffset() [ uiBaseViewIndex ];368 xInitLUTs( uiViewIndex, uiBaseViewIndex, m_aaiCodedScale[ uiViewIndex ][ uiBaseViewIndex ], m_aaiCodedOffset[ uiViewIndex ][ uiBaseViewIndex ], m_adBaseViewShiftLUT, m_aiBaseViewShiftLUT);369 }370 if ( m_receivedIdc[ uiBaseViewIndex ][ uiViewIndex ] != 0 )371 {372 AOF( m_aaiCodedScale [ uiBaseViewIndex ][ uiViewIndex ] == pcSlice->getCodedScale () [ uiBaseViewIndex ] );373 AOF( m_aaiCodedOffset[ uiBaseViewIndex ][ uiViewIndex ] == pcSlice->getCodedOffset () [ uiBaseViewIndex ] );374 }375 else376 {377 m_receivedIdc [ uiBaseViewIndex ][ uiViewIndex ] = 1;378 m_aaiCodedScale [ uiBaseViewIndex ][ uiViewIndex ] = pcSlice->getCodedScale () [ uiBaseViewIndex ];379 m_aaiCodedOffset[ uiBaseViewIndex ][ uiViewIndex ] = pcSlice->getCodedOffset () [ uiBaseViewIndex ];380 xInitLUTs( uiBaseViewIndex, uiViewIndex, m_aaiCodedScale[ uiBaseViewIndex ][ uiViewIndex ], m_aaiCodedOffset[ uiBaseViewIndex ][ uiViewIndex ], m_adBaseViewShiftLUT, m_aiBaseViewShiftLUT);381 }382 }383 }384 }385 #endif386 387 388 292 } 389 293 … … 408 312 if( iPOC == m_firstReceivedPoc ) 409 313 { 410 #if HHI_CAM_PARA_K0052411 314 fprintf( m_pCodedScaleOffsetFile, "#ViewOrderIdx ViewIdVal\n" ); 412 315 fprintf( m_pCodedScaleOffsetFile, "#------------ -------------\n" ); … … 436 339 m_aaiCodedScale [ baseVoiInVps ][ voiInVps ], 437 340 m_aaiCodedOffset[ baseVoiInVps ][ voiInVps ], m_vps->getCpPrecision() ); 438 #else439 fprintf( m_pCodedScaleOffsetFile, "# ViewIndex ViewId\n" );440 fprintf( m_pCodedScaleOffsetFile, "#----------- ------------\n" );441 for( UInt uiViewIndex = 0; uiViewIndex <= m_uiMaxViewIndex; uiViewIndex++ )442 {443 fprintf( m_pCodedScaleOffsetFile, "%12d %12d\n", uiViewIndex, m_vps->getViewIdVal( uiViewIndex ) );444 }445 fprintf( m_pCodedScaleOffsetFile, "\n\n");446 fprintf( m_pCodedScaleOffsetFile, "# StartFrame EndFrame TargetView BaseView CodedScale CodedOffset Precision\n" );447 fprintf( m_pCodedScaleOffsetFile, "#----------- ------------ ------------ ------------ ------------ ------------ ------------\n" );448 }449 if( iPOC == m_firstReceivedPoc || m_bCamParsVaryOverTime )450 {451 Int iS = iPOC;452 Int iE = ( m_bCamParsVaryOverTime ? iPOC : ~( 1 << 31 ) );453 #if HHI_CAM_PARA_K0052454 for( UInt uiViewIndex = 0; uiViewIndex < m_vps->getNumViews(); uiViewIndex++ )455 {456 for( UInt uiBaseIndex = 0; uiBaseIndex < m_vps->getNumViews(); uiBaseIndex++ )457 #else458 for( UInt uiViewIndex = 0; uiViewIndex <= m_uiMaxViewIndex; uiViewIndex++ )459 {460 for( UInt uiBaseIndex = 0; uiBaseIndex <= m_uiMaxViewIndex; uiBaseIndex++ )461 #endif462 {463 if( uiViewIndex != uiBaseIndex )464 {465 if ( m_receivedIdc[uiBaseIndex][uiViewIndex] != 0 )466 {467 #if HHI_CAM_PARA_K0052468 fprintf( m_pCodedScaleOffsetFile, "%12d %12d %12d %12d %12d %12d %12d\n",469 iS, iE, uiViewIndex, uiBaseIndex, m_aaiCodedScale[ uiBaseIndex ][ uiViewIndex ], m_aaiCodedOffset[ uiBaseIndex ][ uiViewIndex ], m_vps->getCpPrecision() );470 #else471 fprintf( m_pCodedScaleOffsetFile, "%12d %12d %12d %12d %12d %12d %12d\n",472 iS, iE, uiViewIndex, uiBaseIndex, m_aaiCodedScale[ uiBaseIndex ][ uiViewIndex ], m_aaiCodedOffset[ uiBaseIndex ][ uiViewIndex ], m_vps->getCamParPrecision() );473 #endif474 #endif475 341 } 476 342 } … … 481 347 } 482 348 #endif 349 483 350 TDecTop::TDecTop() 484 351 { … … 556 423 initROM(); 557 424 #endif 558 #if H_3D _ANNEX_SELECTION_FIX425 #if H_3D 559 426 m_cCavlcDecoder.setDecTop( this ); 560 427 #endif … … 867 734 868 735 #endif 869 #if H_3D870 #if !HHI_INTER_COMP_PRED_K0052871 m_apcSlicePilot->init3dToolParameters();872 #endif873 #endif874 736 pps->setSPS(sps); 875 737 pps->setNumSubstreams(pps->getEntropyCodingSyncEnabledFlag() ? ((sps->getPicHeightInLumaSamples() + sps->getMaxCUHeight() - 1) / sps->getMaxCUHeight()) * (pps->getNumTileColumnsMinus1() + 1) : 1); … … 1098 960 xActivateParameterSets(); 1099 961 1100 #if SONY_MV_V_CONST_C0078962 #if H_MV 1101 963 //Check Multiview Main profile constraint in G.11.1.1 1102 964 // When ViewOrderIdx[ i ] derived according to any active VPS is equal to 1 … … 1230 1092 pcPic->setViewIndex( getViewIndex() ); 1231 1093 pcPic->setIsDepth ( getIsDepth () ); 1232 #endif1233 #endif1234 #if HHI_RES_PRED_K00521235 1094 pcSlice->setIvPicLists( m_ivPicLists ); 1236 1095 #endif 1096 #endif 1097 1098 1099 1237 1100 1238 1101 if (bNextSlice) … … 1271 1134 1272 1135 #if H_3D 1273 #if !HHI_RES_PRED_K00521274 pcSlice->setIvPicLists( m_ivPicLists );1275 #endif1276 1277 #if HHI_INTER_COMP_PRED_K00521278 1136 pcSlice->checkInCompPredRefLayers(); 1279 1137 #if H_3D_IV_MERGE … … 1284 1142 #endif 1285 1143 #endif 1286 #else1287 #if H_3D_IV_MERGE1288 #if H_3D_FCO1289 //assert( !getIsDepth() );1290 #else1291 assert( !getIsDepth() || ( pcSlice->getTexturePic() != 0 ) );1292 #endif1293 #endif1294 #endif1295 1144 #endif 1296 1145 #if H_MV … … 1347 1196 #if H_3D_TMVP 1348 1197 if(pcSlice->getLayerId()) 1198 { 1349 1199 pcSlice->generateAlterRefforTMVP(); 1200 } 1350 1201 #endif 1351 1202 } … … 1800 1651 } 1801 1652 1802 #if H_MV1803 1653 Void TDecTop::xCeckNoClrasOutput() 1804 1654 { … … 1834 1684 return allRefLayersInitilizedFlag; 1835 1685 } 1686 1687 #if H_3D 1688 Void TDecTop::setProfileIdc() 1689 { 1690 if (m_targetOptLayerSetIdx != -1 ) 1691 { 1692 TComVPS* vps = getPrefetchedVPS(); 1693 Int lsIdx = vps->olsIdxToLsIdx( m_targetOptLayerSetIdx ); 1694 Int lIdx = -1; 1695 for (Int j = 0; j < vps->getNumLayersInIdList( lsIdx ); j++ ) 1696 { 1697 if ( vps->getLayerSetLayerIdList( lsIdx, j ) == getLayerId() ) 1698 { 1699 lIdx = j; 1700 break; 1701 } 1702 } 1703 assert( lIdx != -1 ); 1704 1705 Int profileIdc = vps->getPTL( vps->getProfileTierLevelIdx( m_targetOptLayerSetIdx, lIdx ) )->getGeneralPTL()->getProfileIdc(); 1706 assert( profileIdc == 1 || profileIdc == 6 || profileIdc == 8 ); 1707 m_profileIdc = profileIdc; 1708 }; 1709 } 1836 1710 #endif 1837 1711 #endif -
trunk/source/Lib/TLibDecoder/TDecTop.h
r1179 r1196 97 97 TComVPS* m_vps; 98 98 Int** m_receivedIdc; 99 #if!HHI_CAM_PARA_K0052100 Int m_uiMaxViewIndex;101 #endif102 99 Int m_lastPoc; 103 100 Int m_firstReceivedPoc; … … 244 241 Bool m_isDepth; 245 242 CamParsCollector* m_pcCamParsCollector; 246 #endif247 #if H_3D_ANNEX_SELECTION_FIX248 243 Int m_profileIdc; 249 244 #endif … … 305 300 Bool getIsDepth () { return m_isDepth; } 306 301 Void setCamParsCollector( CamParsCollector* pcCamParsCollector ) { m_pcCamParsCollector = pcCamParsCollector; } 307 #endif 308 #if H_3D_ANNEX_SELECTION_FIX 309 Void setProfileIdc() 310 { 311 if (m_targetOptLayerSetIdx != -1 ) 312 { 313 TComVPS* vps = getPrefetchedVPS(); 314 Int lsIdx = vps->olsIdxToLsIdx( m_targetOptLayerSetIdx ); 315 Int lIdx = -1; 316 for (Int j = 0; j < vps->getNumLayersInIdList( lsIdx ); j++ ) 317 { 318 if ( vps->getLayerSetLayerIdList( lsIdx, j ) == getLayerId() ) 319 { 320 lIdx = j; 321 break; 322 } 323 } 324 assert( lIdx != -1 ); 325 326 Int profileIdc = vps->getPTL( vps->getProfileTierLevelIdx( m_targetOptLayerSetIdx, lIdx ) )->getGeneralPTL()->getProfileIdc(); 327 assert( profileIdc == 1 || profileIdc == 6 || profileIdc == 8 ); 328 m_profileIdc = profileIdc; 329 }; 330 } 302 303 Void setProfileIdc(); 331 304 Bool decProcAnnexI() { assert( m_profileIdc != -1 ); return ( m_profileIdc == 8); } 332 305 #endif 333 334 306 #endif 335 307 protected: -
trunk/source/Lib/TLibEncoder/TEncCavlc.cpp
r1179 r1196 40 40 #include "SEIwrite.h" 41 41 #include "../TLibCommon/TypeDef.h" 42 #if H_3D _ANNEX_SELECTION_FIX42 #if H_3D 43 43 #include "TEncTop.h" 44 44 #endif … … 862 862 WRITE_FLAG( pcPPS->getPocResetInfoPresentFlag( ) ? 1 : 0 , "poc_reset_info_present_flag" ); 863 863 WRITE_FLAG( pcPPS->getPpsInferScalingListFlag( ) ? 1 : 0 , "pps_infer_scaling_list_flag" ); 864 #if FIX_TICKET_95865 864 if (pcPPS->getPpsInferScalingListFlag()) 866 865 { 867 866 WRITE_CODE( pcPPS->getPpsScalingListRefLayerId( ), 6, "pps_scaling_list_ref_layer_id" ); 868 867 } 869 #else870 WRITE_CODE( pcPPS->getPpsScalingListRefLayerId( ), 6, "pps_scaling_list_ref_layer_id" );871 #endif872 868 WRITE_UVLC( 0, "num_ref_loc_offsets" ); 873 869 WRITE_FLAG( 0 , "colour_mapping_enabled_flag" ); … … 901 897 WRITE_FLAG( sps3dExt->getQtPredFlag( d ) ? 1 : 0 , "qt_pred_flag" ); 902 898 WRITE_FLAG( sps3dExt->getInterSdcFlag( d ) ? 1 : 0 , "inter_sdc_flag" ); 903 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033904 899 WRITE_FLAG( sps3dExt->getDepthIntraSkipFlag( d ) ? 1 : 0 , "intra_skip_flag" ); 905 #else906 WRITE_FLAG( sps3dExt->getIntraSingleFlag( d ) ? 1 : 0 , "intra_single_flag" );907 #endif908 900 } 909 901 } … … 1614 1606 Void TEncCavlc::codeVPS3dExtension( TComVPS* pcVPS ) 1615 1607 { 1616 #if HHI_CAM_PARA_K00521617 1608 WRITE_UVLC( pcVPS->getCpPrecision( ), "cp_precision" ); 1618 1609 for (Int n = 1; n < pcVPS->getNumViews(); n++) … … 1640 1631 } 1641 1632 } 1642 #else1643 WRITE_UVLC( pcVPS->getCamParPrecision(), "cp_precision" );1644 for (UInt viewIndex=1; viewIndex<pcVPS->getNumViews(); viewIndex++)1645 {1646 WRITE_FLAG( pcVPS->getCamParPresent(viewIndex) ? 1 : 0, "cp_present_flag[i]" );1647 if ( pcVPS->getCamParPresent(viewIndex) )1648 {1649 WRITE_FLAG( pcVPS->hasCamParInSliceHeader(viewIndex) ? 1 : 0, "cp_in_slice_segment_header_flag[i]" );1650 if ( !pcVPS->hasCamParInSliceHeader(viewIndex) )1651 {1652 for( UInt uiIndex = 0; uiIndex < viewIndex; uiIndex++ )1653 {1654 WRITE_SVLC( pcVPS->getCodedScale (viewIndex)[ uiIndex ], "vps_cp_scale" );1655 WRITE_SVLC( pcVPS->getCodedOffset (viewIndex)[ uiIndex ], "vps_cp_off" );1656 WRITE_SVLC( pcVPS->getInvCodedScale (viewIndex)[ uiIndex ] + pcVPS->getCodedScale (viewIndex)[ uiIndex ], "vps_cp_inv_scale_plus_scale" );1657 WRITE_SVLC( pcVPS->getInvCodedOffset(viewIndex)[ uiIndex ] + pcVPS->getCodedOffset(viewIndex)[ uiIndex ], "vps_cp_inv_off_plus_off" );1658 }1659 }1660 }1661 }1662 #endif1663 1633 } 1664 1634 #endif … … 1945 1915 #endif 1946 1916 1947 #if HHI_INTER_COMP_PRED_K00521948 1917 #if H_3D 1949 1918 if( getEncTop()->decProcAnnexI() ) … … 1954 1923 } 1955 1924 } 1956 #endif1957 1925 #endif 1958 1926 if(pcSlice->getSPS()->getUseSAO()) … … 2086 2054 } 2087 2055 #if H_3D_IC 2088 #if H_3D_ANNEX_SELECTION_FIX2089 2056 else if( pcSlice->getViewIndex() && ( pcSlice->getSliceType() == P_SLICE || pcSlice->getSliceType() == B_SLICE ) 2090 2057 && !pcSlice->getIsDepth() && vps->getNumRefListLayers( layerId ) > 0 2091 2058 && getEncTop()->decProcAnnexI() 2092 2059 ) 2093 #else2094 else if( pcSlice->getViewIndex() && ( pcSlice->getSliceType() == P_SLICE || pcSlice->getSliceType() == B_SLICE ) && !pcSlice->getIsDepth() && vps->getNumRefListLayers( layerId ) > 0 )2095 #endif2096 2060 { 2097 2061 WRITE_FLAG( pcSlice->getApplyIC() ? 1 : 0, "slice_ic_enable_flag" ); … … 2148 2112 WRITE_FLAG(pcSlice->getLFCrossSliceBoundaryFlag()?1:0, "slice_loop_filter_across_slices_enabled_flag"); 2149 2113 } 2150 #if HHI_CAM_PARA_K00522151 2114 #if H_3D 2152 2115 if (getEncTop()->decProcAnnexI() ) … … 2166 2129 } 2167 2130 #endif 2168 #endif 2169 } 2170 2171 #if !HHI_CAM_PARA_K0052 2172 #if H_3D 2173 #if H_3D_FCO 2174 if( pcSlice->getVPS()->hasCamParInSliceHeader( pcSlice->getViewIndex() ) && pcSlice->getIsDepth() ) 2175 #else 2176 if( pcSlice->getVPS()->hasCamParInSliceHeader( pcSlice->getViewIndex() ) && !pcSlice->getIsDepth() ) 2177 #endif 2178 { 2179 for( UInt uiId = 0; uiId < pcSlice->getViewIndex(); uiId++ ) 2180 { 2181 WRITE_SVLC( pcSlice->getCodedScale ()[ uiId ], "cp_scale" ); 2182 WRITE_SVLC( pcSlice->getCodedOffset ()[ uiId ], "cp_off" ); 2183 WRITE_SVLC( pcSlice->getInvCodedScale ()[ uiId ] + pcSlice->getCodedScale ()[ uiId ], "cp_inv_scale_plus_scale" ); 2184 WRITE_SVLC( pcSlice->getInvCodedOffset()[ uiId ] + pcSlice->getCodedOffset()[ uiId ], "cp_inv_off_plus_off" ); 2185 } 2186 } 2187 #endif 2188 #endif 2131 } 2132 2189 2133 2190 2134 … … 2532 2476 assert(0); 2533 2477 } 2534 2535 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 2478 #if H_3D 2536 2479 Void TEncCavlc::codeDIS( TComDataCU* pcCU, UInt uiAbsPartIdx ) 2537 2480 { 2538 2481 assert(0); 2539 2482 } 2540 #else2541 #if H_3D_SINGLE_DEPTH2542 Void TEncCavlc::codeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx )2543 {2544 assert(0);2545 }2546 #endif2547 2483 #endif 2548 2484 -
trunk/source/Lib/TLibEncoder/TEncCavlc.h
r1179 r1196 68 68 TComSlice* m_pcSlice; 69 69 UInt m_uiCoeffCost; 70 #if H_3D _ANNEX_SELECTION_FIX70 #if H_3D 71 71 TEncTop* m_encTop; 72 72 #endif … … 129 129 Void codeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx ); 130 130 Void codeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ); 131 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033131 #if H_3D 132 132 Void codeDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx ); 133 #else134 #if H_3D_SINGLE_DEPTH135 Void codeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx );136 #endif137 133 #endif 138 134 Void codeMergeFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ); … … 187 183 Void codeDFFlag ( UInt uiCode, const Char *pSymbolName ); 188 184 Void codeDFSvlc ( Int iCode, const Char *pSymbolName ); 189 #if H_3D _ANNEX_SELECTION_FIX185 #if H_3D 190 186 TEncTop* getEncTop() { return m_encTop; }; 191 187 Void setEncTop( TEncTop* et ) { m_encTop = et; }; -
trunk/source/Lib/TLibEncoder/TEncCfg.h
r1179 r1196 78 78 Int m_interViewRefPosL[2][MAX_NUM_REF_PICS]; 79 79 #endif 80 #if H HI_INTER_COMP_PRED_K005280 #if H_3D 81 81 Bool m_interCompPredFlag; 82 82 #endif … … 98 98 , m_numActiveRefLayerPics(0) 99 99 #endif 100 #if HHI_INTER_COMP_PRED_K0052101 100 #if H_3D 102 101 , m_interCompPredFlag(false) 103 #endif104 102 #endif 105 103 { … … 188 186 Int m_iSearchRange; // 0:Full frame 189 187 Int m_bipredSearchRange; 190 #if SONY_MV_V_CONST_C0078188 #if H_MV 191 189 Bool m_bUseDisparitySearchRangeRestriction; 192 190 Int m_iVerticalDisparitySearchRange; … … 380 378 381 379 //====== Camera Parameters ====== 382 #if !HHI_CAM_PARA_K0052383 UInt m_uiCamParPrecision;384 Bool m_bCamParInSliceHeader;385 Int** m_aaiCodedScale;386 Int** m_aaiCodedOffset;387 #endif388 380 TAppComCamPara* m_cameraParameters; 389 381 … … 418 410 Bool m_bUseQTL; 419 411 #endif 420 #if H_3D_ANNEX_SELECTION_FIX 412 421 413 Int m_profileIdc; 422 #endif423 414 424 415 #endif … … 435 426 , m_isDepth(false) 436 427 , m_bUseVSO(false) 437 #if H_3D_ANNEX_SELECTION_FIX438 428 , m_profileIdc( -1 ) 439 #endif440 429 #endif 441 430 #endif … … 522 511 Void setSearchRange ( Int i ) { m_iSearchRange = i; } 523 512 Void setBipredSearchRange ( Int i ) { m_bipredSearchRange = i; } 524 #if SONY_MV_V_CONST_C0078513 #if H_MV 525 514 Void setUseDisparitySearchRangeRestriction ( Bool b ) { m_bUseDisparitySearchRangeRestriction = b; } 526 515 Void setVerticalDisparitySearchRange ( Int i ) { m_iVerticalDisparitySearchRange = i; } … … 578 567 Int getFastSearch () { return m_iFastSearch; } 579 568 Int getSearchRange () { return m_iSearchRange; } 580 #if SONY_MV_V_CONST_C0078569 #if H_MV 581 570 Bool getUseDisparitySearchRangeRestriction () { return m_bUseDisparitySearchRangeRestriction; } 582 571 Int getVerticalDisparitySearchRange () { return m_iVerticalDisparitySearchRange; } … … 923 912 924 913 //==== CAMERA PARAMETERS ========== 925 #if !HHI_CAM_PARA_K0052926 Void setCamParPrecision ( UInt u ) { m_uiCamParPrecision = u; }927 Void setCamParInSliceHeader ( Bool b ) { m_bCamParInSliceHeader = b; }928 Void setCodedScale ( Int** p ) { m_aaiCodedScale = p; }929 Void setCodedOffset ( Int** p ) { m_aaiCodedOffset = p; }930 #endif931 914 Void setCameraParameters ( TAppComCamPara* c) { m_cameraParameters = c; } 932 915 … … 976 959 Bool getUseQTL () { return m_bUseQTL; } 977 960 #endif 978 #if H_3D_ANNEX_SELECTION_FIX979 961 Void setProfileIdc( Int a ) { assert( a == 1 || a == 6 || a == 8 ); m_profileIdc = a; } 980 962 Bool decProcAnnexI() { assert( m_profileIdc != -1 ); return ( m_profileIdc == 8); } 981 #endif982 963 983 964 #endif // H_3D -
trunk/source/Lib/TLibEncoder/TEncCu.cpp
r1179 r1196 441 441 #if H_3D_VSP 442 442 DisInfo DvInfo; 443 #if !SEC_ARP_REM_ENC_RESTRICT_K0035444 DvInfo.bDV = false;445 #endif446 443 DvInfo.m_acNBDV.setZero(); 447 444 DvInfo.m_aVIdxCan = 0; … … 544 541 TComDataCU* pcTextureCU = pcTexture->getCU( rpcBestCU->getAddr() ); //Corresponding texture LCU 545 542 UInt uiCUIdx = rpcBestCU->getZorderIdxInCU(); 546 assert(pcTextureCU->getDepth(uiCUIdx) >= uiDepth); //Depth cannot be more partition ned than the texture.543 assert(pcTextureCU->getDepth(uiCUIdx) >= uiDepth); //Depth cannot be more partitioned than the texture. 547 544 if (pcTextureCU->getDepth(uiCUIdx) > uiDepth || pcTextureCU->getPartitionSize(uiCUIdx) == SIZE_NxN) //Texture was split. 548 545 { … … 559 556 { 560 557 if(pcTextureCU->getPartitionSize(uiCUIdx)==SIZE_2NxN || pcTextureCU->getPartitionSize(uiCUIdx)==SIZE_2NxnU|| pcTextureCU->getPartitionSize(uiCUIdx)==SIZE_2NxnD) 558 { 561 559 bTry2NxN = true; 560 } 562 561 else 562 { 563 563 bTryNx2N = true; 564 } 564 565 } 565 566 } … … 589 590 if (rpcTempCU->getSlice()->getIsDepth() ) 590 591 { 591 #if SEC_ARP_REM_ENC_RESTRICT_K0035592 592 rpcTempCU->getDispforDepth(0, 0, &DvInfo); 593 #else594 DvInfo.bDV = rpcTempCU->getDispforDepth(0, 0, &DvInfo);595 #endif596 593 } 597 594 else … … 599 596 #endif 600 597 #if H_3D_NBDV_REF 601 if( rpcTempCU->getSlice()->getDepthRefinementFlag() ) 602 #if SEC_ARP_REM_ENC_RESTRICT_K0035 603 rpcTempCU->getDisMvpCandNBDV(&DvInfo, true); 604 #else 605 DvInfo.bDV = rpcTempCU->getDisMvpCandNBDV(&DvInfo, true); 606 #endif 607 else 598 if( rpcTempCU->getSlice()->getDepthRefinementFlag() ) 599 { 600 rpcTempCU->getDisMvpCandNBDV(&DvInfo, true); 601 } 602 else 608 603 #endif 609 #if SEC_ARP_REM_ENC_RESTRICT_K0035 610 rpcTempCU->getDisMvpCandNBDV(&DvInfo); 611 #else 612 DvInfo.bDV = rpcTempCU->getDisMvpCandNBDV(&DvInfo); 613 #endif 614 604 { 605 rpcTempCU->getDisMvpCandNBDV(&DvInfo); 606 } 615 607 #if H_3D_IV_MERGE 616 608 } … … 639 631 Bool bICFlag = uiICId ? true : false; 640 632 #endif 641 // 2Nx2N 642 if(m_pcEncCfg->getUseEarlySkipDetection()) 643 { 633 // 2Nx2N 634 if(m_pcEncCfg->getUseEarlySkipDetection()) 635 { 636 #if H_3D_IC 637 rpcTempCU->setICFlagSubParts(bICFlag, 0, 0, uiDepth); 638 #endif 639 #if H_3D_FAST_TEXTURE_ENCODING 640 xCheckRDCostInter( rpcBestCU, rpcTempCU, SIZE_2Nx2N, bFMD ); rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode );//by Competition for inter_2Nx2N 641 #else 642 xCheckRDCostInter( rpcBestCU, rpcTempCU, SIZE_2Nx2N ); 643 rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode );//by Competition for inter_2Nx2N 644 #endif 645 #if H_3D_VSP 646 rpcTempCU->setDvInfoSubParts(DvInfo, 0, uiDepth); 647 #endif 648 } 649 // SKIP 644 650 #if H_3D_IC 645 651 rpcTempCU->setICFlagSubParts(bICFlag, 0, 0, uiDepth); 646 652 #endif 653 xCheckRDCostMerge2Nx2N( rpcBestCU, rpcTempCU, &earlyDetectionSkipMode );//by Merge for inter_2Nx2N 647 654 #if H_3D_FAST_TEXTURE_ENCODING 648 xCheckRDCostInter( rpcBestCU, rpcTempCU, SIZE_2Nx2N, bFMD ); rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode );//by Competition for inter_2Nx2N 649 #else 650 xCheckRDCostInter( rpcBestCU, rpcTempCU, SIZE_2Nx2N ); 651 rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode );//by Competition for inter_2Nx2N 652 #endif 655 bFMD = bIVFMerge && rpcBestCU->isSkipped(0); 656 #endif 657 rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode ); 653 658 #if H_3D_VSP 654 659 rpcTempCU->setDvInfoSubParts(DvInfo, 0, uiDepth); 655 660 #endif 656 } 657 // SKIP 658 #if H_3D_IC 659 rpcTempCU->setICFlagSubParts(bICFlag, 0, 0, uiDepth); 660 #endif 661 xCheckRDCostMerge2Nx2N( rpcBestCU, rpcTempCU, &earlyDetectionSkipMode );//by Merge for inter_2Nx2N 662 #if H_3D_FAST_TEXTURE_ENCODING 663 bFMD = bIVFMerge && rpcBestCU->isSkipped(0); 664 #endif 665 rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode ); 666 #if H_3D_VSP 667 rpcTempCU->setDvInfoSubParts(DvInfo, 0, uiDepth); 668 #endif 669 670 if(!m_pcEncCfg->getUseEarlySkipDetection()) 671 { 672 // 2Nx2N, NxN 661 662 if(!m_pcEncCfg->getUseEarlySkipDetection()) 663 { 664 // 2Nx2N, NxN 673 665 #if H_3D_IC 674 666 rpcTempCU->setICFlagSubParts(bICFlag, 0, 0, uiDepth); … … 677 669 xCheckRDCostInter( rpcBestCU, rpcTempCU, SIZE_2Nx2N, bFMD ); rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode ); 678 670 #else 679 xCheckRDCostInter( rpcBestCU, rpcTempCU, SIZE_2Nx2N );680 rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode );671 xCheckRDCostInter( rpcBestCU, rpcTempCU, SIZE_2Nx2N ); 672 rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode ); 681 673 #endif 682 674 #if H_3D_VSP 683 675 rpcTempCU->setDvInfoSubParts(DvInfo, 0, uiDepth); 684 676 #endif 685 677 686 678 #if H_3D_DBBP 687 if( rpcTempCU->getSlice()->getDepthBasedBlkPartFlag() && rpcTempCU->getSlice()->getDefaultRefViewIdxAvailableFlag() )688 {689 xCheckRDCostInterDBBP( rpcBestCU, rpcTempCU, false );690 rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode );679 if( rpcTempCU->getSlice()->getDepthBasedBlkPartFlag() && rpcTempCU->getSlice()->getDefaultRefViewIdxAvailableFlag() ) 680 { 681 xCheckRDCostInterDBBP( rpcBestCU, rpcTempCU, false ); 682 rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode ); 691 683 #if H_3D_VSP 692 rpcTempCU->setDvInfoSubParts(DvInfo, 0, uiDepth); 693 #endif 694 } 695 #endif 696 684 rpcTempCU->setDvInfoSubParts(DvInfo, 0, uiDepth); 685 #endif 686 } 687 #endif 697 688 if(m_pcEncCfg->getUseCbfFastMode()) 698 689 { 699 690 doNotBlockPu = rpcBestCU->getQtRootCbf( 0 ) != 0; 700 691 } 701 }692 } 702 693 #if H_3D_IC 703 694 } … … 730 721 } 731 722 #endif 732 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033723 #if H_3D 733 724 rpcTempCU->initEstData( uiDepth, iMinQP, isAddLowestQP ); 734 725 if( rpcBestCU->getSlice()->getDepthIntraSkipFlag() ) … … 737 728 rpcTempCU->initEstData( uiDepth, iMinQP, isAddLowestQP ); 738 729 } 739 #else740 #if H_3D_SINGLE_DEPTH741 rpcTempCU->initEstData( uiDepth, iMinQP, isAddLowestQP );742 if( rpcBestCU->getSlice()->getIntraSingleFlag() )743 {744 xCheckRDCostSingleDepth( rpcBestCU, rpcTempCU, SIZE_2Nx2N );745 rpcTempCU->initEstData( uiDepth, iMinQP, isAddLowestQP );746 }747 #endif748 730 #endif 749 731 if(!earlyDetectionSkipMode) … … 1058 1040 // speedup for inter frames 1059 1041 if( rpcBestCU->getSlice()->getSliceType() == I_SLICE || 1060 1061 1062 1042 rpcBestCU->getCbf( 0, TEXT_LUMA ) != 0 || 1043 rpcBestCU->getCbf( 0, TEXT_CHROMA_U ) != 0 || 1044 rpcBestCU->getCbf( 0, TEXT_CHROMA_V ) != 0 1063 1045 #if H_3D_DIM_ENC 1064 1046 || rpcBestCU->getSlice()->getIsDepth() 1065 1047 #endif 1066 1048 ) // avoid very complex intra if it is unlikely … … 1068 1050 #if H_3D_DIM 1069 1051 Bool bOnlyIVP = false; 1070 #if TICKET083_IVPFLAG_FIX1071 1052 Bool bUseIVP = true; 1072 #endif1073 1053 if( rpcBestCU->getSlice()->getIsDepth() && !(rpcBestCU->getSlice()->isIRAP()) && 1074 1075 1076 1077 1054 rpcBestCU->getSlice()->getSliceType() != I_SLICE && 1055 rpcBestCU->getCbf( 0, TEXT_LUMA ) == 0 && 1056 rpcBestCU->getCbf( 0, TEXT_CHROMA_U ) == 0 && 1057 rpcBestCU->getCbf( 0, TEXT_CHROMA_V ) == 0 1078 1058 ) 1079 1059 { 1080 1060 bOnlyIVP = true; 1081 #if TICKET083_IVPFLAG_FIX1082 1061 bUseIVP = rpcBestCU->getSlice()->getIntraContourFlag(); 1083 #endif1084 1062 } 1085 #if TICKET083_IVPFLAG_FIX1086 1063 if( bUseIVP ) 1087 1064 { 1088 #endif 1089 xCheckRDCostIntra( rpcBestCU, rpcTempCU, SIZE_2Nx2N, bOnlyIVP ); 1065 xCheckRDCostIntra( rpcBestCU, rpcTempCU, SIZE_2Nx2N, bOnlyIVP ); 1090 1066 #else 1091 1067 xCheckRDCostIntra( rpcBestCU, rpcTempCU, SIZE_2Nx2N ); … … 1120 1096 #endif 1121 1097 } 1122 #if TICKET083_IVPFLAG_FIX1098 #if H_3D 1123 1099 } 1124 1100 #endif 1125 1101 } 1126 1102 // test PCM 1127 1103 if(pcPic->getSlice(0)->getSPS()->getUsePCM() … … 1607 1583 return; 1608 1584 } 1609 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331585 #if H_3D 1610 1586 m_pcEntropyCoder->encodeDIS( pcCU, uiAbsPartIdx ); 1611 1587 if(!pcCU->getDISFlag(uiAbsPartIdx)) 1612 1588 { 1613 #else 1614 #if H_3D_SINGLE_DEPTH 1615 m_pcEntropyCoder->encodeSingleDepthMode( pcCU, uiAbsPartIdx ); 1616 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx)) 1617 { 1618 #endif 1619 #endif 1589 #endif 1590 1620 1591 m_pcEntropyCoder->encodePredMode( pcCU, uiAbsPartIdx ); 1621 1592 1622 1593 m_pcEntropyCoder->encodePartSize( pcCU, uiAbsPartIdx, uiDepth ); 1623 1594 1624 #if !HHI_MOVE_SYN_K00521625 #if H_3D_DIM_SDC1626 m_pcEntropyCoder->encodeSDCFlag( pcCU, uiAbsPartIdx, false );1627 #endif1628 #endif1629 1595 if (pcCU->isIntra( uiAbsPartIdx ) && pcCU->getPartitionSize( uiAbsPartIdx ) == SIZE_2Nx2N ) 1630 1596 { … … 1632 1598 if(pcCU->getIPCMFlag(uiAbsPartIdx)) 1633 1599 { 1634 #if HHI_MOVE_SYN_K00521635 1600 #if H_3D_DIM_SDC 1636 1601 m_pcEntropyCoder->encodeSDCFlag( pcCU, uiAbsPartIdx, false ); 1637 1602 #endif 1638 #endif1639 1603 // Encode slice finish 1640 1604 finishCU(pcCU,uiAbsPartIdx,uiDepth); … … 1645 1609 // prediction Info ( Intra : direction mode, Inter : Mv, reference idx ) 1646 1610 m_pcEntropyCoder->encodePredInfo( pcCU, uiAbsPartIdx ); 1647 #if H HI_MOVE_SYN_K00521611 #if H_3D 1648 1612 m_pcEntropyCoder->encodeDBBPFlag( pcCU, uiAbsPartIdx ); 1613 #endif 1649 1614 #if H_3D_DIM_SDC 1650 1615 m_pcEntropyCoder->encodeSDCFlag( pcCU, uiAbsPartIdx, false ); 1651 1616 #endif 1652 #endif1653 1617 #if H_3D_ARP 1654 1618 m_pcEntropyCoder->encodeARPW( pcCU , uiAbsPartIdx ); … … 1665 1629 #endif 1666 1630 setdQPFlag( bCodeDQP ); 1667 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 1668 } 1669 #else 1670 #if H_3D_SINGLE_DEPTH 1671 } 1672 #endif 1631 #if H_3D 1632 } 1673 1633 #endif 1674 1634 // --- write terminating bit --- … … 1817 1777 Bool bICFlag = rpcTempCU->getICFlag( 0 ); 1818 1778 #endif 1819 #if H_3D_VSO // M1 //nece ccary here?1779 #if H_3D_VSO // M1 //necessary here? 1820 1780 if( m_pcRdCost->getUseRenModel() ) 1821 1781 { … … 1889 1849 #if H_3D_ARP 1890 1850 Int nARPWMax = rpcTempCU->getSlice()->getARPStepNum() - 1; 1891 #if SEC_ARP_REM_ENC_RESTRICT_K00351892 1851 if( nARPWMax < 0 || bICFlag ) 1893 #else1894 if( nARPWMax < 0 || !rpcTempCU->getDvInfo(0).bDV || bICFlag )1895 #endif1896 1852 { 1897 1853 nARPWMax = 0; … … 1946 1902 { 1947 1903 #if H_3D_IC 1948 if( rpcTempCU->getSlice()->getApplyIC() && rpcTempCU->getSlice()->getIcSkipParseFlag() ) 1904 if( rpcTempCU->getSlice()->getApplyIC() && rpcTempCU->getSlice()->getIcSkipParseFlag() ) 1905 { 1906 if( bICFlag && uiMergeCand == 0 ) 1949 1907 { 1950 if( bICFlag && uiMergeCand == 0 ) 1951 { 1952 continue; 1953 } 1908 continue; 1954 1909 } 1955 #endif 1956 if(!(uiNoResidual==1 && mergeCandBuffer[uiMergeCand]==1)) 1957 { 1910 } 1911 #endif 1912 if(!(uiNoResidual==1 && mergeCandBuffer[uiMergeCand]==1)) 1913 { 1958 1914 if( !(bestIsSkip && uiNoResidual == 0) ) 1959 1915 { … … 1994 1950 #if H_3D_VSP 1995 1951 { 1996 if ( vspFlag[uiMergeCand] ) 1997 { 1998 UInt partAddr; 1999 Int vspSize; 2000 Int width, height; 2001 rpcTempCU->getPartIndexAndSize( 0, partAddr, width, height ); 2002 if( uhInterDirNeighbours[ uiMergeCand ] & 0x01 ) 1952 if ( vspFlag[uiMergeCand] ) 2003 1953 { 2004 rpcTempCU->setMvFieldPUForVSP( rpcTempCU, partAddr, width, height, REF_PIC_LIST_0, cMvFieldNeighbours[ 2*uiMergeCand + 0 ].getRefIdx(), vspSize ); 2005 rpcTempCU->setVSPFlag( partAddr, vspSize ); 1954 UInt partAddr; 1955 Int vspSize; 1956 Int width, height; 1957 rpcTempCU->getPartIndexAndSize( 0, partAddr, width, height ); 1958 if( uhInterDirNeighbours[ uiMergeCand ] & 0x01 ) 1959 { 1960 rpcTempCU->setMvFieldPUForVSP( rpcTempCU, partAddr, width, height, REF_PIC_LIST_0, cMvFieldNeighbours[ 2*uiMergeCand + 0 ].getRefIdx(), vspSize ); 1961 rpcTempCU->setVSPFlag( partAddr, vspSize ); 1962 } 1963 else 1964 { 1965 rpcTempCU->getCUMvField( REF_PIC_LIST_0 )->setAllMvField( cMvFieldNeighbours[0 + 2*uiMergeCand], SIZE_2Nx2N, 0, 0 ); // interprets depth relative to rpcTempCU level 1966 } 1967 if( uhInterDirNeighbours[ uiMergeCand ] & 0x02 ) 1968 { 1969 rpcTempCU->setMvFieldPUForVSP( rpcTempCU, partAddr, width, height, REF_PIC_LIST_1 , cMvFieldNeighbours[ 2*uiMergeCand + 1 ].getRefIdx(), vspSize ); 1970 rpcTempCU->setVSPFlag( partAddr, vspSize ); 1971 } 1972 else 1973 { 1974 rpcTempCU->getCUMvField( REF_PIC_LIST_1 )->setAllMvField( cMvFieldNeighbours[1 + 2*uiMergeCand], SIZE_2Nx2N, 0, 0 ); // interprets depth relative to rpcTempCU level 1975 } 1976 rpcTempCU->setInterDirSubParts( uhInterDirNeighbours[uiMergeCand], 0, 0, uhDepth ); // interprets depth relative to LCU level 2006 1977 } 2007 1978 else 2008 1979 { 1980 #endif 1981 rpcTempCU->setInterDirSubParts( uhInterDirNeighbours[uiMergeCand], 0, 0, uhDepth ); // interprets depth relative to LCU level 2009 1982 rpcTempCU->getCUMvField( REF_PIC_LIST_0 )->setAllMvField( cMvFieldNeighbours[0 + 2*uiMergeCand], SIZE_2Nx2N, 0, 0 ); // interprets depth relative to rpcTempCU level 1983 rpcTempCU->getCUMvField( REF_PIC_LIST_1 )->setAllMvField( cMvFieldNeighbours[1 + 2*uiMergeCand], SIZE_2Nx2N, 0, 0 ); // interprets depth relative to rpcTempCU level 1984 #if H_3D_VSP 2010 1985 } 2011 if( uhInterDirNeighbours[ uiMergeCand ] & 0x02 )2012 {2013 rpcTempCU->setMvFieldPUForVSP( rpcTempCU, partAddr, width, height, REF_PIC_LIST_1 , cMvFieldNeighbours[ 2*uiMergeCand + 1 ].getRefIdx(), vspSize );2014 rpcTempCU->setVSPFlag( partAddr, vspSize );2015 }2016 else2017 {2018 rpcTempCU->getCUMvField( REF_PIC_LIST_1 )->setAllMvField( cMvFieldNeighbours[1 + 2*uiMergeCand], SIZE_2Nx2N, 0, 0 ); // interprets depth relative to rpcTempCU level2019 }2020 rpcTempCU->setInterDirSubParts( uhInterDirNeighbours[uiMergeCand], 0, 0, uhDepth ); // interprets depth relative to LCU level2021 1986 } 2022 else 1987 #endif 1988 // do MC 1989 m_pcPredSearch->motionCompensation ( rpcTempCU, m_ppcPredYuvTemp[uhDepth] ); 1990 // estimate residual and encode everything 1991 #if H_3D_VSO //M2 1992 if( m_pcRdCost->getUseRenModel() ) 1993 { //Reset 1994 UInt uiWidth = m_ppcOrigYuv[uhDepth]->getWidth (); 1995 UInt uiHeight = m_ppcOrigYuv[uhDepth]->getHeight (); 1996 Pel* piSrc = m_ppcOrigYuv[uhDepth]->getLumaAddr (); 1997 UInt uiSrcStride = m_ppcOrigYuv[uhDepth]->getStride (); 1998 m_pcRdCost->setRenModelData( rpcTempCU, 0, piSrc, uiSrcStride, uiWidth, uiHeight ); 1999 } 2000 #endif 2001 m_pcPredSearch->encodeResAndCalcRdInterCU( rpcTempCU, 2002 m_ppcOrigYuv [uhDepth], 2003 m_ppcPredYuvTemp[uhDepth], 2004 m_ppcResiYuvTemp[uhDepth], 2005 m_ppcResiYuvBest[uhDepth], 2006 m_ppcRecoYuvTemp[uhDepth], 2007 (uiNoResidual? true:false)); 2008 2009 2010 if ( uiNoResidual == 0 && rpcTempCU->getQtRootCbf(0) == 0 ) 2023 2011 { 2024 #endif 2025 rpcTempCU->setInterDirSubParts( uhInterDirNeighbours[uiMergeCand], 0, 0, uhDepth ); // interprets depth relative to LCU level 2026 rpcTempCU->getCUMvField( REF_PIC_LIST_0 )->setAllMvField( cMvFieldNeighbours[0 + 2*uiMergeCand], SIZE_2Nx2N, 0, 0 ); // interprets depth relative to rpcTempCU level 2027 rpcTempCU->getCUMvField( REF_PIC_LIST_1 )->setAllMvField( cMvFieldNeighbours[1 + 2*uiMergeCand], SIZE_2Nx2N, 0, 0 ); // interprets depth relative to rpcTempCU level 2028 #if H_3D_VSP 2012 // If no residual when allowing for one, then set mark to not try case where residual is forced to 0 2013 mergeCandBuffer[uiMergeCand] = 1; 2029 2014 } 2030 }2031 #endif2032 // do MC2033 m_pcPredSearch->motionCompensation ( rpcTempCU, m_ppcPredYuvTemp[uhDepth] );2034 // estimate residual and encode everything2035 #if H_3D_VSO //M22036 if( m_pcRdCost->getUseRenModel() )2037 { //Reset2038 UInt uiWidth = m_ppcOrigYuv[uhDepth]->getWidth ();2039 UInt uiHeight = m_ppcOrigYuv[uhDepth]->getHeight ();2040 Pel* piSrc = m_ppcOrigYuv[uhDepth]->getLumaAddr ();2041 UInt uiSrcStride = m_ppcOrigYuv[uhDepth]->getStride ();2042 m_pcRdCost->setRenModelData( rpcTempCU, 0, piSrc, uiSrcStride, uiWidth, uiHeight );2043 }2044 #endif2045 m_pcPredSearch->encodeResAndCalcRdInterCU( rpcTempCU,2046 m_ppcOrigYuv [uhDepth],2047 m_ppcPredYuvTemp[uhDepth],2048 m_ppcResiYuvTemp[uhDepth],2049 m_ppcResiYuvBest[uhDepth],2050 m_ppcRecoYuvTemp[uhDepth],2051 (uiNoResidual? true:false));2052 2053 2054 if ( uiNoResidual == 0 && rpcTempCU->getQtRootCbf(0) == 0 )2055 {2056 // If no residual when allowing for one, then set mark to not try case where residual is forced to 02057 mergeCandBuffer[uiMergeCand] = 1;2058 }2059 2015 2060 2016 rpcTempCU->setSkipFlagSubParts( rpcTempCU->getQtRootCbf(0) == 0, 0, uhDepth ); 2061 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332017 #if H_3D 2062 2018 rpcTempCU->setDISFlagSubParts( false, 0, uhDepth ); 2063 #else2064 #if H_3D_SINGLE_DEPTH2065 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uhDepth );2066 #endif2067 2019 #endif 2068 2020 #if H_3D_VSP // possible bug fix … … 2105 2057 } 2106 2058 rpcTempCU->setSkipFlagSubParts( false, 0, uhDepth ); 2107 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332059 #if H_3D 2108 2060 rpcTempCU->setDISFlagSubParts( false, 0, uhDepth ); 2109 #else2110 #if H_3D_SINGLE_DEPTH2111 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uhDepth );2112 #endif2113 2061 #endif 2114 2062 rpcTempCU->setTrIdxSubParts( 0, 0, uhDepth ); … … 2152 2100 rpcTempCU->initEstData( uhDepth, orgQP, bTransquantBypassFlag ); 2153 2101 2154 if( m_pcEncCfg->getUseFastDecisionForMerge() && !bestIsSkip ) 2102 if( m_pcEncCfg->getUseFastDecisionForMerge() && !bestIsSkip ) 2103 { 2104 #if H_3D_INTER_SDC 2105 if( rpcTempCU->getSlice()->getInterSdcFlag() ) 2106 { 2107 bestIsSkip = !rpcBestCU->getSDCFlag( 0 ) && ( rpcBestCU->getQtRootCbf(0) == 0 ); 2108 } 2109 else 2110 { 2111 #endif 2112 bestIsSkip = rpcBestCU->getQtRootCbf(0) == 0; 2113 #if H_3D_INTER_SDC 2114 } 2115 #endif 2116 } 2117 } 2118 } 2119 } 2120 2121 if(uiNoResidual == 0 && m_pcEncCfg->getUseEarlySkipDetection()) 2122 { 2123 if(rpcBestCU->getQtRootCbf( 0 ) == 0) 2155 2124 { 2156 #if H_3D_INTER_SDC 2157 if( rpcTempCU->getSlice()->getInterSdcFlag() ) 2125 if( rpcBestCU->getMergeFlag( 0 )) 2158 2126 { 2159 bestIsSkip = !rpcBestCU->getSDCFlag( 0 ) && ( rpcBestCU->getQtRootCbf(0) == 0 );2127 *earlyDetectionSkipMode = true; 2160 2128 } 2161 2129 else 2162 2130 { 2163 #endif 2164 bestIsSkip = rpcBestCU->getQtRootCbf(0) == 0; 2165 #if H_3D_INTER_SDC 2166 } 2167 #endif 2168 } 2169 } 2170 } 2171 } 2172 2173 if(uiNoResidual == 0 && m_pcEncCfg->getUseEarlySkipDetection()) 2174 { 2175 if(rpcBestCU->getQtRootCbf( 0 ) == 0) 2176 { 2177 if( rpcBestCU->getMergeFlag( 0 )) 2178 { 2179 *earlyDetectionSkipMode = true; 2180 } 2181 else 2182 { 2183 Int absoulte_MV=0; 2184 for ( UInt uiRefListIdx = 0; uiRefListIdx < 2; uiRefListIdx++ ) 2185 { 2186 if ( rpcBestCU->getSlice()->getNumRefIdx( RefPicList( uiRefListIdx ) ) > 0 ) 2131 Int absoulte_MV=0; 2132 for ( UInt uiRefListIdx = 0; uiRefListIdx < 2; uiRefListIdx++ ) 2187 2133 { 2188 TComCUMvField* pcCUMvField = rpcBestCU->getCUMvField(RefPicList( uiRefListIdx )); 2189 Int iHor = pcCUMvField->getMvd( 0 ).getAbsHor(); 2190 Int iVer = pcCUMvField->getMvd( 0 ).getAbsVer(); 2191 absoulte_MV+=iHor+iVer; 2134 if ( rpcBestCU->getSlice()->getNumRefIdx( RefPicList( uiRefListIdx ) ) > 0 ) 2135 { 2136 TComCUMvField* pcCUMvField = rpcBestCU->getCUMvField(RefPicList( uiRefListIdx )); 2137 Int iHor = pcCUMvField->getMvd( 0 ).getAbsHor(); 2138 Int iVer = pcCUMvField->getMvd( 0 ).getAbsVer(); 2139 absoulte_MV+=iHor+iVer; 2140 } 2141 } 2142 2143 if(absoulte_MV == 0) 2144 { 2145 *earlyDetectionSkipMode = true; 2192 2146 } 2193 2147 } 2194 2195 if(absoulte_MV == 0)2196 {2197 *earlyDetectionSkipMode = true;2198 }2199 2148 } 2200 2149 } 2201 2150 } 2202 }2203 2151 #if H_3D_SPIVMP 2204 2152 delete[] pcMvFieldSP; … … 2221 2169 #endif 2222 2170 { 2223 2224 2171 #if H_3D 2225 2172 const Bool bTransquantBypassFlag = rpcTempCU->getCUTransquantBypass(0); … … 2229 2176 { 2230 2177 #endif 2231 UChar uhDepth = rpcTempCU->getDepth( 0 );2178 UChar uhDepth = rpcTempCU->getDepth( 0 ); 2232 2179 #if H_3D_ARP 2233 Bool bFirstTime = true; 2234 Int nARPWMax = rpcTempCU->getSlice()->getARPStepNum() - 1; 2235 #if SEC_ARP_REM_ENC_RESTRICT_K0035 2236 if( nARPWMax < 0 || ePartSize != SIZE_2Nx2N || rpcTempCU->getICFlag(0) ) 2237 #else 2238 if( nARPWMax < 0 || ePartSize != SIZE_2Nx2N || !rpcTempCU->getDvInfo(0).bDV || rpcTempCU->getICFlag(0) ) 2239 #endif 2240 { 2241 nARPWMax = 0; 2242 } 2243 2244 for( Int nARPW = 0; nARPW <= nARPWMax; nARPW++ ) 2245 { 2246 if( !bFirstTime && rpcTempCU->getSlice()->getIvResPredFlag() ) 2247 { 2248 rpcTempCU->initEstData( rpcTempCU->getDepth(0), rpcTempCU->getQP(0),bTransquantBypassFlag ); 2249 } 2250 #endif 2251 #if H_3D_VSO // M3 2252 if( m_pcRdCost->getUseRenModel() ) 2253 { 2254 UInt uiWidth = m_ppcOrigYuv[uhDepth]->getWidth ( ); 2255 UInt uiHeight = m_ppcOrigYuv[uhDepth]->getHeight( ); 2256 Pel* piSrc = m_ppcOrigYuv[uhDepth]->getLumaAddr( ); 2257 UInt uiSrcStride = m_ppcOrigYuv[uhDepth]->getStride(); 2258 m_pcRdCost->setRenModelData( rpcTempCU, 0, piSrc, uiSrcStride, uiWidth, uiHeight ); 2259 } 2260 #endif 2261 2262 rpcTempCU->setDepthSubParts( uhDepth, 0 ); 2263 2264 rpcTempCU->setSkipFlagSubParts( false, 0, uhDepth ); 2265 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 2266 rpcTempCU->setDISFlagSubParts( false, 0, uhDepth ); 2267 #else 2268 #if H_3D_SINGLE_DEPTH 2269 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uhDepth ); 2270 #endif 2271 #endif 2272 rpcTempCU->setPartSizeSubParts ( ePartSize, 0, uhDepth ); 2273 rpcTempCU->setPredModeSubParts ( MODE_INTER, 0, uhDepth ); 2274 2275 #if H_3D_ARP 2276 rpcTempCU->setARPWSubParts( (UChar)nARPW , 0 , uhDepth ); 2277 #endif 2278 2279 #if H_3D_ARP 2280 if( bFirstTime == false && nARPWMax ) 2281 { 2282 rpcTempCU->copyPartFrom( m_ppcWeightedTempCU[uhDepth] , 0 , uhDepth ); 2283 rpcTempCU->setARPWSubParts( (UChar)nARPW , 0 , uhDepth ); 2284 2285 m_pcPredSearch->motionCompensation( rpcTempCU , m_ppcPredYuvTemp[uhDepth] ); 2286 } 2287 else 2288 { 2289 bFirstTime = false; 2290 #endif 2291 #if AMP_MRG 2292 rpcTempCU->setMergeAMP (true); 2293 #if H_3D_FAST_TEXTURE_ENCODING 2294 m_pcPredSearch->predInterSearch ( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcRecoYuvTemp[uhDepth], bFMD, false, bUseMRG ); 2295 #else 2296 m_pcPredSearch->predInterSearch ( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcRecoYuvTemp[uhDepth], false, bUseMRG ); 2297 #endif 2298 #else 2299 m_pcPredSearch->predInterSearch ( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcRecoYuvTemp[uhDepth] ); 2300 #endif 2301 #if H_3D_ARP 2302 if( nARPWMax ) 2303 { 2304 m_ppcWeightedTempCU[uhDepth]->copyPartFrom( rpcTempCU , 0 , uhDepth ); 2305 } 2306 } 2307 #endif 2308 2309 #if AMP_MRG 2310 if ( !rpcTempCU->getMergeAMP() ) 2311 { 2312 #if H_3D_ARP 2313 if( nARPWMax ) 2314 { 2315 continue; 2316 } 2317 else 2318 #endif 2319 return; 2320 } 2321 #endif 2322 2323 #if KWU_RC_MADPRED_E0227 2324 if ( m_pcEncCfg->getUseRateCtrl() && m_pcEncCfg->getLCULevelRC() && ePartSize == SIZE_2Nx2N && uhDepth <= m_addSADDepth ) 2325 { 2326 UInt SAD = m_pcRdCost->getSADPart( g_bitDepthY, m_ppcPredYuvTemp[uhDepth]->getLumaAddr(), m_ppcPredYuvTemp[uhDepth]->getStride(), 2327 m_ppcOrigYuv[uhDepth]->getLumaAddr(), m_ppcOrigYuv[uhDepth]->getStride(), 2328 rpcTempCU->getWidth(0), rpcTempCU->getHeight(0) ); 2329 m_temporalSAD = (Int)SAD; 2330 } 2331 #endif 2332 m_pcPredSearch->encodeResAndCalcRdInterCU( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcResiYuvBest[uhDepth], m_ppcRecoYuvTemp[uhDepth], false ); 2333 #if H_3D_VSP // possible bug fix 2334 if( rpcTempCU->getQtRootCbf(0)==0 ) 2335 { 2336 rpcTempCU->setTrIdxSubParts(0, 0, uhDepth); 2337 } 2338 #endif 2339 #if H_3D_VSO // M4 2340 if( m_pcRdCost->getUseLambdaScaleVSO() ) 2341 rpcTempCU->getTotalCost() = m_pcRdCost->calcRdCostVSO( rpcTempCU->getTotalBits(), rpcTempCU->getTotalDistortion() ); 2342 else 2343 #endif 2344 rpcTempCU->getTotalCost() = m_pcRdCost->calcRdCost( rpcTempCU->getTotalBits(), rpcTempCU->getTotalDistortion() ); 2345 #if H_3D_INTER_SDC 2346 TComDataCU *rpcTempCUPre = rpcTempCU; 2347 #endif 2348 xCheckDQP( rpcTempCU ); 2349 xCheckBestMode(rpcBestCU, rpcTempCU, uhDepth); 2350 #if H_3D_INTER_SDC 2351 if( rpcTempCU->getSlice()->getInterSdcFlag() && ePartSize == SIZE_2Nx2N) 2352 { 2353 Double dOffsetCost[3] = {MAX_DOUBLE,MAX_DOUBLE,MAX_DOUBLE}; 2354 for( Int uiOffest = 1 ; uiOffest <= 5 ; uiOffest++ ) 2355 { 2356 if( uiOffest > 3) 2180 Bool bFirstTime = true; 2181 Int nARPWMax = rpcTempCU->getSlice()->getARPStepNum() - 1; 2182 if( nARPWMax < 0 || ePartSize != SIZE_2Nx2N || rpcTempCU->getICFlag(0) ) 2183 { 2184 nARPWMax = 0; 2185 } 2186 2187 for( Int nARPW = 0; nARPW <= nARPWMax; nARPW++ ) 2188 { 2189 if( !bFirstTime && rpcTempCU->getSlice()->getIvResPredFlag() ) 2357 2190 { 2358 if ( dOffsetCost[0] < (0.9*dOffsetCost[1]) && dOffsetCost[0] < (0.9*dOffsetCost[2]) ) 2359 { 2360 continue; 2361 } 2362 if ( dOffsetCost[1] < dOffsetCost[0] && dOffsetCost[0] < dOffsetCost[2] && uiOffest == 5) 2363 { 2364 continue; 2365 } 2366 if ( dOffsetCost[0] < dOffsetCost[1] && dOffsetCost[2] < dOffsetCost[0] && uiOffest == 4) 2367 { 2368 continue; 2369 } 2191 rpcTempCU->initEstData( rpcTempCU->getDepth(0), rpcTempCU->getQP(0),bTransquantBypassFlag ); 2370 2192 } 2371 2372 if( rpcTempCU != rpcTempCUPre ) 2373 { 2374 Int orgQP = rpcBestCU->getQP( 0 ); 2375 rpcTempCU->initEstData( uhDepth, orgQP ,bTransquantBypassFlag ); 2376 rpcTempCU->copyPartFrom( rpcBestCU, 0, uhDepth ); 2377 } 2378 rpcTempCU->setSkipFlagSubParts( false, 0, uhDepth ); 2379 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 2380 rpcTempCU->setDISFlagSubParts( false, 0, uhDepth ); 2381 #else 2382 #if H_3D_SINGLE_DEPTH 2383 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uhDepth ); 2384 #endif 2385 #endif 2386 rpcTempCU->setTrIdxSubParts( 0, 0, uhDepth ); 2387 rpcTempCU->setCbfSubParts( 1, 1, 1, 0, uhDepth ); 2193 #endif 2388 2194 #if H_3D_VSO // M3 2389 2195 if( m_pcRdCost->getUseRenModel() ) … … 2397 2203 #endif 2398 2204 2399 Int iSdcOffset = 0; 2400 if(uiOffest % 2 == 0) 2205 rpcTempCU->setDepthSubParts( uhDepth, 0 ); 2206 2207 rpcTempCU->setSkipFlagSubParts( false, 0, uhDepth ); 2208 #if H_3D 2209 rpcTempCU->setDISFlagSubParts( false, 0, uhDepth ); 2210 #endif 2211 rpcTempCU->setPartSizeSubParts ( ePartSize, 0, uhDepth ); 2212 rpcTempCU->setPredModeSubParts ( MODE_INTER, 0, uhDepth ); 2213 #if H_3D_ARP 2214 rpcTempCU->setARPWSubParts( (UChar)nARPW , 0 , uhDepth ); 2215 #endif 2216 #if H_3D_ARP 2217 if( bFirstTime == false && nARPWMax ) 2401 2218 { 2402 iSdcOffset = uiOffest >> 1; 2219 rpcTempCU->copyPartFrom( m_ppcWeightedTempCU[uhDepth] , 0 , uhDepth ); 2220 rpcTempCU->setARPWSubParts( (UChar)nARPW , 0 , uhDepth ); 2221 2222 m_pcPredSearch->motionCompensation( rpcTempCU , m_ppcPredYuvTemp[uhDepth] ); 2403 2223 } 2404 2224 else 2405 2225 { 2406 iSdcOffset = -1 * (uiOffest >> 1); 2226 bFirstTime = false; 2227 #endif 2228 #if AMP_MRG 2229 rpcTempCU->setMergeAMP (true); 2230 #if H_3D_FAST_TEXTURE_ENCODING 2231 m_pcPredSearch->predInterSearch ( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcRecoYuvTemp[uhDepth], bFMD, false, bUseMRG ); 2232 #else 2233 m_pcPredSearch->predInterSearch ( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcRecoYuvTemp[uhDepth], false, bUseMRG ); 2234 #endif 2235 #else 2236 m_pcPredSearch->predInterSearch ( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcRecoYuvTemp[uhDepth] ); 2237 #endif 2238 #if H_3D_ARP 2239 if( nARPWMax ) 2240 { 2241 m_ppcWeightedTempCU[uhDepth]->copyPartFrom( rpcTempCU , 0 , uhDepth ); 2242 } 2407 2243 } 2408 m_pcPredSearch->encodeResAndCalcRdInterSDCCU( rpcTempCU, 2409 m_ppcOrigYuv[uhDepth], 2410 ( rpcTempCU != rpcTempCUPre ) ? m_ppcPredYuvBest[uhDepth] : m_ppcPredYuvTemp[uhDepth], 2411 m_ppcResiYuvTemp[uhDepth], 2412 m_ppcRecoYuvTemp[uhDepth], 2413 iSdcOffset, 2414 uhDepth ); 2415 if (uiOffest <= 3 ) 2244 #endif 2245 2246 #if AMP_MRG 2247 if ( !rpcTempCU->getMergeAMP() ) 2416 2248 { 2417 dOffsetCost [uiOffest -1] = rpcTempCU->getTotalCost(); 2249 #if H_3D_ARP 2250 if( nARPWMax ) 2251 { 2252 continue; 2253 } 2254 else 2255 #endif 2256 return; 2418 2257 } 2419 2258 #endif 2259 2260 #if KWU_RC_MADPRED_E0227 2261 if ( m_pcEncCfg->getUseRateCtrl() && m_pcEncCfg->getLCULevelRC() && ePartSize == SIZE_2Nx2N && uhDepth <= m_addSADDepth ) 2262 { 2263 UInt SAD = m_pcRdCost->getSADPart( g_bitDepthY, m_ppcPredYuvTemp[uhDepth]->getLumaAddr(), m_ppcPredYuvTemp[uhDepth]->getStride(), 2264 m_ppcOrigYuv[uhDepth]->getLumaAddr(), m_ppcOrigYuv[uhDepth]->getStride(), 2265 rpcTempCU->getWidth(0), rpcTempCU->getHeight(0) ); 2266 m_temporalSAD = (Int)SAD; 2267 } 2268 #endif 2269 m_pcPredSearch->encodeResAndCalcRdInterCU( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcResiYuvBest[uhDepth], m_ppcRecoYuvTemp[uhDepth], false ); 2270 #if H_3D_VSP // possible bug fix 2271 if( rpcTempCU->getQtRootCbf(0)==0 ) 2272 { 2273 rpcTempCU->setTrIdxSubParts(0, 0, uhDepth); 2274 } 2275 #endif 2276 #if H_3D_VSO // M4 2277 if( m_pcRdCost->getUseLambdaScaleVSO() ) 2278 rpcTempCU->getTotalCost() = m_pcRdCost->calcRdCostVSO( rpcTempCU->getTotalBits(), rpcTempCU->getTotalDistortion() ); 2279 else 2280 #endif 2281 rpcTempCU->getTotalCost() = m_pcRdCost->calcRdCost( rpcTempCU->getTotalBits(), rpcTempCU->getTotalDistortion() ); 2282 #if H_3D_INTER_SDC 2283 TComDataCU *rpcTempCUPre = rpcTempCU; 2284 #endif 2420 2285 xCheckDQP( rpcTempCU ); 2421 2286 xCheckBestMode(rpcBestCU, rpcTempCU, uhDepth); 2422 } 2423 2424 } 2287 #if H_3D_INTER_SDC 2288 if( rpcTempCU->getSlice()->getInterSdcFlag() && ePartSize == SIZE_2Nx2N) 2289 { 2290 Double dOffsetCost[3] = {MAX_DOUBLE,MAX_DOUBLE,MAX_DOUBLE}; 2291 for( Int uiOffest = 1 ; uiOffest <= 5 ; uiOffest++ ) 2292 { 2293 if( uiOffest > 3) 2294 { 2295 if ( dOffsetCost[0] < (0.9*dOffsetCost[1]) && dOffsetCost[0] < (0.9*dOffsetCost[2]) ) 2296 { 2297 continue; 2298 } 2299 if ( dOffsetCost[1] < dOffsetCost[0] && dOffsetCost[0] < dOffsetCost[2] && uiOffest == 5) 2300 { 2301 continue; 2302 } 2303 if ( dOffsetCost[0] < dOffsetCost[1] && dOffsetCost[2] < dOffsetCost[0] && uiOffest == 4) 2304 { 2305 continue; 2306 } 2307 } 2308 2309 if( rpcTempCU != rpcTempCUPre ) 2310 { 2311 Int orgQP = rpcBestCU->getQP( 0 ); 2312 rpcTempCU->initEstData( uhDepth, orgQP ,bTransquantBypassFlag ); 2313 rpcTempCU->copyPartFrom( rpcBestCU, 0, uhDepth ); 2314 } 2315 rpcTempCU->setSkipFlagSubParts( false, 0, uhDepth ); 2316 #if H_3D 2317 rpcTempCU->setDISFlagSubParts( false, 0, uhDepth ); 2318 #endif 2319 rpcTempCU->setTrIdxSubParts( 0, 0, uhDepth ); 2320 rpcTempCU->setCbfSubParts( 1, 1, 1, 0, uhDepth ); 2321 #if H_3D_VSO // M3 2322 if( m_pcRdCost->getUseRenModel() ) 2323 { 2324 UInt uiWidth = m_ppcOrigYuv[uhDepth]->getWidth ( ); 2325 UInt uiHeight = m_ppcOrigYuv[uhDepth]->getHeight( ); 2326 Pel* piSrc = m_ppcOrigYuv[uhDepth]->getLumaAddr( ); 2327 UInt uiSrcStride = m_ppcOrigYuv[uhDepth]->getStride(); 2328 m_pcRdCost->setRenModelData( rpcTempCU, 0, piSrc, uiSrcStride, uiWidth, uiHeight ); 2329 } 2330 #endif 2331 2332 Int iSdcOffset = 0; 2333 if(uiOffest % 2 == 0) 2334 { 2335 iSdcOffset = uiOffest >> 1; 2336 } 2337 else 2338 { 2339 iSdcOffset = -1 * (uiOffest >> 1); 2340 } 2341 m_pcPredSearch->encodeResAndCalcRdInterSDCCU( rpcTempCU, 2342 m_ppcOrigYuv[uhDepth], 2343 ( rpcTempCU != rpcTempCUPre ) ? m_ppcPredYuvBest[uhDepth] : m_ppcPredYuvTemp[uhDepth], 2344 m_ppcResiYuvTemp[uhDepth], 2345 m_ppcRecoYuvTemp[uhDepth], 2346 iSdcOffset, 2347 uhDepth ); 2348 if (uiOffest <= 3 ) 2349 { 2350 dOffsetCost [uiOffest -1] = rpcTempCU->getTotalCost(); 2351 } 2352 2353 xCheckDQP( rpcTempCU ); 2354 xCheckBestMode(rpcBestCU, rpcTempCU, uhDepth); 2355 } 2356 2357 } 2425 2358 #endif 2426 2359 #if H_3D_ARP 2427 }2360 } 2428 2361 #endif 2429 2362 #if H_3D_FAST_TEXTURE_ENCODING … … 2492 2425 } 2493 2426 2494 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332495 2427 Void TEncCu::xCheckRDCostDIS( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize eSize ) 2496 2428 { … … 2564 2496 xCheckBestMode(rpcBestCU, rpcTempCU, uiDepth); 2565 2497 } 2566 #else2567 #if H_3D_SINGLE_DEPTH2568 Void TEncCu::xCheckRDCostSingleDepth( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize eSize )2569 {2570 UInt uiDepth = rpcTempCU->getDepth( 0 );2571 if( !rpcBestCU->getSlice()->getIsDepth() || (eSize != SIZE_2Nx2N))2572 {2573 return;2574 }2575 2576 #if H_3D_VSO // M52577 if( m_pcRdCost->getUseRenModel() )2578 {2579 UInt uiWidth = m_ppcOrigYuv[uiDepth]->getWidth ();2580 UInt uiHeight = m_ppcOrigYuv[uiDepth]->getHeight ();2581 Pel* piSrc = m_ppcOrigYuv[uiDepth]->getLumaAddr();2582 UInt uiSrcStride = m_ppcOrigYuv[uiDepth]->getStride ();2583 m_pcRdCost->setRenModelData( rpcTempCU, 0, piSrc, uiSrcStride, uiWidth, uiHeight );2584 }2585 #endif2586 2587 rpcTempCU->setSkipFlagSubParts( false, 0, uiDepth );2588 rpcTempCU->setPartSizeSubParts( SIZE_2Nx2N, 0, uiDepth );2589 rpcTempCU->setPredModeSubParts( MODE_INTRA, 0, uiDepth );2590 rpcTempCU->setCUTransquantBypassSubParts( rpcTempCU->getCUTransquantBypass(0), 0, uiDepth );2591 2592 rpcTempCU->setTrIdxSubParts(0, 0, uiDepth);2593 rpcTempCU->setCbfSubParts(0, 1, 1, 0, uiDepth);2594 rpcTempCU->setSingleDepthFlagSubParts(true, 0, uiDepth);2595 rpcTempCU->setLumaIntraDirSubParts (DC_IDX, 0, uiDepth);2596 #if H_3D_DIM_SDC2597 rpcTempCU->setSDCFlagSubParts( false, 0, uiDepth);2598 #endif2599 2600 UInt uiPreCalcDistC;2601 m_pcPredSearch ->estIntraPredSingleDepth ( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], uiPreCalcDistC, false );2602 2603 2604 m_ppcRecoYuvTemp[uiDepth]->copyToPicLuma(rpcTempCU->getPic()->getPicYuvRec(), rpcTempCU->getAddr(), rpcTempCU->getZorderIdxInCU() );2605 2606 2607 m_pcEntropyCoder->resetBits();2608 if ( rpcTempCU->getSlice()->getPPS()->getTransquantBypassEnableFlag())2609 {2610 m_pcEntropyCoder->encodeCUTransquantBypassFlag( rpcTempCU, 0, true );2611 }2612 m_pcEntropyCoder->encodeSkipFlag ( rpcTempCU, 0, true );2613 m_pcEntropyCoder->encodeSingleDepthMode( rpcTempCU, 0, true );2614 2615 2616 m_pcRDGoOnSbacCoder->store(m_pppcRDSbacCoder[uiDepth][CI_TEMP_BEST]);2617 2618 rpcTempCU->getTotalBits() = m_pcEntropyCoder->getNumberOfWrittenBits();2619 rpcTempCU->getTotalBins() = ((TEncBinCABAC *)((TEncSbac*)m_pcEntropyCoder->m_pcEntropyCoderIf)->getEncBinIf())->getBinsCoded();2620 2621 2622 #if H_3D_VSO // M62623 if( m_pcRdCost->getUseLambdaScaleVSO())2624 rpcTempCU->getTotalCost() = m_pcRdCost->calcRdCostVSO( rpcTempCU->getTotalBits(), rpcTempCU->getTotalDistortion() );2625 else2626 #endif2627 rpcTempCU->getTotalCost() = m_pcRdCost->calcRdCost( rpcTempCU->getTotalBits(), rpcTempCU->getTotalDistortion() );2628 2629 2630 xCheckDQP( rpcTempCU );2631 xCheckBestMode(rpcBestCU, rpcTempCU, uiDepth);2632 }2633 #endif2634 #endif2635 2498 2636 2499 Void TEncCu::xCheckRDCostInterDBBP( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, Bool bUseMRG ) … … 2675 2538 AOF( uiDepthStride != 0 ); 2676 2539 2677 #if HS_DBBP_CLEAN_K00482678 2540 PartSize eVirtualPartSize = m_pcPredSearch->getPartitionSizeFromDepth(pDepthPels, uiDepthStride, uiWidth, rpcTempCU); 2679 2541 … … 2681 2543 Bool pMask[MAX_CU_SIZE*MAX_CU_SIZE]; 2682 2544 Bool bValidMask = m_pcPredSearch->getSegmentMaskFromDepth(pDepthPels, uiDepthStride, uiWidth, uiHeight, pMask, rpcTempCU); 2683 #else2684 PartSize eVirtualPartSize = m_pcPredSearch->getPartitionSizeFromDepth(pDepthPels, uiDepthStride, uiWidth);2685 2686 // derive segmentation mask from depth2687 Bool pMask[MAX_CU_SIZE*MAX_CU_SIZE];2688 Bool bValidMask = m_pcPredSearch->getSegmentMaskFromDepth(pDepthPels, uiDepthStride, uiWidth, uiHeight, pMask);2689 #endif2690 2545 2691 2546 if( !bValidMask ) … … 2696 2551 // find optimal motion/disparity vector for each segment 2697 2552 DisInfo originalDvInfo = rpcTempCU->getDvInfo(0); 2698 D BBPTmpData* pDBBPTmpData = rpcTempCU->getDBBPTmpData();2553 DbbpTmpData* pDBBPTmpData = rpcTempCU->getDBBPTmpData(); 2699 2554 TComYuv* apPredYuv[2] = { m_ppcRecoYuvTemp[uhDepth], m_ppcPredYuvTemp[uhDepth] }; 2700 2555 … … 2777 2632 } 2778 2633 #endif 2634 2779 2635 #if H_3D_DIM 2780 2636 Void TEncCu::xCheckRDCostIntra( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize eSize, Bool bOnlyIVP ) … … 2796 2652 2797 2653 rpcTempCU->setSkipFlagSubParts( false, 0, uiDepth ); 2798 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332654 #if H_3D 2799 2655 rpcTempCU->setDISFlagSubParts( false, 0, uiDepth ); 2800 #else2801 #if H_3D_SINGLE_DEPTH2802 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uiDepth );2803 #endif2804 2656 #endif 2805 2657 rpcTempCU->setPartSizeSubParts( eSize, 0, uiDepth ); … … 2820 2672 2821 2673 #if H_3D_DIM_SDC 2822 #if 0 // H_3D_DISABLE_CHROMA2823 if( !rpcTempCU->getSDCFlag( 0 ) && !rpcTempCU->getSlice()->getIsDepth() )2824 #else2825 2674 if( !rpcTempCU->getSDCFlag( 0 ) ) 2826 2675 #endif 2827 #endif 2828 m_pcPredSearch ->estIntraPredChromaQT( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], uiPreCalcDistC ); 2676 m_pcPredSearch ->estIntraPredChromaQT( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], uiPreCalcDistC ); 2829 2677 2830 2678 m_pcEntropyCoder->resetBits(); … … 2834 2682 } 2835 2683 m_pcEntropyCoder->encodeSkipFlag ( rpcTempCU, 0, true ); 2836 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332684 #if H_3D 2837 2685 m_pcEntropyCoder->encodeDIS( rpcTempCU, 0, true ); 2838 2686 if(!rpcTempCU->getDISFlag(0)) 2839 2687 { 2840 #else 2841 #if H_3D_SINGLE_DEPTH 2842 m_pcEntropyCoder->encodeSingleDepthMode( rpcTempCU, 0, true ); 2843 if(!rpcTempCU->getSingleDepthFlag(0)) 2844 { 2845 #endif 2846 #endif 2847 m_pcEntropyCoder->encodePredMode( rpcTempCU, 0, true ); 2848 m_pcEntropyCoder->encodePartSize( rpcTempCU, 0, uiDepth, true ); 2849 #if !HHI_MOVE_SYN_K0052 2688 #endif 2689 m_pcEntropyCoder->encodePredMode( rpcTempCU, 0, true ); 2690 m_pcEntropyCoder->encodePartSize( rpcTempCU, 0, uiDepth, true ); 2691 m_pcEntropyCoder->encodePredInfo( rpcTempCU, 0, true ); 2692 m_pcEntropyCoder->encodeIPCMInfo(rpcTempCU, 0, true ); 2850 2693 #if H_3D_DIM_SDC 2851 m_pcEntropyCoder->encodeSDCFlag( rpcTempCU, 0, true ); 2852 #endif 2853 #endif 2854 m_pcEntropyCoder->encodePredInfo( rpcTempCU, 0, true ); 2855 m_pcEntropyCoder->encodeIPCMInfo(rpcTempCU, 0, true ); 2856 #if HHI_MOVE_SYN_K0052 2857 #if H_3D_DIM_SDC 2858 m_pcEntropyCoder->encodeSDCFlag( rpcTempCU, 0, true ); 2859 #endif 2860 #endif 2861 2862 // Encode Coefficients 2863 Bool bCodeDQP = getdQPFlag(); 2694 m_pcEntropyCoder->encodeSDCFlag( rpcTempCU, 0, true ); 2695 #endif 2696 2697 // Encode Coefficients 2698 Bool bCodeDQP = getdQPFlag(); 2864 2699 #if H_3D_DISABLE_CHROMA 2865 m_pcEntropyCoder->encodeCoeff( rpcTempCU, 0, uiDepth, rpcTempCU->getWidth (0), rpcTempCU->getHeight(0), bCodeDQP, true ); 2866 #else 2867 m_pcEntropyCoder->encodeCoeff( rpcTempCU, 0, uiDepth, rpcTempCU->getWidth (0), rpcTempCU->getHeight(0), bCodeDQP ); 2868 #endif 2869 2870 2871 setdQPFlag( bCodeDQP ); 2872 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 2873 } 2874 #else 2875 #if H_3D_SINGLE_DEPTH 2876 } 2877 #endif 2700 m_pcEntropyCoder->encodeCoeff( rpcTempCU, 0, uiDepth, rpcTempCU->getWidth (0), rpcTempCU->getHeight(0), bCodeDQP, true ); 2701 #else 2702 m_pcEntropyCoder->encodeCoeff( rpcTempCU, 0, uiDepth, rpcTempCU->getWidth (0), rpcTempCU->getHeight(0), bCodeDQP ); 2703 #endif 2704 setdQPFlag( bCodeDQP ); 2705 #if H_3D 2706 } 2878 2707 #endif 2879 2708 m_pcRDGoOnSbacCoder->store(m_pppcRDSbacCoder[uiDepth][CI_TEMP_BEST]); 2880 2709 2881 2710 rpcTempCU->getTotalBits() = m_pcEntropyCoder->getNumberOfWrittenBits(); 2882 2711 rpcTempCU->getTotalBins() = ((TEncBinCABAC *)((TEncSbac*)m_pcEntropyCoder->m_pcEntropyCoderIf)->getEncBinIf())->getBinsCoded(); 2883 2712 #if H_3D_VSO // M6 2884 2713 if( m_pcRdCost->getUseLambdaScaleVSO()) … … 2904 2733 2905 2734 rpcTempCU->setSkipFlagSubParts( false, 0, uiDepth ); 2906 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332735 #if H_3D 2907 2736 rpcTempCU->setDISFlagSubParts( false, 0, uiDepth ); 2908 #else2909 #if H_3D_SINGLE_DEPTH2910 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uiDepth );2911 #endif2912 2737 #endif 2913 2738 rpcTempCU->setIPCMFlag(0, true); … … 2927 2752 } 2928 2753 m_pcEntropyCoder->encodeSkipFlag ( rpcTempCU, 0, true ); 2929 #if SEC_DEPTH_INTRA_SKIP_MODE_K00332754 #if H_3D 2930 2755 m_pcEntropyCoder->encodeDIS( rpcTempCU, 0, true ); 2931 #else2932 #if H_3D_SINGLE_DEPTH2933 m_pcEntropyCoder->encodeSingleDepthMode( rpcTempCU, 0, true );2934 #endif2935 2756 #endif 2936 2757 m_pcEntropyCoder->encodePredMode ( rpcTempCU, 0, true ); 2937 2758 m_pcEntropyCoder->encodePartSize ( rpcTempCU, 0, uiDepth, true ); 2938 #if !HHI_MOVE_SYN_K0052 2759 m_pcEntropyCoder->encodeIPCMInfo ( rpcTempCU, 0, true ); 2939 2760 #if H_3D_DIM_SDC 2940 2761 m_pcEntropyCoder->encodeSDCFlag( rpcTempCU, 0, true ); 2941 #endif2942 #endif2943 m_pcEntropyCoder->encodeIPCMInfo ( rpcTempCU, 0, true );2944 #if HHI_MOVE_SYN_K00522945 #if H_3D_DIM_SDC2946 m_pcEntropyCoder->encodeSDCFlag( rpcTempCU, 0, true );2947 #endif2948 2762 #endif 2949 2763 m_pcRDGoOnSbacCoder->store(m_pppcRDSbacCoder[uiDepth][CI_TEMP_BEST]); -
trunk/source/Lib/TLibEncoder/TEncCu.h
r1179 r1196 159 159 Void xCheckRDCostInterDBBP( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, Bool bUseMRG = false ); 160 160 #endif 161 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033161 #if H_3D 162 162 Void xCheckRDCostDIS ( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize ePartSize ); 163 #else164 #if H_3D_SINGLE_DEPTH165 Void xCheckRDCostSingleDepth ( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize ePartSize );166 #endif167 163 #endif 168 164 #if H_3D_DIM -
trunk/source/Lib/TLibEncoder/TEncEntropy.cpp
r1179 r1196 111 111 m_pcEntropyCoderIf->codeSkipFlag( pcCU, uiAbsPartIdx ); 112 112 } 113 114 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 113 #if H_3D 115 114 Void TEncEntropy::encodeDIS( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD ) 116 115 { … … 125 124 m_pcEntropyCoderIf->codeDIS( pcCU, uiAbsPartIdx ); 126 125 } 127 #else 128 #if H_3D_SINGLE_DEPTH 129 Void TEncEntropy::encodeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD ) 130 { 131 if(!pcCU->getSlice()->getIntraSingleFlag() ) 132 { 133 return; 134 } 135 if( bRD ) 136 { 137 uiAbsPartIdx = 0; 138 } 139 m_pcEntropyCoderIf->codeSingleDepthMode( pcCU, uiAbsPartIdx ); 140 } 141 #endif 142 #endif 143 126 #endif 144 127 /** encode merge flag 145 128 * \param pcCU … … 271 254 m_pcEntropyCoderIf->codePartSize( pcCU, uiAbsPartIdx, uiDepth ); 272 255 273 #if !HHI_MOVE_SYN_K0052274 #if H_3D_DBBP275 if( pcCU->getSlice()->getDepthBasedBlkPartFlag() && (pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_2NxN || pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_Nx2N) && pcCU->getWidth(uiAbsPartIdx) > 8 && pcCU->getSlice()->getDefaultRefViewIdxAvailableFlag() )276 {277 encodeDBBPFlag(pcCU, uiAbsPartIdx, bRD);278 }279 #endif280 #endif281 256 } 282 257 … … 586 561 #endif 587 562 #endif 588 encodeIntraDirModeChroma( pcCU, uiAbsPartIdx, bRD );563 encodeIntraDirModeChroma( pcCU, uiAbsPartIdx, bRD ); 589 564 } 590 565 else // if it is Inter mode, encode motion vector and reference index … … 904 879 Void TEncEntropy::encodeDBBPFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD ) 905 880 { 906 #if HHI_MOVE_SYN_K0052907 881 if( pcCU->getSlice()->getDepthBasedBlkPartFlag() && 908 882 ( pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_2NxN || … … 911 885 pcCU->getSlice()->getDefaultRefViewIdxAvailableFlag() ) 912 886 { 913 #endif914 887 if( bRD ) 915 888 { … … 917 890 } 918 891 m_pcEntropyCoderIf->codeDBBPFlag( pcCU, uiAbsPartIdx ); 919 #if HHI_MOVE_SYN_K0052 920 } 921 #endif 892 } 922 893 } 923 894 #endif -
trunk/source/Lib/TLibEncoder/TEncEntropy.h
r1179 r1196 82 82 virtual Void codeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0; 83 83 virtual Void codeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0; 84 #if SEC_DEPTH_INTRA_SKIP_MODE_K003384 #if H_3D 85 85 virtual Void codeDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0; 86 #else87 #if H_3D_SINGLE_DEPTH88 virtual Void codeSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0;89 #endif90 86 #endif 91 87 virtual Void codeMergeFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0; … … 179 175 Void encodeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD = false ); 180 176 Void encodeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD = false ); 181 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033177 #if H_3D 182 178 Void encodeDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD=false ); 183 #else184 #if H_3D_SINGLE_DEPTH185 Void encodeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD=false );186 #endif187 179 #endif 188 180 Void encodePUWise ( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD = false ); -
trunk/source/Lib/TLibEncoder/TEncGOP.cpp
r1179 r1196 395 395 Void TEncGOP::initGOP( Int iPOCLast, Int iNumPicRcvd, TComList<TComPic*>& rcListPic, TComList<TComPicYuv*>& rcListPicYuvRecOut, std::list<AccessUnit>& accessUnitsInGOP) 396 396 { 397 #if H_MV_ALIGN_HM_15398 397 xInitGOP( iPOCLast, iNumPicRcvd, rcListPic, rcListPicYuvRecOut, false ); 399 #else400 xInitGOP( iPOCLast, iNumPicRcvd, rcListPic, rcListPicYuvRecOut );401 #endif402 398 m_iNumPicCoded = 0; 403 399 } … … 885 881 Int numDirectRefLayers = vps ->getNumDirectRefLayers( getLayerId() ); 886 882 #endif 887 #if H HI_INTER_COMP_PRED_K0052883 #if H_3D 888 884 pcSlice->setIvPicLists( m_ivPicLists ); 889 885 … … 893 889 GOPEntry gopEntry = m_pcCfg->getGOPEntry( (pcSlice->getRapPicFlag() && getLayerId() > 0) ? MAX_GOP : iGOPid ); 894 890 #endif 891 892 895 893 896 894 Bool interLayerPredLayerIdcPresentFlag = false; … … 929 927 assert( pcSlice->getNumActiveRefLayerPics() == gopEntry.m_numActiveRefLayerPics ); 930 928 931 #if HHI_INTER_COMP_PRED_K0052932 929 #if H_3D 933 930 if ( m_pcEncTop->decProcAnnexI() ) … … 962 959 pcSlice->setMaxNumMergeCand ( m_pcCfg->getMaxNumMergeCand() + ( ( pcSlice->getMpiFlag( ) || pcSlice->getIvMvPredFlag( ) || pcSlice->getViewSynthesisPredFlag( ) ) ? 1 : 0 )); 963 960 #endif 964 #endif965 961 966 962 pcSlice->createInterLayerReferencePictureSet( m_ivPicLists, m_refPicSetInterLayer0, m_refPicSetInterLayer1 ); … … 1009 1005 } 1010 1006 } 1011 #endif1012 #if !HHI_INTER_COMP_PRED_K00521013 #if H_3D1014 pcSlice->setIvPicLists( m_ivPicLists );1015 #if H_3D_IV_MERGE1016 assert( !m_pcEncTop->getIsDepth() || ( pcSlice->getTexturePic() != 0 ) );1017 #endif1018 #endif1019 1007 #endif 1020 1008 #if H_3D_IC -
trunk/source/Lib/TLibEncoder/TEncSbac.cpp
r1179 r1196 58 58 , m_cCUSplitFlagSCModel ( 1, 1, NUM_SPLIT_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels ) 59 59 , m_cCUSkipFlagSCModel ( 1, 1, NUM_SKIP_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels) 60 #if SEC_DEPTH_INTRA_SKIP_MODE_K003360 #if H_3D 61 61 , m_cCUDISFlagSCModel ( 1, 1, NUM_DIS_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels) 62 62 , m_cCUDISTypeSCModel ( 1, 1, NUM_DIS_TYPE_CTX , m_contextModels + m_numContextModels, m_numContextModels) 63 #else64 #if H_3D_SINGLE_DEPTH65 , m_cCUSingleDepthFlagSCModel ( 1, 1, NUM_SINGLEDEPTH_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels)66 , m_cSingleDepthValueSCModel ( 1, 1, NUM_SINGLE_DEPTH_VALUE_DATA_CTX , m_contextModels + m_numContextModels, m_numContextModels)67 #endif68 63 #endif 69 64 , m_cCUMergeFlagExtSCModel ( 1, 1, NUM_MERGE_FLAG_EXT_CTX , m_contextModels + m_numContextModels, m_numContextModels) … … 139 134 140 135 m_cCUSkipFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SKIP_FLAG ); 141 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033136 #if H_3D 142 137 m_cCUDISFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_DIS_FLAG ); 143 138 m_cCUDISTypeSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_DIS_TYPE ); 144 #else145 #if H_3D_SINGLE_DEPTH146 m_cCUSingleDepthFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLEDEPTH_FLAG );147 m_cSingleDepthValueSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA );148 #endif149 139 #endif 150 140 m_cCUMergeFlagExtSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_MERGE_FLAG_EXT); … … 224 214 curCost = m_cCUSplitFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_SPLIT_FLAG ); 225 215 curCost += m_cCUSkipFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_SKIP_FLAG ); 226 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033216 #if H_3D 227 217 curCost += m_cCUDISFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_DIS_FLAG ); 228 218 curCost += m_cCUDISTypeSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_DIS_TYPE ); 229 #else230 #if H_3D_SINGLE_DEPTH231 curCost += m_cCUSingleDepthFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_SINGLEDEPTH_FLAG );232 curCost += m_cSingleDepthValueSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA );233 #endif234 219 #endif 235 220 curCost += m_cCUMergeFlagExtSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_MERGE_FLAG_EXT); … … 270 255 curCost += m_CUTransquantBypassFlagSCModel.calcCost( curSliceType, qp, (UChar*)INIT_CU_TRANSQUANT_BYPASS_FLAG ); 271 256 #if H_3D_DIM 272 if( m_pcSlice->getIntraSdcWedgeFlag() || m_pcSlice->getIntraContourFlag() )273 {274 curCost += m_cDepthIntraModeSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_DEPTH_INTRA_MODE );275 curCost += m_cDdcFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_DDC_FLAG );276 curCost += m_cDdcDataSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_DDC_DATA );277 curCost += m_cAngleFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_ANGLE_FLAG );278 }257 if( m_pcSlice->getIntraSdcWedgeFlag() || m_pcSlice->getIntraContourFlag() ) 258 { 259 curCost += m_cDepthIntraModeSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_DEPTH_INTRA_MODE ); 260 curCost += m_cDdcFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_DDC_FLAG ); 261 curCost += m_cDdcDataSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_DDC_DATA ); 262 curCost += m_cAngleFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_ANGLE_FLAG ); 263 } 279 264 #endif 280 265 if (curCost < bestCost) … … 302 287 303 288 m_cCUSkipFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SKIP_FLAG ); 304 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033289 #if H_3D 305 290 m_cCUDISFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_DIS_FLAG ); 306 291 m_cCUDISTypeSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_DIS_TYPE ); 307 #else308 #if H_3D_SINGLE_DEPTH309 m_cCUSingleDepthFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLEDEPTH_FLAG );310 m_cSingleDepthValueSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA );311 #endif312 292 #endif 313 293 m_cCUMergeFlagExtSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_MERGE_FLAG_EXT); … … 466 446 m_pcBinIf->encodeBinsEP( bins, numBins ); 467 447 } 468 469 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 448 #if H_3D 470 449 Void TEncSbac::codeDIS( TComDataCU* pcCU, UInt uiAbsPartIdx ) 471 450 { … … 498 477 } 499 478 } 500 #else 501 #if H_3D_SINGLE_DEPTH 502 Void TEncSbac::codeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx ) 503 { 504 UInt uiSymbol = pcCU->getSingleDepthFlag(uiAbsPartIdx ) ? 1 : 0; 505 m_pcBinIf->encodeBin( uiSymbol, m_cCUSingleDepthFlagSCModel.get( 0, 0, 0 ) ); 506 if(uiSymbol) 507 { 508 UInt uiUnaryIdx = (UInt) pcCU->getSingleDepthValue(uiAbsPartIdx); 509 UInt uiNumCand = SINGLE_DEPTH_MODE_CAND_LIST_SIZE; 510 if ( uiNumCand > 1 ) 511 { 512 for( UInt ui = 0; ui < uiNumCand - 1; ++ui ) 513 { 514 const UInt uiSymbol2 = ui == uiUnaryIdx ? 0 : 1; 515 if ( ui==0 ) 516 { 517 m_pcBinIf->encodeBin( uiSymbol2, m_cSingleDepthValueSCModel.get( 0, 0, 0 ) ); 518 } 519 else 520 { 521 m_pcBinIf->encodeBinEP( uiSymbol2 ); 522 } 523 if( uiSymbol2 == 0 ) 524 { 525 break; 526 } 527 } 528 } 529 } 530 } 531 #endif 532 #endif 533 479 #endif 534 480 /** Coding of coeff_abs_level_minus3 535 481 * \param uiSymbol value of coeff_abs_level_minus3 … … 680 626 Bool bDepthMapDetect = (pcTexture != NULL); 681 627 Bool bIntraSliceDetect = (pcCU->getSlice()->getSliceType() == I_SLICE); 682 628 683 629 Bool rapPic = (pcCU->getSlice()->getNalUnitType() == NAL_UNIT_CODED_SLICE_IDR_W_RADL || pcCU->getSlice()->getNalUnitType() == NAL_UNIT_CODED_SLICE_IDR_N_LP || pcCU->getSlice()->getNalUnitType() == NAL_UNIT_CODED_SLICE_CRA); 684 630 … … 718 664 return; 719 665 } 720 666 721 667 #if H_MV_ENC_DEC_TRAC 722 668 DTRACE_CU("part_mode", eSize ) … … 726 672 { 727 673 #endif 728 switch(eSize)729 {730 case SIZE_2Nx2N:731 {732 m_pcBinIf->encodeBin( 1, m_cCUPartSizeSCModel.get( 0, 0, 0) );733 break;734 }735 case SIZE_2NxN:736 case SIZE_2NxnU:737 case SIZE_2NxnD:738 {739 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 0) );740 m_pcBinIf->encodeBin( 1, m_cCUPartSizeSCModel.get( 0, 0, 1) );741 if ( pcCU->getSlice()->getSPS()->getAMPAcc( uiDepth ) )742 {743 if (eSize == SIZE_2NxN)744 {745 m_pcBinIf->encodeBin(1, m_cCUPartSizeSCModel.get( 0, 0, 3 ));746 }747 else748 {749 m_pcBinIf->encodeBin(0, m_cCUPartSizeSCModel.get( 0, 0, 3 ));750 m_pcBinIf->encodeBinEP((eSize == SIZE_2NxnU? 0: 1));751 }752 }753 break;754 }755 case SIZE_Nx2N:756 case SIZE_nLx2N:757 case SIZE_nRx2N:758 {759 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 0) );760 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 1) );761 if( uiDepth == g_uiMaxCUDepth - g_uiAddCUDepth && !( pcCU->getWidth(uiAbsPartIdx) == 8 && pcCU->getHeight(uiAbsPartIdx) == 8 ) )762 {763 m_pcBinIf->encodeBin( 1, m_cCUPartSizeSCModel.get( 0, 0, 2) );764 }765 if ( pcCU->getSlice()->getSPS()->getAMPAcc( uiDepth ) )766 {767 if (eSize == SIZE_Nx2N)768 {769 m_pcBinIf->encodeBin(1, m_cCUPartSizeSCModel.get( 0, 0, 3 ));770 }771 else772 {773 m_pcBinIf->encodeBin(0, m_cCUPartSizeSCModel.get( 0, 0, 3 ));774 m_pcBinIf->encodeBinEP((eSize == SIZE_nLx2N? 0: 1));775 }776 }777 break;778 }779 case SIZE_NxN:780 {781 if( uiDepth == g_uiMaxCUDepth - g_uiAddCUDepth && !( pcCU->getWidth(uiAbsPartIdx) == 8 && pcCU->getHeight(uiAbsPartIdx) == 8 ) )782 {783 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 0) );784 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 1) );785 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 2) );786 }787 break;788 }789 default:790 {791 assert(0);792 }793 }674 switch(eSize) 675 { 676 case SIZE_2Nx2N: 677 { 678 m_pcBinIf->encodeBin( 1, m_cCUPartSizeSCModel.get( 0, 0, 0) ); 679 break; 680 } 681 case SIZE_2NxN: 682 case SIZE_2NxnU: 683 case SIZE_2NxnD: 684 { 685 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 0) ); 686 m_pcBinIf->encodeBin( 1, m_cCUPartSizeSCModel.get( 0, 0, 1) ); 687 if ( pcCU->getSlice()->getSPS()->getAMPAcc( uiDepth ) ) 688 { 689 if (eSize == SIZE_2NxN) 690 { 691 m_pcBinIf->encodeBin(1, m_cCUPartSizeSCModel.get( 0, 0, 3 )); 692 } 693 else 694 { 695 m_pcBinIf->encodeBin(0, m_cCUPartSizeSCModel.get( 0, 0, 3 )); 696 m_pcBinIf->encodeBinEP((eSize == SIZE_2NxnU? 0: 1)); 697 } 698 } 699 break; 700 } 701 case SIZE_Nx2N: 702 case SIZE_nLx2N: 703 case SIZE_nRx2N: 704 { 705 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 0) ); 706 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 1) ); 707 if( uiDepth == g_uiMaxCUDepth - g_uiAddCUDepth && !( pcCU->getWidth(uiAbsPartIdx) == 8 && pcCU->getHeight(uiAbsPartIdx) == 8 ) ) 708 { 709 m_pcBinIf->encodeBin( 1, m_cCUPartSizeSCModel.get( 0, 0, 2) ); 710 } 711 if ( pcCU->getSlice()->getSPS()->getAMPAcc( uiDepth ) ) 712 { 713 if (eSize == SIZE_Nx2N) 714 { 715 m_pcBinIf->encodeBin(1, m_cCUPartSizeSCModel.get( 0, 0, 3 )); 716 } 717 else 718 { 719 m_pcBinIf->encodeBin(0, m_cCUPartSizeSCModel.get( 0, 0, 3 )); 720 m_pcBinIf->encodeBinEP((eSize == SIZE_nLx2N? 0: 1)); 721 } 722 } 723 break; 724 } 725 case SIZE_NxN: 726 { 727 if( uiDepth == g_uiMaxCUDepth - g_uiAddCUDepth && !( pcCU->getWidth(uiAbsPartIdx) == 8 && pcCU->getHeight(uiAbsPartIdx) == 8 ) ) 728 { 729 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 0) ); 730 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 1) ); 731 m_pcBinIf->encodeBin( 0, m_cCUPartSizeSCModel.get( 0, 0, 2) ); 732 } 733 break; 734 } 735 default: 736 { 737 assert(0); 738 } 739 } 794 740 #if H_3D_QTLPC 795 741 } … … 1143 1089 { 1144 1090 #endif 1145 if(predIdx[j] != -1)1146 {1147 m_pcBinIf->encodeBinEP( predIdx[j] ? 1 : 0 );1148 if (predIdx[j])1149 {1150 m_pcBinIf->encodeBinEP( predIdx[j]-1 );1151 }1091 if(predIdx[j] != -1) 1092 { 1093 m_pcBinIf->encodeBinEP( predIdx[j] ? 1 : 0 ); 1094 if (predIdx[j]) 1095 { 1096 m_pcBinIf->encodeBinEP( predIdx[j]-1 ); 1097 } 1152 1098 #if H_MV_ENC_DEC_TRAC 1153 DTRACE_CU("mpm_idx", predIdx[j] );1154 #endif 1155 }1156 else1157 {1158 if (preds[j][0] > preds[j][1])1159 {1160 std::swap(preds[j][0], preds[j][1]);1161 }1162 if (preds[j][0] > preds[j][2])1163 {1164 std::swap(preds[j][0], preds[j][2]);1165 }1166 if (preds[j][1] > preds[j][2])1167 {1168 std::swap(preds[j][1], preds[j][2]);1169 }1170 for(Int i = (predNum[j] - 1); i >= 0; i--)1171 {1172 dir[j] = dir[j] > preds[j][i] ? dir[j] - 1 : dir[j];1173 }1174 m_pcBinIf->encodeBinsEP( dir[j], 5 );1099 DTRACE_CU("mpm_idx", predIdx[j] ); 1100 #endif 1101 } 1102 else 1103 { 1104 if (preds[j][0] > preds[j][1]) 1105 { 1106 std::swap(preds[j][0], preds[j][1]); 1107 } 1108 if (preds[j][0] > preds[j][2]) 1109 { 1110 std::swap(preds[j][0], preds[j][2]); 1111 } 1112 if (preds[j][1] > preds[j][2]) 1113 { 1114 std::swap(preds[j][1], preds[j][2]); 1115 } 1116 for(Int i = (predNum[j] - 1); i >= 0; i--) 1117 { 1118 dir[j] = dir[j] > preds[j][i] ? dir[j] - 1 : dir[j]; 1119 } 1120 m_pcBinIf->encodeBinsEP( dir[j], 5 ); 1175 1121 #if H_MV_ENC_DEC_TRAC 1176 DTRACE_CU("rem_intra_luma_pred_mode", dir[j] );1177 #endif 1178 }1122 DTRACE_CU("rem_intra_luma_pred_mode", dir[j] ); 1123 #endif 1124 } 1179 1125 #if H_3D_DIM 1180 1126 } … … 1521 1467 { 1522 1468 #endif 1523 piPCMSample = pcCU->getPCMSampleCb() + uiChromaOffset;1524 uiWidth = pcCU->getWidth(uiAbsPartIdx)/2;1525 uiHeight = pcCU->getHeight(uiAbsPartIdx)/2;1526 uiSampleBits = pcCU->getSlice()->getSPS()->getPCMBitDepthChroma();1527 1528 for(uiY = 0; uiY < uiHeight; uiY++)1529 {1530 for(uiX = 0; uiX < uiWidth; uiX++)1531 {1532 UInt uiSample = piPCMSample[uiX];1533 1534 m_pcBinIf->xWritePCMCode(uiSample, uiSampleBits);1535 }1536 piPCMSample += uiWidth;1537 }1538 1539 piPCMSample = pcCU->getPCMSampleCr() + uiChromaOffset;1540 uiWidth = pcCU->getWidth(uiAbsPartIdx)/2;1541 uiHeight = pcCU->getHeight(uiAbsPartIdx)/2;1542 uiSampleBits = pcCU->getSlice()->getSPS()->getPCMBitDepthChroma();1543 1544 for(uiY = 0; uiY < uiHeight; uiY++)1545 {1546 for(uiX = 0; uiX < uiWidth; uiX++)1547 {1548 UInt uiSample = piPCMSample[uiX];1549 1550 m_pcBinIf->xWritePCMCode(uiSample, uiSampleBits);1551 }1552 piPCMSample += uiWidth;1553 }1469 piPCMSample = pcCU->getPCMSampleCb() + uiChromaOffset; 1470 uiWidth = pcCU->getWidth(uiAbsPartIdx)/2; 1471 uiHeight = pcCU->getHeight(uiAbsPartIdx)/2; 1472 uiSampleBits = pcCU->getSlice()->getSPS()->getPCMBitDepthChroma(); 1473 1474 for(uiY = 0; uiY < uiHeight; uiY++) 1475 { 1476 for(uiX = 0; uiX < uiWidth; uiX++) 1477 { 1478 UInt uiSample = piPCMSample[uiX]; 1479 1480 m_pcBinIf->xWritePCMCode(uiSample, uiSampleBits); 1481 } 1482 piPCMSample += uiWidth; 1483 } 1484 1485 piPCMSample = pcCU->getPCMSampleCr() + uiChromaOffset; 1486 uiWidth = pcCU->getWidth(uiAbsPartIdx)/2; 1487 uiHeight = pcCU->getHeight(uiAbsPartIdx)/2; 1488 uiSampleBits = pcCU->getSlice()->getSPS()->getPCMBitDepthChroma(); 1489 1490 for(uiY = 0; uiY < uiHeight; uiY++) 1491 { 1492 for(uiX = 0; uiX < uiWidth; uiX++) 1493 { 1494 UInt uiSample = piPCMSample[uiX]; 1495 1496 m_pcBinIf->xWritePCMCode(uiSample, uiSampleBits); 1497 } 1498 piPCMSample += uiWidth; 1499 } 1554 1500 #if H_3D_DISABLE_CHROMA 1555 1501 } -
trunk/source/Lib/TLibEncoder/TEncSbac.h
r1179 r1196 146 146 Void codeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx ); 147 147 Void codeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ); 148 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033148 #if H_3D 149 149 Void codeDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx ); 150 #else151 #if H_3D_SINGLE_DEPTH152 Void codeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx );153 #endif154 150 #endif 155 151 Void codeMergeFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ); … … 219 215 ContextModel3DBuffer m_cCUSplitFlagSCModel; 220 216 ContextModel3DBuffer m_cCUSkipFlagSCModel; 221 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033217 #if H_3D 222 218 ContextModel3DBuffer m_cCUDISFlagSCModel; 223 219 ContextModel3DBuffer m_cCUDISTypeSCModel; 224 #else225 #if H_3D_SINGLE_DEPTH226 ContextModel3DBuffer m_cCUSingleDepthFlagSCModel;227 ContextModel3DBuffer m_cSingleDepthValueSCModel;228 #endif229 220 #endif 230 221 ContextModel3DBuffer m_cCUMergeFlagExtSCModel; -
trunk/source/Lib/TLibEncoder/TEncSearch.cpp
r1179 r1196 915 915 } 916 916 m_pcEntropyCoder->encodeSkipFlag( pcCU, 0, true ); 917 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033917 #if H_3D 918 918 m_pcEntropyCoder->encodeDIS(pcCU, 0, true ); 919 919 if(!pcCU->getDISFlag(uiAbsPartIdx)) 920 #else921 #if H_3D_SINGLE_DEPTH922 m_pcEntropyCoder->encodeSingleDepthMode(pcCU, 0, true );923 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx))924 #endif925 920 #endif 926 921 m_pcEntropyCoder->encodePredMode( pcCU, 0, true ); 927 922 } 928 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033923 #if H_3D 929 924 else 930 925 { 931 926 m_pcEntropyCoder->encodeDIS(pcCU, 0, true ); 932 927 } 933 #else 934 #if H_3D_SINGLE_DEPTH 935 else 936 { 937 m_pcEntropyCoder->encodeSingleDepthMode(pcCU, 0, true ); 938 } 939 #endif 940 #endif 941 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 928 #endif 929 #if H_3D 942 930 if(!pcCU->getDISFlag(uiAbsPartIdx)) 943 931 { 944 #else945 #if H_3D_SINGLE_DEPTH946 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx))947 {948 #endif949 932 #endif 950 933 m_pcEntropyCoder ->encodePartSize( pcCU, 0, pcCU->getDepth(0), true ); 951 934 952 #if !HHI_MOVE_SYN_K0052953 #if H_3D_DIM_SDC954 m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true );955 #endif956 #endif957 935 if (pcCU->isIntra(0) && pcCU->getPartitionSize(0) == SIZE_2Nx2N ) 958 936 { … … 960 938 if ( pcCU->getIPCMFlag (0)) 961 939 { 962 #if HHI_MOVE_SYN_K0052963 940 #if H_3D_DIM_SDC 964 941 m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true ); 965 942 #endif 966 #endif967 943 return; 968 944 } 969 945 } 970 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 971 } 972 #else 973 #if H_3D_SINGLE_DEPTH 974 } 975 #endif 976 #endif 977 } 978 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 946 #if H_3D 947 } 948 #endif 949 } 950 #if H_3D 979 951 if(!pcCU->getDISFlag(uiAbsPartIdx)) 980 952 { 981 #else982 #if H_3D_SINGLE_DEPTH983 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx))984 {985 #endif986 953 #endif 987 954 // luma prediction mode … … 992 959 m_pcEntropyCoder->encodeIntraDirModeLuma ( pcCU, 0 ); 993 960 #if H_3D_DIM_SDC 994 #if HHI_MOVE_SYN_K0052995 #if H_3D_DIM_SDC996 961 m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true ); 997 #endif998 #endif999 962 if( pcCU->getSlice()->getIsDepth() && ( !pcCU->getSDCFlag( 0 ) ) && getDimType( pcCU->getLumaIntraDir( 0 ) ) < DIM_NUM_TYPE ) 1000 963 { … … 1013 976 { 1014 977 m_pcEntropyCoder->encodeIntraDirModeLuma ( pcCU, uiPart * uiQNumParts ); 1015 1016 #if HHI_MOVE_SYN_K0052 978 #if H_3D_DIM_SDC 1017 979 } 1018 980 m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true ); 1019 981 for( UInt uiPart = 0; uiPart < 4; uiPart++ ) 1020 982 { 1021 #endif1022 #if H_3D_DIM_SDC1023 983 if( pcCU->getSlice()->getIsDepth() && ( !pcCU->getSDCFlag( uiPart * uiQNumParts ) ) && getDimType( pcCU->getLumaIntraDir( uiPart * uiQNumParts ) ) < DIM_NUM_TYPE ) 1024 984 { … … 1032 992 m_pcEntropyCoder->encodeIntraDirModeLuma ( pcCU, uiAbsPartIdx ); 1033 993 #if H_3D_DIM_SDC 1034 #if HHI_MOVE_SYN_K00521035 994 if( uiAbsPartIdx == 0 ) 1036 995 { 1037 996 m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true ); 1038 997 } 1039 #endif1040 998 if( pcCU->getSlice()->getIsDepth() && ( !pcCU->getSDCFlag( uiAbsPartIdx ) ) && getDimType( pcCU->getLumaIntraDir( uiAbsPartIdx ) ) < DIM_NUM_TYPE ) 1041 999 { … … 1044 1002 #endif 1045 1003 } 1046 } 1047 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 1048 } 1049 #else 1050 #if H_3D_SINGLE_DEPTH 1051 } 1052 #endif 1053 #endif 1004 #if H_3D 1005 } 1006 #endif 1007 } 1054 1008 } 1055 1009 if( bChroma ) … … 1914 1868 } 1915 1869 1916 #if SEC_DEPTH_INTRA_SKIP_MODE_K00331870 #if H_3D 1917 1871 Void TEncSearch::xIntraCodingDIS( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, UInt uiPredMode ) 1918 1872 { … … 2006 1960 dRDCost = m_pcRdCost->calcRdCost( uiBits, ruiDist ); 2007 1961 } 2008 #else 2009 #if H_3D_SINGLE_DEPTH 2010 Void TEncSearch::xIntraCodingSingleDepth( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, Int iTestDepthIdx, Pel *DepthNeighbor ) 2011 { 2012 UInt uiWidth = pcCU ->getWidth ( 0 ); 2013 UInt uiHeight = pcCU ->getHeight ( 0 ); 2014 UInt uiStride = pcOrgYuv ->getStride (); 2015 Pel* piOrg = pcOrgYuv ->getLumaAddr( uiAbsPartIdx ); 2016 Pel* piPred = pcPredYuv->getLumaAddr( uiAbsPartIdx ); 2017 2018 AOF( uiWidth == uiHeight ); 2019 AOF( uiAbsPartIdx == 0 ); 2020 pcCU->setSingleDepthValueSubParts((Pel)iTestDepthIdx,uiAbsPartIdx, 0, pcCU->getDepth(0)); 2021 //===== reconstruction ===== 2022 2023 for( UInt uiY = 0; uiY < uiHeight; uiY++ ) 2024 { 2025 for( UInt uiX = 0; uiX < uiWidth; uiX++ ) 2026 { 2027 piPred[ uiX ] = DepthNeighbor[iTestDepthIdx]; 2028 } 2029 piPred += uiStride; 2030 } 2031 2032 // clear UV 2033 UInt uiStrideC = pcPredYuv->getCStride(); 2034 Pel *pRecCb = pcPredYuv->getCbAddr(); 2035 Pel *pRecCr = pcPredYuv->getCrAddr(); 2036 2037 for (Int y=0; y<uiHeight/2; y++) 2038 { 2039 for (Int x=0; x<uiWidth/2; x++) 2040 { 2041 pRecCb[x] = 1<<(g_bitDepthC-1); 2042 pRecCr[x] = 1<<(g_bitDepthC-1); 2043 } 2044 2045 pRecCb += uiStrideC; 2046 pRecCr += uiStrideC; 2047 } 2048 2049 piPred = pcPredYuv->getLumaAddr( uiAbsPartIdx ); 2050 //===== determine distortion ===== 2051 #if H_3D_VSO 2052 if ( m_pcRdCost->getUseVSO() ) 2053 ruiDist = m_pcRdCost->getDistPartVSO ( pcCU, uiAbsPartIdx, piPred, uiStride, piOrg, uiStride, uiWidth, uiHeight, false ); 2054 else 2055 #endif 2056 ruiDist = m_pcRdCost->getDistPart(g_bitDepthY, piPred, uiStride, piOrg, uiStride, uiWidth, uiHeight ); 2057 2058 //===== determine rate and r-d cost ===== 2059 m_pcEntropyCoder->resetBits(); 2060 m_pcEntropyCoder->encodeSingleDepthMode( pcCU, 0, true ); 2061 UInt uiBits = m_pcEntropyCoder->getNumberOfWrittenBits(); 2062 2063 #if H_3D_VSO 2064 if ( m_pcRdCost->getUseLambdaScaleVSO()) 2065 dRDCost = m_pcRdCost->calcRdCostVSO( uiBits, ruiDist ); 2066 else 2067 #endif 2068 dRDCost = m_pcRdCost->calcRdCost( uiBits, ruiDist ); 2069 } 2070 #endif 2071 #endif 2072 1962 #endif 2073 1963 #if H_3D_DIM_SDC 2074 1964 Void TEncSearch::xIntraCodingSDC( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, Bool bZeroResidual, Int iSDCDeltaResi ) … … 2318 2208 2319 2209 m_pcEntropyCoder->encodePartSize( pcCU, 0, pcCU->getDepth( 0 ), true ); 2320 #if !HHI_MOVE_SYN_K00522321 m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true );2322 #endif2323 2210 2324 2211 // encode pred direction + DC residual data 2325 2212 m_pcEntropyCoder->encodePredInfo( pcCU, 0, true ); 2326 #if H HI_MOVE_SYN_K00522213 #if H_3D_DIM_SDC 2327 2214 m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true ); 2328 2215 #endif … … 3021 2908 pcCU->setChromIntraDirSubParts( uiBestMode, 0, pcCU->getDepth( 0 ) ); 3022 2909 } 3023 3024 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 2910 #if H_3D 3025 2911 Void TEncSearch::estIntraPredDIS( TComDataCU* pcCU, 3026 2912 TComYuv* pcOrgYuv, … … 3081 2967 pcCU->getTotalDistortion() = uiBestDist; 3082 2968 } 3083 #else 3084 #if H_3D_SINGLE_DEPTH 3085 Void 3086 TEncSearch::estIntraPredSingleDepth( TComDataCU* pcCU, 3087 TComYuv* pcOrgYuv, 3088 TComYuv* pcPredYuv, 3089 TComYuv* pcResiYuv, 3090 TComYuv* pcRecoYuv, 3091 UInt& ruiDistC, 3092 Bool bLumaOnly ) 3093 { 3094 UInt uiDepth = pcCU->getDepth(0); 3095 UInt uiWidth = pcCU->getWidth (0); 3096 UInt uiHeight = pcCU->getHeight(0); 3097 3098 3099 Pel* piOrg = pcOrgYuv ->getLumaAddr( 0, uiWidth ); 3100 UInt uiStride = pcPredYuv->getStride(); 3101 3102 Int index=0; 3103 Pel testDepth; 3104 Pel DepthNeighbours[2]; 3105 //construction of depth candidates 3106 for( Int i = 0; (i < 2) && (index<SINGLE_DEPTH_MODE_CAND_LIST_SIZE) ; i++ ) 3107 { 3108 if(!pcCU->getNeighDepth (0, 0, &testDepth, i)) 3109 { 3110 continue; 3111 } 3112 DepthNeighbours[index]=testDepth; 3113 index++; 3114 } 3115 3116 if(index==0) 3117 { 3118 DepthNeighbours[index]=1<<(g_bitDepthY-1); 3119 index++; 3120 } 3121 3122 if(index==1) 3123 { 3124 DepthNeighbours[index]=ClipY(DepthNeighbours[0] + 1 ); 3125 index++; 3126 } 3127 3128 3129 Dist uiDist = 0; 3130 Double dCost = 0.0; 3131 Dist uiBestDist = 0; 3132 Double dBestCost = MAX_DOUBLE; 3133 Pel pBestSingleDepthValue = 0; 3134 3135 for( Int testdepthidx = 0; testdepthidx < index ; testdepthidx++ ) 3136 { 3137 // set context models 3138 m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST] ); 3139 3140 // determine residual for partition 3141 uiDist = 0; 3142 dCost = 0.0; 3143 #if H_3D_VSO // M36 3144 if( m_pcRdCost->getUseRenModel() ) 3145 { 3146 m_pcRdCost->setRenModelData( pcCU, 0, piOrg, uiStride, uiWidth, uiHeight ); 3147 } 3148 #endif 3149 xIntraCodingSingleDepth(pcCU, 0, pcOrgYuv, pcPredYuv, uiDist, dCost, testdepthidx, DepthNeighbours); 3150 // check r-d cost 3151 if( dCost < dBestCost ) 3152 { 3153 uiBestDist = uiDist; 3154 dBestCost = dCost; 3155 pBestSingleDepthValue = pcCU->getSingleDepthValue(0); 3156 // copy reconstruction 3157 pcPredYuv->copyPartToPartYuv(pcRecoYuv, 0, uiWidth, uiHeight); 3158 } 3159 } // depth index loop 3160 3161 3162 pcCU->setSingleDepthValueSubParts((Pel)pBestSingleDepthValue,0, 0, uiDepth); 3163 assert(pBestSingleDepthValue>=0); 3164 3165 //===== reset context models ===== 3166 m_pcRDGoOnSbacCoder->load(m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST]); 3167 3168 //===== set distortion (rate and r-d costs are determined later) ===== 3169 pcCU->getTotalDistortion() = uiBestDist; 3170 } 3171 3172 #endif 3173 #endif 3174 2969 #endif 3175 2970 Void 3176 2971 TEncSearch::estIntraPredQT( TComDataCU* pcCU, … … 3221 3016 pcCU->getPattern()->initPattern ( pcCU, uiInitTrDepth, uiPartOffset ); 3222 3017 pcCU->getPattern()->initAdiPattern( pcCU, uiPartOffset, uiInitTrDepth, m_piYuvExt, m_iYuvExtStride, m_iYuvExtHeight, bAboveAvail, bLeftAvail ); 3223 3018 3224 3019 //===== determine set of modes to be tested (using prediction signal only) ===== 3225 3020 Int numModesAvailable = 35; //total number of Intra modes … … 3229 3024 UInt uiRdModeList[FAST_UDI_MAX_RDMODE_NUM]; 3230 3025 Int numModesForFullRD = g_aucIntraModeNumFast[ uiWidthBit ]; 3231 3026 3232 3027 #if H_3D_DIM 3233 3028 if( bOnlyIVP ) … … 3238 3033 { 3239 3034 #endif 3240 Bool doFastSearch = (numModesForFullRD != numModesAvailable);3241 if (doFastSearch)3242 {3243 assert(numModesForFullRD < numModesAvailable);3244 3245 for( Int i=0; i < numModesForFullRD; i++ )3246 {3247 CandCostList[ i ] = MAX_DOUBLE;3248 }3249 CandNum = 0;3250 3251 for( Int modeIdx = 0; modeIdx < numModesAvailable; modeIdx++ )3252 {3253 UInt uiMode = modeIdx;3254 3255 predIntraLumaAng( pcCU->getPattern(), uiMode, piPred, uiStride, uiWidth, uiHeight, bAboveAvail, bLeftAvail );3035 Bool doFastSearch = (numModesForFullRD != numModesAvailable); 3036 if (doFastSearch) 3037 { 3038 assert(numModesForFullRD < numModesAvailable); 3039 3040 for( Int i=0; i < numModesForFullRD; i++ ) 3041 { 3042 CandCostList[ i ] = MAX_DOUBLE; 3043 } 3044 CandNum = 0; 3045 3046 for( Int modeIdx = 0; modeIdx < numModesAvailable; modeIdx++ ) 3047 { 3048 UInt uiMode = modeIdx; 3049 3050 predIntraLumaAng( pcCU->getPattern(), uiMode, piPred, uiStride, uiWidth, uiHeight, bAboveAvail, bLeftAvail ); 3256 3051 #if H_3D_VSO // M34 3257 Dist uiSad; 3258 if ( m_pcRdCost->getUseVSO() ) 3259 { 3260 if ( m_pcRdCost->getUseEstimatedVSD() ) 3261 { 3262 uiSad = (Dist) ( m_pcRdCost->getDistPartVSD( pcCU, uiPartOffset, piPred, uiStride, piOrg, uiStride, uiWidth, uiHeight, true ) ); 3052 Dist uiSad; 3053 if ( m_pcRdCost->getUseVSO() ) 3054 { 3055 if ( m_pcRdCost->getUseEstimatedVSD() ) 3056 { 3057 uiSad = (Dist) ( m_pcRdCost->getDistPartVSD( pcCU, uiPartOffset, piPred, uiStride, piOrg, uiStride, uiWidth, uiHeight, true ) ); 3058 } 3059 else 3060 { 3061 uiSad = m_pcRdCost->getDistPartVSO(pcCU, uiPartOffset, piPred, uiStride, piOrg, uiStride, uiWidth, uiHeight, true ); 3062 } 3263 3063 } 3264 3064 else 3265 { 3266 uiSad = m_pcRdCost-> getDistPartVSO(pcCU, uiPartOffset, piPred, uiStride, piOrg, uiStride, uiWidth, uiHeight, true);3065 { 3066 uiSad = m_pcRdCost->calcHAD(g_bitDepthY, piOrg, uiStride, piPred, uiStride, uiWidth, uiHeight ); 3267 3067 } 3268 }3269 else3270 {3271 uiSad = m_pcRdCost->calcHAD(g_bitDepthY, piOrg, uiStride, piPred, uiStride, uiWidth, uiHeight );3272 }3273 3068 #else 3274 // use hadamard transform here3275 UInt uiSad = m_pcRdCost->calcHAD(g_bitDepthY, piOrg, uiStride, piPred, uiStride, uiWidth, uiHeight );3276 #endif 3277 3278 UInt iModeBits = xModeBitsIntra( pcCU, uiMode, uiPU, uiPartOffset, uiDepth, uiInitTrDepth );3069 // use hadamard transform here 3070 UInt uiSad = m_pcRdCost->calcHAD(g_bitDepthY, piOrg, uiStride, piPred, uiStride, uiWidth, uiHeight ); 3071 #endif 3072 3073 UInt iModeBits = xModeBitsIntra( pcCU, uiMode, uiPU, uiPartOffset, uiDepth, uiInitTrDepth ); 3279 3074 #if H_3D_VSO // M35 3280 Double dLambda;3281 if ( m_pcRdCost->getUseLambdaScaleVSO() )3282 {3283 dLambda = m_pcRdCost->getUseRenModel() ? m_pcRdCost->getLambdaVSO() : m_pcRdCost->getSqrtLambdaVSO();3284 }3285 else3286 {3287 dLambda = m_pcRdCost->getSqrtLambda();3288 }3289 3290 Double cost = (Double)uiSad + (Double)iModeBits * dLambda;3075 Double dLambda; 3076 if ( m_pcRdCost->getUseLambdaScaleVSO() ) 3077 { 3078 dLambda = m_pcRdCost->getUseRenModel() ? m_pcRdCost->getLambdaVSO() : m_pcRdCost->getSqrtLambdaVSO(); 3079 } 3080 else 3081 { 3082 dLambda = m_pcRdCost->getSqrtLambda(); 3083 } 3084 3085 Double cost = (Double)uiSad + (Double)iModeBits * dLambda; 3291 3086 #else 3292 Double cost = (Double)uiSad + (Double)iModeBits * m_pcRdCost->getSqrtLambda();3293 #endif 3294 3295 CandNum += xUpdateCandList( uiMode, cost, numModesForFullRD, uiRdModeList, CandCostList );3296 }3297 3087 Double cost = (Double)uiSad + (Double)iModeBits * m_pcRdCost->getSqrtLambda(); 3088 #endif 3089 3090 CandNum += xUpdateCandList( uiMode, cost, numModesForFullRD, uiRdModeList, CandCostList ); 3091 } 3092 3298 3093 #if FAST_UDI_USE_MPM 3299 Int uiPreds[3] = {-1, -1, -1}; 3300 Int iMode = -1; 3301 Int numCand = pcCU->getIntraDirLumaPredictor( uiPartOffset, uiPreds, &iMode ); 3302 if( iMode >= 0 ) 3303 { 3304 numCand = iMode; 3305 } 3306 3307 for( Int j=0; j < numCand; j++) 3308 3309 { 3310 Bool mostProbableModeIncluded = false; 3311 Int mostProbableMode = uiPreds[j]; 3312 3094 Int uiPreds[3] = {-1, -1, -1}; 3095 Int iMode = -1; 3096 Int numCand = pcCU->getIntraDirLumaPredictor( uiPartOffset, uiPreds, &iMode ); 3097 if( iMode >= 0 ) 3098 { 3099 numCand = iMode; 3100 } 3101 3102 for( Int j=0; j < numCand; j++) 3103 3104 { 3105 Bool mostProbableModeIncluded = false; 3106 Int mostProbableMode = uiPreds[j]; 3107 3108 for( Int i=0; i < numModesForFullRD; i++) 3109 { 3110 mostProbableModeIncluded |= (mostProbableMode == uiRdModeList[i]); 3111 } 3112 if (!mostProbableModeIncluded) 3113 { 3114 uiRdModeList[numModesForFullRD++] = mostProbableMode; 3115 } 3116 } 3117 #endif // FAST_UDI_USE_MPM 3118 } 3119 else 3120 { 3313 3121 for( Int i=0; i < numModesForFullRD; i++) 3314 3122 { 3315 mostProbableModeIncluded |= (mostProbableMode == uiRdModeList[i]); 3316 } 3317 if (!mostProbableModeIncluded) 3318 { 3319 uiRdModeList[numModesForFullRD++] = mostProbableMode; 3320 } 3321 } 3322 #endif // FAST_UDI_USE_MPM 3323 } 3324 else 3325 { 3326 for( Int i=0; i < numModesForFullRD; i++) 3327 { 3328 uiRdModeList[i] = i; 3329 } 3330 } 3123 uiRdModeList[i] = i; 3124 } 3125 } 3331 3126 #if H_3D_DIM 3332 3127 } 3333 3128 #endif 3334 3129 3335 3130 #if H_3D_DIM 3336 3131 //===== determine set of depth intra modes to be tested ===== 3337 3132 if( m_pcEncCfg->getIsDepth() && uiWidth >= DIM_MIN_SIZE && uiWidth <= DIM_MAX_SIZE && uiWidth == uiHeight ) 3338 3133 { 3339 #if TICKET083_IVPFLAG_FIX3340 3134 if( bOnlyIVP ) 3341 #else3342 if( bOnlyIVP && pcCU->getSlice()->getIntraContourFlag() )3343 #endif3344 3135 { 3345 3136 TComWedgelet* dmm4Segmentation = new TComWedgelet( uiWidth, uiHeight ); … … 3357 3148 { 3358 3149 #if H_3D_FAST_DEPTH_INTRA 3359 Int threshold = max(((pcCU->getQP(0))>>3)-1,3);3360 Int varThreshold = (Int)( threshold * threshold - 8 );3361 UInt varCU = m_pcRdCost->calcVAR(piOrg, uiStride, uiWidth,uiHeight,pcCU->getDepth(0));3150 Int threshold = max(((pcCU->getQP(0))>>3)-1,3); 3151 Int varThreshold = (Int)( threshold * threshold - 8 ); 3152 UInt varCU = m_pcRdCost->calcVAR(piOrg, uiStride, uiWidth,uiHeight,pcCU->getDepth(0)); 3362 3153 #endif 3363 3154 3364 3155 #if H_3D_DIM_DMM 3365 if( ( ( m_pcEncCfg->getUseDMM() && pcCU->getSlice()->getIntraSdcWedgeFlag() ) || pcCU->getSlice()->getIntraContourFlag() )3156 if( ( ( m_pcEncCfg->getUseDMM() && pcCU->getSlice()->getIntraSdcWedgeFlag() ) || pcCU->getSlice()->getIntraContourFlag() ) 3366 3157 #if H_3D_FAST_DEPTH_INTRA 3367 && (uiRdModeList[0] != PLANAR_IDX || varCU >= varThreshold)3368 #endif 3369 )3370 {3371 UInt uiStart, uiEnd;3372 if( ( m_pcEncCfg->getUseDMM() && pcCU->getSlice()->getIntraSdcWedgeFlag() ) && pcCU->getSlice()->getIntraContourFlag() )3373 {3374 uiStart = 0;3375 uiEnd = 2;3376 }3377 else if( ( m_pcEncCfg->getUseDMM() && pcCU->getSlice()->getIntraSdcWedgeFlag() ) )3378 {3379 uiStart = 0;3380 uiEnd = 1;3381 }3382 else if( pcCU->getSlice()->getIntraContourFlag() )3383 {3384 uiStart = 1;3385 uiEnd = 2;3386 }3387 else3388 {3389 uiStart = 0;3390 uiEnd = 0;3391 }3392 for( UInt dmmType = uiStart; dmmType < uiEnd; dmmType++ )3393 {3158 && (uiRdModeList[0] != PLANAR_IDX || varCU >= varThreshold) 3159 #endif 3160 ) 3161 { 3162 UInt uiStart, uiEnd; 3163 if( ( m_pcEncCfg->getUseDMM() && pcCU->getSlice()->getIntraSdcWedgeFlag() ) && pcCU->getSlice()->getIntraContourFlag() ) 3164 { 3165 uiStart = 0; 3166 uiEnd = 2; 3167 } 3168 else if( ( m_pcEncCfg->getUseDMM() && pcCU->getSlice()->getIntraSdcWedgeFlag() ) ) 3169 { 3170 uiStart = 0; 3171 uiEnd = 1; 3172 } 3173 else if( pcCU->getSlice()->getIntraContourFlag() ) 3174 { 3175 uiStart = 1; 3176 uiEnd = 2; 3177 } 3178 else 3179 { 3180 uiStart = 0; 3181 uiEnd = 0; 3182 } 3183 for( UInt dmmType = uiStart; dmmType < uiEnd; dmmType++ ) 3184 { 3394 3185 #if H_3D_FCO 3395 3186 TComPic* picTexture = pcCU->getSlice()->getIvPic(false, pcCU->getSlice()->getViewIndex() ); … … 3400 3191 #endif 3401 3192 { 3402 3193 continue; 3403 3194 } 3404 3195 #endif 3405 UInt uiTabIdx = 0; 3406 TComWedgelet* biSegmentation = NULL; 3407 Pel deltaDC1 = 0; Pel deltaDC2 = 0; 3408 switch( dmmType ) 3409 { 3410 case( DMM1_IDX ): 3196 UInt uiTabIdx = 0; 3197 TComWedgelet* biSegmentation = NULL; 3198 Pel deltaDC1 = 0; Pel deltaDC2 = 0; 3199 switch( dmmType ) 3411 3200 { 3412 xSearchDmm1Wedge( pcCU, uiPartOffset, piOrg, uiStride, uiWidth, uiHeight, uiTabIdx ); 3413 pcCU->setDmmWedgeTabIdxSubParts( uiTabIdx, dmmType, uiPartOffset, uiDepth + uiInitTrDepth ); 3414 biSegmentation = pcCU->isDMM1UpscaleMode( uiWidth ) ? 3201 case( DMM1_IDX ): 3202 { 3203 xSearchDmm1Wedge( pcCU, uiPartOffset, piOrg, uiStride, uiWidth, uiHeight, uiTabIdx ); 3204 pcCU->setDmmWedgeTabIdxSubParts( uiTabIdx, dmmType, uiPartOffset, uiDepth + uiInitTrDepth ); 3205 biSegmentation = pcCU->isDMM1UpscaleMode( uiWidth ) ? 3415 3206 &(g_dmmWedgeLists[(g_aucConvertToBit[pcCU->getDMM1BasePatternWidth(uiWidth)])][uiTabIdx]) : &(g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])][uiTabIdx]); 3416 } break; 3417 3418 case( DMM4_IDX ): 3207 } break; 3208 3209 case( DMM4_IDX ): 3210 { 3211 { 3212 biSegmentation = new TComWedgelet( uiWidth, uiHeight ); 3213 xPredContourFromTex( pcCU, uiPartOffset, uiWidth, uiHeight, biSegmentation ); 3214 } 3215 } break; 3216 default: assert(0); 3217 } 3218 3219 if( biSegmentation ) 3419 3220 { 3221 if( dmmType == DMM1_IDX && pcCU->isDMM1UpscaleMode( uiWidth ) ){ 3222 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegmentation->getScaledPattern(uiWidth), uiWidth, uiWidth, uiHeight, deltaDC1, deltaDC2 ); 3223 } 3224 else 3420 3225 { 3421 biSegmentation = new TComWedgelet( uiWidth, uiHeight ); 3422 xPredContourFromTex( pcCU, uiPartOffset, uiWidth, uiHeight, biSegmentation ); 3226 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegmentation->getPattern(), biSegmentation->getStride(), uiWidth, uiHeight, deltaDC1, deltaDC2 ); 3423 3227 } 3424 } break; 3425 default: assert(0); 3228 pcCU->setDimDeltaDC( dmmType, 0, uiPartOffset, deltaDC1 ); 3229 pcCU->setDimDeltaDC( dmmType, 1, uiPartOffset, deltaDC2 ); 3230 3231 uiRdModeList[ numModesForFullRD++ ] = (dmmType +DIM_OFFSET); 3232 if( DMM4_IDX == dmmType ) { biSegmentation->destroy(); delete biSegmentation; } 3233 } 3426 3234 } 3427 3428 if( biSegmentation ) 3429 { 3430 if( dmmType == DMM1_IDX && pcCU->isDMM1UpscaleMode( uiWidth ) ){ 3431 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegmentation->getScaledPattern(uiWidth), uiWidth, uiWidth, uiHeight, deltaDC1, deltaDC2 ); 3432 } 3433 else 3434 { 3435 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegmentation->getPattern(), biSegmentation->getStride(), uiWidth, uiHeight, deltaDC1, deltaDC2 ); 3436 } 3437 pcCU->setDimDeltaDC( dmmType, 0, uiPartOffset, deltaDC1 ); 3438 pcCU->setDimDeltaDC( dmmType, 1, uiPartOffset, deltaDC2 ); 3439 3440 uiRdModeList[ numModesForFullRD++ ] = (dmmType +DIM_OFFSET); 3441 if( DMM4_IDX == dmmType ) { biSegmentation->destroy(); delete biSegmentation; } 3442 } 3443 } 3444 } 3235 } 3445 3236 #if H_3D_DIM 3446 3237 } … … 3454 3245 Double dSecondBestPUCost = MAX_DOUBLE; 3455 3246 #endif 3456 3247 3457 3248 UInt uiBestPUMode = 0; 3458 3249 #if H_3D_FAST_INTRA_SDC … … 3488 3279 // set luma prediction mode 3489 3280 #if !H_3D_FAST_INTRA_SDC 3490 UInt uiOrgMode = uiRdModeList[uiMode];3491 #endif 3492 3281 UInt uiOrgMode = uiRdModeList[uiMode]; 3282 #endif 3283 3493 3284 #if H_3D_FAST_INTRA_SDC 3494 3285 UInt uiOrgMode; 3495 3286 if (uiMode < numModesForFullRD) 3496 3287 { 3497 3288 uiOrgMode = uiRdModeList[uiMode]; 3498 3289 } 3499 3290 else 3500 3291 { 3501 3502 3503 3504 3505 3506 3507 3508 3509 3510 3511 3512 3513 3292 uiOrgMode = uiRdModeList[uiMode - numModesForFullRD]; 3293 3294 if (uiBestPUModeConv <= 1 ) 3295 { 3296 if (uiOrgMode > 1 && varCU < 1) continue; 3297 } 3298 else 3299 { 3300 if (uiOrgMode != uiBestPUModeConv && uiOrgMode != uiSecondBestPUModeConv && uiOrgMode != uiThirdBestPUModeConv 3301 && uiOrgMode > 1 && uiOrgMode < NUM_INTRA_MODE && varCU < 4) 3302 continue; 3303 } 3304 } 3514 3305 #endif 3515 3306 3516 3307 pcCU->setLumaIntraDirSubParts ( uiOrgMode, uiPartOffset, uiDepth + uiInitTrDepth ); 3517 3308 3518 3309 #if H_3D_DIM_SDC 3519 3310 #if H_3D_FAST_INTRA_SDC … … 3522 3313 Bool bTestSDC = ( m_pcEncCfg->getUseSDC() && pcCU->getSDCAvailable(uiPartOffset) ); 3523 3314 #endif 3524 3315 3525 3316 for( UInt uiSDC=0; uiSDC<=(bTestSDC?1:0); uiSDC++ ) 3526 3317 { … … 3561 3352 } 3562 3353 #endif 3563 3354 3564 3355 #if H_3D_DIM_ENC || H_3D_DIM_SDC 3565 Bool bTestZeroResi = false;3356 Bool bTestZeroResi = false; 3566 3357 #if H_3D_DIM_ENC 3567 bTestZeroResi |= pcCU->getSlice()->getIsDepth() && !pcCU->getSlice()->isIRAP();3358 bTestZeroResi |= pcCU->getSlice()->getIsDepth() && !pcCU->getSlice()->isIRAP(); 3568 3359 #endif 3569 3360 #if H_3D_DIM_SDC 3570 bTestZeroResi |= pcCU->getSDCFlag(uiPartOffset);3571 #endif 3572 if( uiSDC != 0 && iSDCDeltaResi != 0 )3573 {3574 bTestZeroResi = false;3575 }3576 #endif 3577 3361 bTestZeroResi |= pcCU->getSDCFlag(uiPartOffset); 3362 #endif 3363 if( uiSDC != 0 && iSDCDeltaResi != 0 ) 3364 { 3365 bTestZeroResi = false; 3366 } 3367 #endif 3368 3578 3369 #if H_3D_DIM_ENC || H_3D_DIM_SDC 3579 for( UInt testZeroResi = 0; testZeroResi <= (bTestZeroResi ? 1 : 0) ; testZeroResi++ )3580 {3581 #endif 3582 // set context models3583 m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST] );3584 3585 // determine residual for partition3370 for( UInt testZeroResi = 0; testZeroResi <= (bTestZeroResi ? 1 : 0) ; testZeroResi++ ) 3371 { 3372 #endif 3373 // set context models 3374 m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST] ); 3375 3376 // determine residual for partition 3586 3377 #if H_3D_VSO 3587 Dist uiPUDistY = 0;3378 Dist uiPUDistY = 0; 3588 3379 #else 3589 UInt uiPUDistY = 0;3590 #endif 3591 UInt uiPUDistC = 0;3592 Double dPUCost = 0.0;3380 UInt uiPUDistY = 0; 3381 #endif 3382 UInt uiPUDistC = 0; 3383 Double dPUCost = 0.0; 3593 3384 #if H_3D_VSO // M36 3594 if( m_pcRdCost->getUseRenModel() )3595 {3596 m_pcRdCost->setRenModelData( pcCU, uiPartOffset, piOrg, uiStride, uiWidth, uiHeight );3597 }3385 if( m_pcRdCost->getUseRenModel() ) 3386 { 3387 m_pcRdCost->setRenModelData( pcCU, uiPartOffset, piOrg, uiStride, uiWidth, uiHeight ); 3388 } 3598 3389 #endif 3599 3390 #if H_3D_DIM_SDC 3600 if( pcCU->getSDCFlag(uiPartOffset) )3601 {3602 pcCU->setTrIdxSubParts(0, uiPartOffset, uiDepth + uiInitTrDepth);3603 pcCU->setCbfSubParts(1, 1, 1, uiPartOffset, uiDepth + uiInitTrDepth);3604 3605 // start encoding with SDC3606 xIntraCodingSDC(pcCU, uiPartOffset, pcOrgYuv, pcPredYuv, uiPUDistY, dPUCost, ( testZeroResi != 0 ), iSDCDeltaResi );3607 if ( testZeroResi == 0 && iOffset <= 3 )3608 {3609 dOffsetCost [iOffset -1] = dPUCost;3610 }3611 }3612 else3613 {3391 if( pcCU->getSDCFlag(uiPartOffset) ) 3392 { 3393 pcCU->setTrIdxSubParts(0, uiPartOffset, uiDepth + uiInitTrDepth); 3394 pcCU->setCbfSubParts(1, 1, 1, uiPartOffset, uiDepth + uiInitTrDepth); 3395 3396 // start encoding with SDC 3397 xIntraCodingSDC(pcCU, uiPartOffset, pcOrgYuv, pcPredYuv, uiPUDistY, dPUCost, ( testZeroResi != 0 ), iSDCDeltaResi ); 3398 if ( testZeroResi == 0 && iOffset <= 3 ) 3399 { 3400 dOffsetCost [iOffset -1] = dPUCost; 3401 } 3402 } 3403 else 3404 { 3614 3405 #endif 3615 3406 #if HHI_RQT_INTRA_SPEEDUP 3616 3407 #if H_3D_DIM_ENC 3617 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, true, dPUCost, (testZeroResi != 0) );3408 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, true, dPUCost, (testZeroResi != 0) ); 3618 3409 #if H_3D_FAST_INTRA_SDC 3619 if( dPUCost < dBestPUCostConv )3620 {3621 uiThirdBestPUModeConv = uiSecondBestPUModeConv;3622 uiSecondBestPUModeConv = uiBestPUModeConv;3623 uiBestPUModeConv = uiOrgMode;3624 dBestPUCostConv = dPUCost;3625 }3410 if( dPUCost < dBestPUCostConv ) 3411 { 3412 uiThirdBestPUModeConv = uiSecondBestPUModeConv; 3413 uiSecondBestPUModeConv = uiBestPUModeConv; 3414 uiBestPUModeConv = uiOrgMode; 3415 dBestPUCostConv = dPUCost; 3416 } 3626 3417 #endif 3627 3418 #else 3628 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, true, dPUCost );3419 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, true, dPUCost ); 3629 3420 #endif 3630 3421 #else 3631 3422 #if H_3D_DIM_ENC 3632 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, dPUCost, (testZeroResi != 0) );3423 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, dPUCost, (testZeroResi != 0) ); 3633 3424 #else 3634 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, dPUCost );3425 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, dPUCost ); 3635 3426 #endif 3636 3427 #endif 3637 3428 #if H_3D_DIM_SDC 3638 }3639 #endif 3640 3641 // check r-d cost3642 if( dPUCost < dBestPUCost )3643 {3429 } 3430 #endif 3431 3432 // check r-d cost 3433 if( dPUCost < dBestPUCost ) 3434 { 3644 3435 #if HHI_RQT_INTRA_SPEEDUP_MOD 3645 uiSecondBestMode = uiBestPUMode;3646 dSecondBestPUCost = dBestPUCost;3647 #endif 3648 uiBestPUMode = uiOrgMode;3649 uiBestPUDistY = uiPUDistY;3650 uiBestPUDistC = uiPUDistC;3651 dBestPUCost = dPUCost;3436 uiSecondBestMode = uiBestPUMode; 3437 dSecondBestPUCost = dBestPUCost; 3438 #endif 3439 uiBestPUMode = uiOrgMode; 3440 uiBestPUDistY = uiPUDistY; 3441 uiBestPUDistC = uiPUDistC; 3442 dBestPUCost = dPUCost; 3652 3443 3653 3444 #if H_3D_DIM_SDC 3654 if( pcCU->getSDCFlag(uiPartOffset) ) 3655 { 3656 bBestUseSDC = true; 3657 3658 // copy reconstruction 3659 pcPredYuv->copyPartToPartYuv(pcRecoYuv, uiPartOffset, uiWidth, uiHeight); 3660 3661 // copy DC values 3662 apBestDCOffsets[0] = pcCU->getSDCSegmentDCOffset(0, uiPartOffset); 3663 apBestDCOffsets[1] = pcCU->getSDCSegmentDCOffset(1, uiPartOffset); 3445 if( pcCU->getSDCFlag(uiPartOffset) ) 3446 { 3447 bBestUseSDC = true; 3448 3449 // copy reconstruction 3450 pcPredYuv->copyPartToPartYuv(pcRecoYuv, uiPartOffset, uiWidth, uiHeight); 3451 3452 // copy DC values 3453 apBestDCOffsets[0] = pcCU->getSDCSegmentDCOffset(0, uiPartOffset); 3454 apBestDCOffsets[1] = pcCU->getSDCSegmentDCOffset(1, uiPartOffset); 3455 } 3456 else 3457 { 3458 bBestUseSDC = false; 3459 #endif 3460 xSetIntraResultQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcRecoYuv ); 3461 3462 UInt uiQPartNum = pcCU->getPic()->getNumPartInCU() >> ( ( pcCU->getDepth(0) + uiInitTrDepth ) << 1 ); 3463 ::memcpy( m_puhQTTempTrIdx, pcCU->getTransformIdx() + uiPartOffset, uiQPartNum * sizeof( UChar ) ); 3464 ::memcpy( m_puhQTTempCbf[0], pcCU->getCbf( TEXT_LUMA ) + uiPartOffset, uiQPartNum * sizeof( UChar ) ); 3465 ::memcpy( m_puhQTTempCbf[1], pcCU->getCbf( TEXT_CHROMA_U ) + uiPartOffset, uiQPartNum * sizeof( UChar ) ); 3466 ::memcpy( m_puhQTTempCbf[2], pcCU->getCbf( TEXT_CHROMA_V ) + uiPartOffset, uiQPartNum * sizeof( UChar ) ); 3467 ::memcpy( m_puhQTTempTransformSkipFlag[0], pcCU->getTransformSkip(TEXT_LUMA) + uiPartOffset, uiQPartNum * sizeof( UChar ) ); 3468 ::memcpy( m_puhQTTempTransformSkipFlag[1], pcCU->getTransformSkip(TEXT_CHROMA_U) + uiPartOffset, uiQPartNum * sizeof( UChar ) ); 3469 ::memcpy( m_puhQTTempTransformSkipFlag[2], pcCU->getTransformSkip(TEXT_CHROMA_V) + uiPartOffset, uiQPartNum * sizeof( UChar ) ); 3470 #if H_3D_DIM_SDC 3471 } 3472 #endif 3473 } 3474 #if HHI_RQT_INTRA_SPEEDUP_MOD 3475 else if( dPUCost < dSecondBestPUCost ) 3476 { 3477 uiSecondBestMode = uiOrgMode; 3478 dSecondBestPUCost = dPUCost; 3479 } 3480 #endif 3481 #if H_3D_DIM_ENC || H_3D_DIM_SDC 3664 3482 } 3665 else3666 {3667 bBestUseSDC = false;3668 #endif3669 xSetIntraResultQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcRecoYuv );3670 3671 UInt uiQPartNum = pcCU->getPic()->getNumPartInCU() >> ( ( pcCU->getDepth(0) + uiInitTrDepth ) << 1 );3672 ::memcpy( m_puhQTTempTrIdx, pcCU->getTransformIdx() + uiPartOffset, uiQPartNum * sizeof( UChar ) );3673 ::memcpy( m_puhQTTempCbf[0], pcCU->getCbf( TEXT_LUMA ) + uiPartOffset, uiQPartNum * sizeof( UChar ) );3674 ::memcpy( m_puhQTTempCbf[1], pcCU->getCbf( TEXT_CHROMA_U ) + uiPartOffset, uiQPartNum * sizeof( UChar ) );3675 ::memcpy( m_puhQTTempCbf[2], pcCU->getCbf( TEXT_CHROMA_V ) + uiPartOffset, uiQPartNum * sizeof( UChar ) );3676 ::memcpy( m_puhQTTempTransformSkipFlag[0], pcCU->getTransformSkip(TEXT_LUMA) + uiPartOffset, uiQPartNum * sizeof( UChar ) );3677 ::memcpy( m_puhQTTempTransformSkipFlag[1], pcCU->getTransformSkip(TEXT_CHROMA_U) + uiPartOffset, uiQPartNum * sizeof( UChar ) );3678 ::memcpy( m_puhQTTempTransformSkipFlag[2], pcCU->getTransformSkip(TEXT_CHROMA_V) + uiPartOffset, uiQPartNum * sizeof( UChar ) );3679 #if H_3D_DIM_SDC3680 }3681 #endif3682 }3683 #if HHI_RQT_INTRA_SPEEDUP_MOD3684 else if( dPUCost < dSecondBestPUCost )3685 {3686 uiSecondBestMode = uiOrgMode;3687 dSecondBestPUCost = dPUCost;3688 }3689 #endif3690 #if H_3D_DIM_ENC || H_3D_DIM_SDC3691 }3692 3483 } // SDC residual loop 3693 3484 #endif … … 3696 3487 #endif 3697 3488 } // Mode loop 3698 3489 3699 3490 #if HHI_RQT_INTRA_SPEEDUP 3700 3491 #if HHI_RQT_INTRA_SPEEDUP_MOD … … 3711 3502 UInt uiOrgMode = uiBestPUMode; 3712 3503 #endif 3713 3504 3714 3505 pcCU->setLumaIntraDirSubParts ( uiOrgMode, uiPartOffset, uiDepth + uiInitTrDepth ); 3715 3506 #if H_3D_DIM_SDC 3716 3507 pcCU->setSDCFlagSubParts(false, uiPartOffset, uiDepth + uiInitTrDepth); 3717 3508 #endif 3718 3509 3719 3510 // set context models 3720 3721 3511 m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST] ); 3512 3722 3513 // determine residual for partition 3723 3514 #if H_3D_VSO … … 3736 3527 #endif 3737 3528 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, false, dPUCost ); 3738 3529 3739 3530 // check r-d cost 3740 3531 if( dPUCost < dBestPUCost ) … … 3747 3538 bBestUseSDC = false; 3748 3539 #endif 3749 3540 3750 3541 xSetIntraResultQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcRecoYuv ); 3751 3542 3752 3543 UInt uiQPartNum = pcCU->getPic()->getNumPartInCU() >> ( ( pcCU->getDepth(0) + uiInitTrDepth ) << 1 ); 3753 3544 ::memcpy( m_puhQTTempTrIdx, pcCU->getTransformIdx() + uiPartOffset, uiQPartNum * sizeof( UChar ) ); … … 3761 3552 } // Mode loop 3762 3553 #endif 3763 3554 3764 3555 //--- update overall distortion --- 3765 3556 uiOverallDistY += uiBestPUDistY; 3766 3557 uiOverallDistC += uiBestPUDistC; 3767 3558 3768 3559 #if H_3D_DIM_SDC 3769 3560 if( bBestUseSDC ) … … 3771 3562 pcCU->setTrIdxSubParts(0, uiPartOffset, uiDepth + uiInitTrDepth); 3772 3563 pcCU->setCbfSubParts(1, 1, 1, uiPartOffset, uiDepth + uiInitTrDepth); 3773 3564 3774 3565 //=== copy best DC segment values back to CU ==== 3775 3566 pcCU->setSDCSegmentDCOffset(apBestDCOffsets[0], 0, uiPartOffset); … … 3779 3570 { 3780 3571 #endif 3781 3782 UInt uiQPartNum = pcCU->getPic()->getNumPartInCU() >> ( ( pcCU->getDepth(0) + uiInitTrDepth ) << 1 );3783 ::memcpy( pcCU->getTransformIdx() + uiPartOffset, m_puhQTTempTrIdx, uiQPartNum * sizeof( UChar ) );3784 ::memcpy( pcCU->getCbf( TEXT_LUMA ) + uiPartOffset, m_puhQTTempCbf[0], uiQPartNum * sizeof( UChar ) );3785 ::memcpy( pcCU->getCbf( TEXT_CHROMA_U ) + uiPartOffset, m_puhQTTempCbf[1], uiQPartNum * sizeof( UChar ) );3786 ::memcpy( pcCU->getCbf( TEXT_CHROMA_V ) + uiPartOffset, m_puhQTTempCbf[2], uiQPartNum * sizeof( UChar ) );3787 ::memcpy( pcCU->getTransformSkip(TEXT_LUMA) + uiPartOffset, m_puhQTTempTransformSkipFlag[0], uiQPartNum * sizeof( UChar ) );3788 ::memcpy( pcCU->getTransformSkip(TEXT_CHROMA_U) + uiPartOffset, m_puhQTTempTransformSkipFlag[1], uiQPartNum * sizeof( UChar ) );3789 ::memcpy( pcCU->getTransformSkip(TEXT_CHROMA_V) + uiPartOffset, m_puhQTTempTransformSkipFlag[2], uiQPartNum * sizeof( UChar ) );3572 //--- update transform index and cbf --- 3573 UInt uiQPartNum = pcCU->getPic()->getNumPartInCU() >> ( ( pcCU->getDepth(0) + uiInitTrDepth ) << 1 ); 3574 ::memcpy( pcCU->getTransformIdx() + uiPartOffset, m_puhQTTempTrIdx, uiQPartNum * sizeof( UChar ) ); 3575 ::memcpy( pcCU->getCbf( TEXT_LUMA ) + uiPartOffset, m_puhQTTempCbf[0], uiQPartNum * sizeof( UChar ) ); 3576 ::memcpy( pcCU->getCbf( TEXT_CHROMA_U ) + uiPartOffset, m_puhQTTempCbf[1], uiQPartNum * sizeof( UChar ) ); 3577 ::memcpy( pcCU->getCbf( TEXT_CHROMA_V ) + uiPartOffset, m_puhQTTempCbf[2], uiQPartNum * sizeof( UChar ) ); 3578 ::memcpy( pcCU->getTransformSkip(TEXT_LUMA) + uiPartOffset, m_puhQTTempTransformSkipFlag[0], uiQPartNum * sizeof( UChar ) ); 3579 ::memcpy( pcCU->getTransformSkip(TEXT_CHROMA_U) + uiPartOffset, m_puhQTTempTransformSkipFlag[1], uiQPartNum * sizeof( UChar ) ); 3580 ::memcpy( pcCU->getTransformSkip(TEXT_CHROMA_V) + uiPartOffset, m_puhQTTempTransformSkipFlag[2], uiQPartNum * sizeof( UChar ) ); 3790 3581 #if H_3D_DIM_SDC 3791 3582 } … … 3803 3594 bChromaSame = true; 3804 3595 } 3805 3596 3806 3597 UInt uiCompWidth = pcCU->getWidth ( 0 ) >> uiInitTrDepth; 3807 3598 UInt uiCompHeight = pcCU->getHeight( 0 ) >> uiInitTrDepth; … … 3855 3646 } 3856 3647 } 3857 3648 3858 3649 //=== update PU data ==== 3859 3650 pcCU->setLumaIntraDirSubParts ( uiBestPUMode, uiPartOffset, uiDepth + uiInitTrDepth ); … … 4183 3974 4184 3975 #if H_3D_DBBP 4185 D BBPTmpData* pDBBPTmpData = pcCU->getDBBPTmpData();3976 DbbpTmpData* pDBBPTmpData = pcCU->getDBBPTmpData(); 4186 3977 if( pcCU->getDBBPFlag(0) ) 4187 3978 { … … 5173 4964 { 5174 4965 #if H_3D_DBBP 5175 D BBPTmpData* pDBBPTmpData = pcCU->getDBBPTmpData();4966 DbbpTmpData* pDBBPTmpData = pcCU->getDBBPTmpData(); 5176 4967 if( pcCU->getDBBPFlag(0) ) 5177 4968 { … … 5534 5325 TComMv cMvPred = *pcMvPred; 5535 5326 5536 #if SONY_MV_V_CONST_C00785537 Bool bMv_VRng_Restricted = false;5327 #if H_MV 5328 Bool motVecVertRngRestricted = false; 5538 5329 if( m_pcEncCfg->getUseDisparitySearchRangeRestriction() 5539 5330 && … … 5541 5332 ) 5542 5333 { 5543 bMv_VRng_Restricted = true;5544 } 5545 if ( bBi ) xSetSearchRange ( pcCU, rcMv , iSrchRng, cMvSrchRngLT, cMvSrchRngRB, bMv_VRng_Restricted, m_pcEncCfg->getVerticalDisparitySearchRange() );5546 else xSetSearchRange ( pcCU, cMvPred, iSrchRng, cMvSrchRngLT, cMvSrchRngRB, bMv_VRng_Restricted, m_pcEncCfg->getVerticalDisparitySearchRange() );5334 motVecVertRngRestricted = true; 5335 } 5336 if ( bBi ) xSetSearchRange ( pcCU, rcMv , iSrchRng, cMvSrchRngLT, cMvSrchRngRB, motVecVertRngRestricted, m_pcEncCfg->getVerticalDisparitySearchRange() ); 5337 else xSetSearchRange ( pcCU, cMvPred, iSrchRng, cMvSrchRngLT, cMvSrchRngRB, motVecVertRngRestricted, m_pcEncCfg->getVerticalDisparitySearchRange() ); 5547 5338 #else 5548 5339 if ( bBi ) xSetSearchRange ( pcCU, rcMv , iSrchRng, cMvSrchRngLT, cMvSrchRngRB ); … … 5601 5392 5602 5393 5603 #if SONY_MV_V_CONST_C00785394 #if H_MV 5604 5395 Void TEncSearch::xSetSearchRange ( TComDataCU* pcCU, TComMv& cMvPred, Int iSrchRng, TComMv& rcMvSrchRngLT, TComMv& rcMvSrchRngRB, Bool bMv_VRng_Restricted, Int iVerDispSrchRng ) 5605 5396 #else … … 5621 5412 rcMvSrchRngRB.setVer( cTmpMvPred.getVer() + (iSrchRng << iMvShift) ); 5622 5413 5623 #if SONY_MV_V_CONST_C00785414 #if H_MV 5624 5415 if ( bMv_VRng_Restricted ) { 5625 5416 Int iRestrictMvVrange = ( iVerDispSrchRng - 1 ) << iMvShift ; // -1 to consider subpel search … … 5732 5523 if( ! pcCU->getSlice()->getIsDepth() ) 5733 5524 #endif 5734 rcMv >>= 2;5525 rcMv >>= 2; 5735 5526 // init TZSearchStruct 5736 5527 IntTZSearchStruct cStruct; … … 7369 7160 const UInt uiQTTempAccessLayer = pcCU->getSlice()->getSPS()->getQuadtreeTULog2MaxSize() - uiLog2TrSize; 7370 7161 7371 #if 0 //H_3D_DISABLE_CHROMA7372 Bool bCodeChroma = !pcCU->getSlice()->getIsDepth();7373 #else7374 7162 Bool bCodeChroma = true; 7375 #endif7376 7163 UInt uiTrModeC = uiTrMode; 7377 7164 UInt uiLog2TrSizeC = uiLog2TrSize-1; … … 7515 7302 } 7516 7303 m_pcEntropyCoder->encodeSkipFlag ( pcCU, 0, true ); 7517 #if SEC_DEPTH_INTRA_SKIP_MODE_K00337304 #if H_3D 7518 7305 m_pcEntropyCoder->encodeDIS ( pcCU, 0, true ); 7519 #else7520 #if H_3D_SINGLE_DEPTH7521 m_pcEntropyCoder->encodeSingleDepthMode ( pcCU, 0, true );7522 #endif7523 7306 #endif 7524 7307 m_pcEntropyCoder->encodePredMode( pcCU, 0, true ); 7525 7308 m_pcEntropyCoder->encodePartSize( pcCU, 0, pcCU->getDepth(0), true ); 7526 #if !HHI_MOVE_SYN_K0052 7309 m_pcEntropyCoder->encodePredInfo( pcCU, 0, true ); 7527 7310 #if H_3D_DIM_SDC 7528 7311 m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true ); 7529 7312 #endif 7530 #endif7531 m_pcEntropyCoder->encodePredInfo( pcCU, 0, true );7532 #if HHI_MOVE_SYN_K00527533 #if H_3D_DIM_SDC7534 m_pcEntropyCoder->encodeSDCFlag( pcCU, 0, true );7535 #endif7536 #endif7537 7313 #if H_3D_ARP 7538 7314 m_pcEntropyCoder->encodeARPW( pcCU , 0 ); … … 7541 7317 m_pcEntropyCoder->encodeICFlag( pcCU, 0, true ); 7542 7318 #endif 7543 #if H HI_MOVE_SYN_K00527319 #if H_3D 7544 7320 m_pcEntropyCoder->encodeDBBPFlag( pcCU, 0, true ); 7545 7321 #endif -
trunk/source/Lib/TLibEncoder/TEncSearch.h
r1179 r1196 191 191 TComYuv* pcRecoYuv, 192 192 UInt uiPreCalcDistC ); 193 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033193 #if H_3D 194 194 Void estIntraPredDIS ( TComDataCU* pcCU, 195 195 TComYuv* pcOrgYuv, … … 199 199 UInt& ruiDistC, 200 200 Bool bLumaOnly ); 201 #else 202 #if H_3D_SINGLE_DEPTH 203 Void estIntraPredSingleDepth ( TComDataCU* pcCU, 204 TComYuv* pcOrgYuv, 205 TComYuv* pcPredYuv, 206 TComYuv* pcResiYuv, 207 TComYuv* pcRecoYuv, 208 UInt& ruiDistC, 209 Bool bLumaOnly ); 210 #endif 211 #endif 212 201 #endif 213 202 /// encoder estimation - inter prediction (non-skip) 214 203 Void predInterSearch ( TComDataCU* pcCU, … … 364 353 UInt uiAbsPartIdx, 365 354 UInt stateU0V1Both2 ); 366 #if SEC_DEPTH_INTRA_SKIP_MODE_K0033 355 356 #if H_3D 367 357 Void xIntraCodingDIS ( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, UInt uiPredMode ); 368 #else369 #if H_3D_SINGLE_DEPTH370 Void xIntraCodingSingleDepth( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, Int iTestDepthIdx, Pel * DepthNeighbor );371 #endif372 358 #endif 373 359 #if H_3D_DIM … … 480 466 UInt& ruiSAD ); 481 467 482 #if SONY_MV_V_CONST_C0078468 #if H_MV 483 469 Void xSetSearchRange ( TComDataCU* pcCU, 484 470 TComMv& cMvPred, -
trunk/source/Lib/TLibEncoder/TEncSlice.cpp
r1179 r1196 215 215 rpcSlice->setPicOutputFlag( true ); 216 216 rpcSlice->setPOC( pocCurr ); 217 #if !HHI_INTER_COMP_PRED_K0052218 #if H_3D219 rpcSlice->init3dToolParameters();220 #endif221 #endif222 217 #if H_3D_IC 223 218 rpcSlice->setApplyIC( false ); … … 612 607 rpcSlice->setSliceSegmentMode ( m_pcCfg->getSliceSegmentMode() ); 613 608 rpcSlice->setSliceSegmentArgument ( m_pcCfg->getSliceSegmentArgument() ); 614 #if !HHI_INTER_COMP_PRED_K0052615 #if H_3D_IV_MERGE616 rpcSlice->setMaxNumMergeCand ( m_pcCfg->getMaxNumMergeCand() + ( ( rpcSlice->getMpiFlag( ) || rpcSlice->getIvMvPredFlag( ) || rpcSlice->getViewSynthesisPredFlag( ) ) ? 1 : 0 ));617 #else618 rpcSlice->setMaxNumMergeCand ( m_pcCfg->getMaxNumMergeCand() );619 #endif620 #else621 609 #if !H_3D 622 610 rpcSlice->setMaxNumMergeCand ( m_pcCfg->getMaxNumMergeCand() ); 623 #endif624 611 #endif 625 612 xStoreWPparam( pPPS->getUseWP(), pPPS->getWPBiPred() ); -
trunk/source/Lib/TLibEncoder/TEncTop.cpp
r1179 r1196 91 91 m_aICEnableNum = NULL; 92 92 #endif 93 #if H_3D _ANNEX_SELECTION_FIX93 #if H_3D 94 94 m_cCavlcCoder.setEncTop(this); 95 95 #endif … … 417 417 #endif 418 418 #if H_3D 419 #if HHI_CAM_PARA_K0052420 419 pcPicCurr->setScaleOffset( m_cameraParameters->getCodedScale(), m_cameraParameters->getCodedOffset() ); 421 #else422 pcPicCurr->setScaleOffset( m_aaiCodedScale, m_aaiCodedOffset );423 #endif424 420 #endif 425 421 } … … 768 764 m_cSPS.setSpsInferScalingListFlag ( true ); 769 765 m_cSPS.setSpsScalingListRefLayerId( m_cVPS->getIdRefLayer( getLayerId(), 0 ) ); 770 #if SONY_MV_V_CONST_C0078766 #if H_MV 771 767 if ( m_bUseDisparitySearchRangeRestriction ) 772 768 {
Note: See TracChangeset for help on using the changeset viewer.