Changeset 1039 in 3DVCSoftware for trunk/source
- Timestamp:
- 4 Aug 2014, 11:36:05 (11 years ago)
- Location:
- trunk/source
- Files:
-
- 39 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/source/App/TAppEncoder/TAppEncCfg.cpp
r976 r1039 378 378 #if H_3D_DIM 379 379 ("DMM", m_useDMM, true, "Depth intra model modes") 380 #if SEPARATE_FLAG_I0085 381 ("IVP", m_useIVP, true, "intra-view prediction") 382 #endif 380 383 ("SDC", m_useSDC, true, "Simplified depth coding") 381 384 ("DLT", m_useDLT, true, "Depth lookup table") 385 #endif 386 #if MTK_SINGLE_DEPTH_MODE_I0095 387 ("SingleDepthMode", m_useSingleDepthMode, true, "Single depth mode") 382 388 #endif 383 389 #endif … … 761 767 762 768 #endif //HHI_VSO 769 #if MTK_I0099_VPS_EX2 770 ("LimQtPredFlag", m_bLimQtPredFlag , true , "Use Predictive Coding with QTL" ) 771 #endif 772 #if !MTK_I0099_VPS_EX2 || MTK_I0099_FIX 763 773 #if H_3D_QTLPC 764 774 ("QTL", m_bUseQTL , true , "Use depth Quadtree Limitation" ) 775 #if !MTK_I0099_VPS_EX2 765 776 ("PC", m_bUsePC , true , "Use Predictive Coding with QTL" ) 777 #endif 778 #endif 766 779 #endif 767 780 #if H_3D_IV_MERGE … … 1402 1415 for ( Int i = 0; i < m_layerIdsInSets[lsIdx].size(); i++ ) 1403 1416 { 1417 #if FIX_TICKET_61 1418 xConfirmPara( m_layerIdsInSets[lsIdx][i] < 0 || m_layerIdsInSets[lsIdx][i] >= MAX_NUM_LAYER_IDS, "LayerIdsInSet must be greater than 0 and less than MAX_NUM_LAYER_IDS" ); 1419 #else 1404 1420 xConfirmPara( m_layerIdsInSets[lsIdx][i] < 0 || m_layerIdsInSets[lsIdx].size() >= MAX_NUM_LAYER_IDS, "LayerIdsInSet must be greater than and less than MAX_NUM_LAYER_IDS" ); 1421 #endif 1405 1422 } 1406 1423 } … … 2491 2508 printf("WVSO:%d ", m_bUseWVSO ); 2492 2509 #endif 2510 #if MTK_I0099_VPS_EX2 2511 printf("LimQtPredFlag:%d ", m_bLimQtPredFlag ? 1 : 0); 2512 #endif 2513 #if !MTK_I0099_VPS_EX2 || MTK_I0099_FIX 2493 2514 #if H_3D_QTLPC 2494 2515 printf("QTL:%d ", m_bUseQTL); 2516 #if !MTK_I0099_VPS_EX2 2495 2517 printf("PC:%d " , m_bUsePC ); 2518 #endif 2519 #endif 2496 2520 #endif 2497 2521 #if H_3D_IV_MERGE … … 2520 2544 #if H_3D_DIM 2521 2545 printf("DMM:%d ", m_useDMM ); 2546 #if SEPARATE_FLAG_I0085 2547 printf("IVP:%d ", m_useIVP ); 2548 #endif 2522 2549 printf("SDC:%d ", m_useSDC ); 2523 2550 printf("DLT:%d ", m_useDLT ); 2551 #endif 2552 #if MTK_SINGLE_DEPTH_MODE_I0095 2553 printf("SingleDepthMode:%d ", m_useSingleDepthMode); 2524 2554 #endif 2525 2555 #if H_3D_INTER_SDC -
trunk/source/App/TAppEncoder/TAppEncCfg.h
r976 r1039 131 131 Int m_iSubPUMPILog2Size; 132 132 #endif 133 #endif 134 #if MTK_I0099_VPS_EX2 135 Bool m_bLimQtPredFlag; 133 136 #endif 134 137 #if H_3D_ARP /// < flag and number of weighting factors in ARP … … 470 473 #if H_3D_DIM 471 474 Bool m_useDMM; ///< flag for using DMM 475 #if SEPARATE_FLAG_I0085 476 Bool m_useIVP; 477 #endif 472 478 Bool m_useSDC; ///< flag for using SDC 473 479 Bool m_useDLT; ///< flag for using DLT 474 480 #endif 481 #if MTK_SINGLE_DEPTH_MODE_I0095 482 Bool m_useSingleDepthMode; ///< flag for using single depth mode 483 #endif 484 #if !MTK_I0099_VPS_EX2 || MTK_I0099_FIX 475 485 #if H_3D_QTLPC 476 486 Bool m_bUseQTL; ///< flag for using depth QuadTree Limitation 487 #if !MTK_I0099_VPS_EX2 477 488 Bool m_bUsePC; ///< flag for using Predictive Coding with QTL 489 #endif 490 #endif 478 491 #endif 479 492 #if H_3D_INTER_SDC -
trunk/source/App/TAppEncoder/TAppEncTop.cpp
r976 r1039 199 199 #if H_3D_DIM 200 200 m_cTEncTop.setUseDMM ( isDepth ? m_useDMM : false ); 201 #if SEPARATE_FLAG_I0085 202 m_cTEncTop.setUseIVP ( isDepth ? m_useIVP : false ); 203 #endif 201 204 m_cTEncTop.setUseSDC ( isDepth ? m_useSDC : false ); 202 205 m_cTEncTop.setUseDLT ( isDepth ? m_useDLT : false ); 203 206 #endif 207 #if MTK_SINGLE_DEPTH_MODE_I0095 208 m_cTEncTop.setUseSingleDepthMode ( isDepth ? m_useSingleDepthMode : false ); 209 #endif 210 #if !MTK_I0099_VPS_EX2 || MTK_I0099_FIX 204 211 #if H_3D_QTLPC 205 212 m_cTEncTop.setUseQTL ( isDepth ? m_bUseQTL : false ); 213 #if !MTK_I0099_VPS_EX2 206 214 m_cTEncTop.setUsePC ( isDepth ? m_bUsePC : false ); 215 #endif 216 #endif 207 217 #endif 208 218 //====== Depth Inter SDC ========= … … 1815 1825 { 1816 1826 vps.setSubPULog2Size ( layer, (layer != 1) ? 6: 0 ); 1827 #if MTK_I0099_VPS_EX2 1828 vps.setSubPUMPILog2Size ( layer, (!isLayerZero) ? m_iSubPUMPILog2Size: 0 ); 1829 #endif 1817 1830 } 1818 1831 else … … 1824 1837 #if H_3D_DIM 1825 1838 vps.setVpsDepthModesFlag( layer, isDepth && !isLayerZero && (m_useDMM || m_useSDC || m_useDLT ) ); 1839 #if SEPARATE_FLAG_I0085 1840 vps.setIVPFlag ( layer, isDepth && !isLayerZero && m_useIVP ); 1841 #endif 1826 1842 #endif 1827 1843 … … 1830 1846 { 1831 1847 vps.setIvMvPredFlag (layer, false); 1848 #if SEC_HLS_CLEANUP_I0100 1849 vps.setIvMvScalingFlag (layer, false); 1850 #endif 1832 1851 } 1833 1852 else … … 1841 1860 vps.setIvMvPredFlag ( layer, !isLayerZero && m_ivMvPredFlag[0] ); 1842 1861 } 1843 } 1862 #if SEC_HLS_CLEANUP_I0100 1863 vps.setIvMvScalingFlag (layer, m_ivMvScalingFlag); 1864 #endif 1865 } 1866 #endif 1867 #if MTK_I0099_VPS_EX2 1868 vps.setLimQtPredFlag ( layer, isDepth && m_bLimQtPredFlag ); 1844 1869 #endif 1845 1870 #if H_3D_NBDV_REF … … 1859 1884 #endif 1860 1885 } 1886 #if !MTK_I0099_VPS_EX2 1861 1887 #if H_3D_SPIVMP 1862 1888 vps.setSubPUMPILog2Size( m_iSubPUMPILog2Size ); 1863 1889 #endif 1890 #endif 1864 1891 #if H_3D 1892 #if !SEC_HLS_CLEANUP_I0100 1865 1893 vps.setIvMvScalingFlag( m_ivMvScalingFlag ); 1894 #endif 1866 1895 #endif 1867 1896 } -
trunk/source/Lib/TAppCommon/program_options_lite.h
r872 r1039 378 378 std::string cDescBuffer; 379 379 380 #if !FIX_TICKET_62 380 381 cNameBuffer .resize( name.size() + 10 ); 381 382 cDescBuffer.resize( desc.size() + 10 ); 383 #endif 382 384 383 385 storage.resize(uiMaxNum); 384 386 for ( unsigned int uiK = 0; uiK < uiMaxNum; uiK++ ) 385 387 { 388 389 #if FIX_TICKET_62 390 cNameBuffer .resize( name.size() + 10 ); 391 cDescBuffer.resize( desc.size() + 10 ); 392 #endif 393 386 394 Bool duplicate = (uiK != 0); 387 395 // isn't there are sprintf function for string?? -
trunk/source/Lib/TLibCommon/ContextTables.h
r976 r1039 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 53 #if MTK_SINGLE_DEPTH_MODE_I0095 54 #define NUM_SINGLEDEPTH_FLAG_CTX 1 55 #define NUM_SINGLE_DEPTH_VALUE_DATA_CTX 1 56 #endif 54 57 #define NUM_MERGE_FLAG_EXT_CTX 1 ///< number of context models for merge flag of merge extended 55 58 #define NUM_MERGE_IDX_EXT_CTX 1 ///< number of context models for merge index of merge extended … … 150 153 { CNU, CNU, CNU, }, 151 154 }; 152 155 #if MTK_SINGLE_DEPTH_MODE_I0095 156 static const UChar 157 INIT_SINGLEDEPTH_FLAG[3][NUM_SINGLEDEPTH_FLAG_CTX] = 158 { 159 { 185 }, 160 { 185 }, 161 { 185 }, 162 }; 163 static const UChar 164 INIT_SINGLE_DEPTH_VALUE_DATA[3][NUM_SINGLE_DEPTH_VALUE_DATA_CTX] = 165 { 166 { 137 }, 167 { 137 }, 168 { 137 }, 169 }; 170 #endif 153 171 static const UChar 154 172 INIT_MERGE_FLAG_EXT[3][NUM_MERGE_FLAG_EXT_CTX] = … … 432 450 static const UChar INIT_DBBP_FLAG[3][DBBP_NUM_FLAG_CTX] = 433 451 { 452 #if SEC_DBBP_EXPLICIT_SIG_I0077 453 { CNU }, 454 { CNU }, 455 { CNU }, 456 #else 434 457 { 161 }, 435 458 { 161 }, 436 459 { 161 }, 437 }; 438 #endif 439 440 #endif 460 #endif 461 }; 462 #endif 463 464 #endif -
trunk/source/Lib/TLibCommon/TComDataCU.cpp
r976 r1039 60 60 61 61 m_skipFlag = NULL; 62 62 #if MTK_SINGLE_DEPTH_MODE_I0095 63 m_singleDepthFlag = NULL; 64 m_apSingleDepthValue = NULL; 65 #endif 63 66 m_pePartSize = NULL; 64 67 m_pePredMode = NULL; … … 182 185 183 186 m_skipFlag = new Bool[ uiNumPartition ]; 184 187 #if MTK_SINGLE_DEPTH_MODE_I0095 188 m_singleDepthFlag = new Bool[ uiNumPartition ]; 189 m_apSingleDepthValue = (Pel*)xMalloc(Pel, uiNumPartition); 190 #endif 185 191 m_pePartSize = new Char[ uiNumPartition ]; 186 192 memset( m_pePartSize, SIZE_NONE,uiNumPartition * sizeof( *m_pePartSize ) ); … … 329 335 330 336 if ( m_skipFlag ) { delete[] m_skipFlag; m_skipFlag = NULL; } 331 337 #if MTK_SINGLE_DEPTH_MODE_I0095 338 if ( m_singleDepthFlag ) { delete[] m_singleDepthFlag; m_singleDepthFlag = NULL; } 339 if ( m_apSingleDepthValue ) { xFree(m_apSingleDepthValue); m_apSingleDepthValue = NULL; } 340 #endif 332 341 if ( m_pePartSize ) { delete[] m_pePartSize; m_pePartSize = NULL; } 333 342 if ( m_pePredMode ) { delete[] m_pePredMode; m_pePredMode = NULL; } … … 494 503 TComDataCU * pcFrom = pcPic->getCU(getAddr()); 495 504 m_skipFlag[ui] = pcFrom->getSkipFlag(ui); 505 #if MTK_SINGLE_DEPTH_MODE_I0095 506 m_singleDepthFlag[ui] = pcFrom->getSingleDepthFlag(ui); 507 m_apSingleDepthValue[ui] = pcFrom->getSingleDepthValue(ui); 508 #endif 496 509 m_pePartSize[ui] = pcFrom->getPartitionSize(ui); 497 510 m_pePredMode[ui] = pcFrom->getPredictionMode(ui); … … 550 563 { 551 564 memset( m_skipFlag + firstElement, false, numElements * sizeof( *m_skipFlag ) ); 552 565 #if MTK_SINGLE_DEPTH_MODE_I0095 566 memset( m_singleDepthFlag + firstElement, false, numElements * sizeof( *m_singleDepthFlag ) ); 567 memset( m_apSingleDepthValue + firstElement, 0, numElements * sizeof( *m_apSingleDepthValue ) ); 568 #endif 553 569 memset( m_pePartSize + firstElement, SIZE_NONE, numElements * sizeof( *m_pePartSize ) ); 554 570 memset( m_pePredMode + firstElement, MODE_NONE, numElements * sizeof( *m_pePredMode ) ); … … 738 754 m_puhTransformSkip[2][ui] = 0; 739 755 m_skipFlag[ui] = false; 756 #if MTK_SINGLE_DEPTH_MODE_I0095 757 m_singleDepthFlag[ui] = false; 758 m_apSingleDepthValue[ui] = 0; 759 #endif 740 760 m_pePartSize[ui] = SIZE_NONE; 741 761 m_pePredMode[ui] = MODE_NONE; … … 913 933 { 914 934 m_skipFlag[ui] = false; 935 #if MTK_SINGLE_DEPTH_MODE_I0095 936 m_singleDepthFlag[ui] = false; 937 m_apSingleDepthValue[ui]= 0; 938 #endif 915 939 m_pePartSize[ui] = SIZE_NONE; 916 940 m_pePredMode[ui] = MODE_NONE; … … 934 958 m_puhTransformSkip[2][ui] = pcCU->getTransformSkip(uiPartOffset+ui,TEXT_CHROMA_V); 935 959 m_skipFlag[ui] = pcCU->getSkipFlag(uiPartOffset+ui); 960 #if MTK_SINGLE_DEPTH_MODE_I0095 961 m_singleDepthFlag[ui] = pcCU->getSingleDepthFlag(uiPartOffset+ui); 962 m_apSingleDepthValue[ui] = pcCU->getSingleDepthValue(uiPartOffset+ui); 963 #endif 936 964 m_pePartSize[ui] = pcCU->getPartitionSize(uiPartOffset+ui); 937 965 m_pePredMode[ui] = pcCU->getPredictionMode(uiPartOffset+ui); … … 1083 1111 1084 1112 m_skipFlag=pcCU->getSkipFlag() + uiPart; 1085 1113 #if MTK_SINGLE_DEPTH_MODE_I0095 1114 m_singleDepthFlag = pcCU->getSingleDepthFlag() + uiPart; 1115 m_apSingleDepthValue = pcCU->getSingleDepthValue() + uiPart; 1116 #endif 1086 1117 m_phQP=pcCU->getQP() + uiPart; 1087 1118 m_pePartSize = pcCU->getPartitionSize() + uiPart; … … 1221 1252 1222 1253 m_skipFlag = pcCU->getSkipFlag () + uiAbsPartIdx; 1223 1254 #if MTK_SINGLE_DEPTH_MODE_I0095 1255 m_singleDepthFlag = pcCU->getSingleDepthFlag () + uiAbsPartIdx; 1256 m_apSingleDepthValue = pcCU->getSingleDepthValue () + uiAbsPartIdx; 1257 #endif 1224 1258 m_pePartSize = pcCU->getPartitionSize () + uiAbsPartIdx; 1225 1259 #if H_3D_NBDV … … 1297 1331 Int sizeInChar = sizeof( Char ) * uiNumPartition; 1298 1332 memcpy( m_skipFlag + uiOffset, pcCU->getSkipFlag(), sizeof( *m_skipFlag ) * uiNumPartition ); 1333 #if MTK_SINGLE_DEPTH_MODE_I0095 1334 memcpy( m_singleDepthFlag + uiOffset, pcCU->getSingleDepthFlag(), sizeof( *m_singleDepthFlag ) * uiNumPartition ); 1335 memcpy( m_apSingleDepthValue + uiOffset, pcCU->getSingleDepthValue(), sizeof( *m_apSingleDepthValue ) * uiNumPartition); 1336 #endif 1299 1337 memcpy( m_phQP + uiOffset, pcCU->getQP(), sizeInChar ); 1300 1338 memcpy( m_pePartSize + uiOffset, pcCU->getPartitionSize(), sizeof( *m_pePartSize ) * uiNumPartition ); … … 1417 1455 1418 1456 memcpy( rpcCU->getSkipFlag() + m_uiAbsIdxInLCU, m_skipFlag, sizeof( *m_skipFlag ) * m_uiNumPartition ); 1419 1457 #if MTK_SINGLE_DEPTH_MODE_I0095 1458 memcpy( rpcCU->getSingleDepthFlag() + m_uiAbsIdxInLCU, m_singleDepthFlag, sizeof( *m_singleDepthFlag ) * m_uiNumPartition ); 1459 memcpy( rpcCU->getSingleDepthValue() + m_uiAbsIdxInLCU, m_apSingleDepthValue, sizeof( *m_apSingleDepthValue ) * m_uiNumPartition); 1460 #endif 1420 1461 memcpy( rpcCU->getQP() + m_uiAbsIdxInLCU, m_phQP, sizeInChar ); 1421 1462 #if H_3D_NBDV … … 1533 1574 Int sizeInChar = sizeof( Char ) * uiQNumPart; 1534 1575 memcpy( rpcCU->getSkipFlag() + uiPartOffset, m_skipFlag, sizeof( *m_skipFlag ) * uiQNumPart ); 1535 1576 #if MTK_SINGLE_DEPTH_MODE_I0095 1577 memcpy( rpcCU->getSingleDepthFlag() + uiPartOffset, m_singleDepthFlag, sizeof( *m_singleDepthFlag ) * uiQNumPart ); 1578 memcpy( rpcCU->getSingleDepthValue() + uiPartOffset, m_apSingleDepthValue, sizeof( *m_apSingleDepthValue ) * uiQNumPart); 1579 #endif 1536 1580 memcpy( rpcCU->getQP() + uiPartOffset, m_phQP, sizeInChar ); 1537 1581 memcpy( rpcCU->getPartitionSize() + uiPartOffset, m_pePartSize, sizeof( *m_pePartSize ) * uiQNumPart ); … … 2453 2497 memset( m_skipFlag + absPartIdx, skip, m_pcPic->getNumPartInCU() >> ( 2 * depth ) ); 2454 2498 } 2455 2499 #if MTK_SINGLE_DEPTH_MODE_I0095 2500 Void TComDataCU::setSingleDepthFlagSubParts( Bool singleDepth, UInt absPartIdx, UInt depth ) 2501 { 2502 assert( sizeof( *m_singleDepthFlag) == 1 ); 2503 memset( m_singleDepthFlag + absPartIdx, singleDepth, m_pcPic->getNumPartInCU() >> ( 2 * depth ) ); 2504 } 2505 2506 Void TComDataCU::setSingleDepthValueSubParts(Pel singleDepthValue, UInt uiAbsPartIdx, UInt uiPUIdx, UInt uiDepth ) 2507 { 2508 setSubPartT<Pel>( singleDepthValue, m_apSingleDepthValue, uiAbsPartIdx, uiDepth, uiPUIdx ); 2509 } 2510 #endif 2456 2511 Void TComDataCU::setPredModeSubParts( PredMode eMode, UInt uiAbsPartIdx, UInt uiDepth ) 2457 2512 { … … 2622 2677 } 2623 2678 2679 #if HS_DMM_SIGNALLING_I0120 2680 if( isDimMode( getLumaIntraDir( uiAbsPartIdx ) ) ) 2681 #else 2624 2682 if( isDimMode( getLumaIntraDir( uiAbsPartIdx ) ) && !isDimDeltaDC( getLumaIntraDir( uiAbsPartIdx ) ) ) 2683 #endif 2625 2684 { 2626 2685 return true; … … 2635 2694 // check prediction mode 2636 2695 UInt uiLumaPredMode = getLumaIntraDir( uiAbsPartIdx ); 2696 #if HS_DMM_SIGNALLING_I0120 2697 if( uiLumaPredMode == PLANAR_IDX || ( getDimType( uiLumaPredMode ) == DMM1_IDX ) ) 2698 #else 2637 2699 if( uiLumaPredMode == PLANAR_IDX || ( getDimType( uiLumaPredMode ) == DMM1_IDX && !isDimDeltaDC( uiLumaPredMode ) ) ) 2700 #endif 2638 2701 return true; 2639 2702 … … 3310 3373 for(Int iLoop = 0; iLoop < 2; iLoop ++ ) 3311 3374 { 3375 #if !SEC_SIMP_SHIFTED_DV_I0086 3312 3376 // IvDcShift (Derived from spatial Iv neighboring blocks) 3313 3377 if( iLoop == 1 ) … … 3343 3407 } 3344 3408 } 3409 #endif 3345 3410 3346 3411 /// iLoop = 0 --> IvMCShift … … 3390 3455 } 3391 3456 3457 #if !SEC_SIMP_SHIFTED_DV_I0086 3392 3458 inline Bool TComDataCU::xGetPosFirstAvailDmvCand(Int iCount, Int& posFirstAvailDmvCand ) 3393 3459 { … … 3406 3472 return false; 3407 3473 } 3474 #endif 3408 3475 3409 3476 #endif … … 3854 3921 Void TComDataCU::getInterMergeCandidates( UInt uiAbsPartIdx, UInt uiPUIdx, TComMvField* pcMvFieldNeighbours, UChar* puhInterDirNeighbours 3855 3922 #endif 3856 #if H_3D_VSP 3923 #if H_3D_VSP && !FIX_TICKET_79 3857 3924 , InheritedVSPDisInfo* inheritedVSPDisInfo 3858 3925 #endif … … 3884 3951 ////////////////////////////////// 3885 3952 DisInfo cDisInfo = getDvInfo(uiAbsPartIdx); 3953 #if !FIX_TICKET_79 3886 3954 for(Int i = 0; i < MRG_MAX_NUM_CANDS_MEM; i++) 3887 3955 { 3888 3956 inheritedVSPDisInfo[i].m_acDvInfo = cDisInfo; // To prevent run-time error, this code must be executed always for merging process. 3889 3957 } 3958 #endif 3890 3959 m_cDefaultDisInfo = cDisInfo; 3891 3960 … … 4178 4247 TComMv cMv = cDefaultMvField.getMv() + cMvRounding; 4179 4248 cMv >>= 2; 4249 #if !FIX_TICKET_68 4180 4250 clipMv( cMv ); 4251 #endif 4181 4252 cMvFieldSaved[eCurrRefPicList].setMvField(cMv, iRefPicList) ; 4182 4253 break; … … 5250 5321 #endif 5251 5322 5252 5323 #if !FIX_TICKET_76 5253 5324 #if H_3D_VSP 5254 5325 inline Void TComDataCU::xInheritVSPDisInfo(TComDataCU* pcCURef, UInt uiAbsPartIdx, Int iCount, InheritedVSPDisInfo* inheritedVSPDisInfo) … … 5257 5328 inheritedVSPDisInfo[iCount].m_acDvInfo.m_aVIdxCan = pcCURef->getDvInfo(uiAbsPartIdx).m_aVIdxCan; 5258 5329 } 5330 #endif 5259 5331 #endif 5260 5332 /** Check whether the current PU and a spatial neighboring PU are in a same ME region. … … 5900 5972 Int iColRefViewId = pColCU->getSlice()->getRefPic( eColRefPicList, pColCU->getCUMvField(eColRefPicList)->getRefIdx(uiAbsPartAddr))->getViewIndex(); 5901 5973 iScale = xGetDistScaleFactor( iCurrViewId, iCurrRefViewId, iColViewId, iColRefViewId ); 5974 #if SEC_HLS_CLEANUP_I0100 5975 if ( iScale != 4096 && m_pcSlice->getVPS()->getIvMvScalingFlag(getSlice()->getLayerIdInVps()) ) 5976 #else 5902 5977 if ( iScale != 4096 && m_pcSlice->getVPS()->getIvMvScalingFlag() ) 5978 #endif 5903 5979 { 5904 5980 rcMv = cColMv.scaleMv( iScale ); … … 6083 6159 6084 6160 TComMv cMv; 6161 #if MTK_I0093 6162 Int iDisp = getSlice()->getDepthToDisparityB( 0 )[ 1 << ( getSlice()->getSPS()->getBitDepthY() - 1 ) ]; 6163 #else 6085 6164 Int iDisp = getSlice()->getDepthToDisparityB( 0 )[ 128 ]; 6165 #endif 6086 6166 cMv.setHor(iDisp); 6087 6167 cMv.setVer(0); … … 6091 6171 return true; 6092 6172 } 6173 #endif 6174 6175 #if MTK_SINGLE_DEPTH_MODE_I0095 6176 Bool TComDataCU::getNeighDepth (UInt uiPartIdx, UInt uiPartAddr, Pel* pNeighDepth, Int index) 6177 { 6178 6179 Bool bDepAvail = false; 6180 Pel *pDepth = this->getPic()->getPicYuvRec()->getLumaAddr(); 6181 Int iDepStride = this->getPic()->getPicYuvRec()->getStride(); 6182 6183 Int xP, yP, nPSW, nPSH; 6184 this->getPartPosition(uiPartIdx, xP, yP, nPSW, nPSH); 6185 UInt PicHeight=this->getPic()->getPicYuvRec()->getHeight(); 6186 UInt PicWidth=this->getPic()->getPicYuvRec()->getWidth(); 6187 switch(index) 6188 { 6189 case 0: // Mid Left 6190 if( ( xP != 0 ) && ( ( yP + ( nPSH >> 1 ) ) < PicHeight ) ) 6191 { 6192 *pNeighDepth = pDepth[ (yP+(nPSH>>1)) * iDepStride + (xP-1) ]; 6193 bDepAvail = true; 6194 } 6195 break; 6196 case 1: // Mid Above 6197 if( ( yP != 0 ) && ( ( xP + ( nPSW >> 1 ) ) < PicWidth ) ) 6198 { 6199 *pNeighDepth = pDepth[ (yP-1) * iDepStride + (xP + (nPSW>>1)) ]; 6200 bDepAvail = true; 6201 } 6202 break; 6203 case 2: // Above 6204 if(yP != 0) 6205 { 6206 *pNeighDepth = pDepth[ (yP-1) * iDepStride + (xP) ]; 6207 bDepAvail = true; 6208 } 6209 break; 6210 case 3: // Left 6211 if(xP != 0) 6212 { 6213 *pNeighDepth = pDepth[ (yP) * iDepStride + (xP-1) ]; 6214 bDepAvail = true; 6215 } 6216 break; 6217 case 4: // Above_Left 6218 if(xP != 0 && yP != 0) 6219 { 6220 *pNeighDepth = pDepth[ (yP-1) * iDepStride + (xP-1) ]; 6221 bDepAvail = true; 6222 } 6223 break; 6224 default: 6225 break; 6226 } 6227 return bDepAvail; 6228 } 6229 6093 6230 #endif 6094 6231 #if H_3D_NBDV … … 6650 6787 if( getSlice()->getIsDepth() ) 6651 6788 { 6789 #if MTK_I0099_VPS_EX2 6790 iSubPUSize = 1<<getSlice()->getVPS()->getSubPUMPILog2Size(getSlice()->getLayerId()); 6791 #else 6652 6792 iSubPUSize = 1 << getSlice()->getVPS()->getSubPUMPILog2Size(); 6793 #endif 6653 6794 } 6654 6795 -
trunk/source/Lib/TLibCommon/TComDataCU.h
r976 r1039 110 110 // ------------------------------------------------------------------------------------------------------------------- 111 111 Bool* m_skipFlag; ///< array of skip flags 112 #if MTK_SINGLE_DEPTH_MODE_I0095 113 Bool* m_singleDepthFlag; ///< array of single depth flags 114 Pel* m_apSingleDepthValue; 115 #endif 112 116 Char* m_pePartSize; ///< array of partition sizes 113 117 Char* m_pePredMode; ///< array of prediction modes … … 246 250 #if H_3D_IV_MERGE 247 251 Bool xAddIvMRGCand( Int mrgCandIdx, Int& iCount, Int* ivCandDir, TComMv* ivCandMv, Int* ivCandRefIdx ); 252 #if! SEC_SIMP_SHIFTED_DV_I0086 248 253 Bool xGetPosFirstAvailDmvCand( Int iCount, Int& iFirDispCand ); 254 #endif 249 255 #endif 250 256 … … 347 353 Void setSkipFlag ( UInt idx, Bool skip) { m_skipFlag[idx] = skip; } 348 354 Void setSkipFlagSubParts ( Bool skip, UInt absPartIdx, UInt depth ); 349 355 #if MTK_SINGLE_DEPTH_MODE_I0095 356 Bool* getSingleDepthFlag () { return m_singleDepthFlag; } 357 Bool getSingleDepthFlag (UInt idx) { return m_singleDepthFlag[idx]; } 358 Void setSingleDepthFlag ( UInt idx, Bool singleDepth) { m_singleDepthFlag[idx] = singleDepth; } 359 Void setSingleDepthFlagSubParts ( Bool singleDepth, UInt absPartIdx, UInt depth ); 360 361 Pel* getSingleDepthValue( ) { return m_apSingleDepthValue; } 362 Pel getSingleDepthValue (UInt idx) { return m_apSingleDepthValue[idx]; } 363 Void setSingleDepthValue ( UInt idx, Pel pDepthValue) { m_apSingleDepthValue[idx] = pDepthValue; } 364 Void setSingleDepthValueSubParts (Pel singleDepthValue, UInt uiAbsPartIdx, UInt uiPUIdx, UInt uiDepth ); 365 #endif 350 366 Char* getPredictionMode () { return m_pePredMode; } 351 367 PredMode getPredictionMode ( UInt uiIdx ) { return static_cast<PredMode>( m_pePredMode[uiIdx] ); } … … 489 505 Bool getDispMvPredCan(UInt uiPartIdx, RefPicList eRefPicList, Int iRefIdx, Int* paiPdmRefIdx, TComMv* pacPdmMv, DisInfo* pDis, Int* iPdm ); 490 506 #endif 491 507 #if MTK_SINGLE_DEPTH_MODE_I0095 508 Bool getNeighDepth (UInt uiPartIdx, UInt uiPartAddr, Pel* pNeighDepth, Int index); 509 #endif 492 510 #if H_3D_NBDV_REF 493 511 Pel getMcpFromDM(TComPicYuv* pcBaseViewDepthPicYuv, TComMv* mv, Int iBlkX, Int iBlkY, Int iWidth, Int iHeight, Int* aiShiftLUT ); … … 652 670 Void getInterMergeCandidates ( UInt uiAbsPartIdx, UInt uiPUIdx, TComMvField* pcMFieldNeighbours, UChar* puhInterDirNeighbours 653 671 #endif 654 #if H_3D_VSP 672 #if H_3D_VSP && !FIX_TICKET_79 655 673 , InheritedVSPDisInfo* inheritedVSPDisInfo 656 674 #endif … … 662 680 663 681 #if H_3D_VSP 682 #if !FIX_TICKET_76 664 683 inline Void xInheritVSPDisInfo(TComDataCU* pcCURef, UInt uiAbsPartIdx, Int iCount, InheritedVSPDisInfo* inheritedVSPDisInfo); 684 #endif 665 685 666 686 #if H_3D_SPIVMP … … 750 770 751 771 #endif 772 773 #if SHARP_DMM1_I0110 774 Bool isDMM1UpscaleMode ( UInt uiWidth ){ Bool bDMM1UpsampleModeFlag = true; UInt uiBaseWidth = 16; if( uiBaseWidth >= uiWidth ){ bDMM1UpsampleModeFlag = false; } return bDMM1UpsampleModeFlag; }; 775 UInt getDMM1BasePatternWidth ( UInt uiWidth ){ UInt uiBaseWidth = 16; if( uiBaseWidth >= uiWidth ){ uiBaseWidth = uiWidth; } return uiBaseWidth; } 776 #endif 777 752 778 }; 753 779 -
trunk/source/Lib/TLibCommon/TComMotionInfo.h
r976 r1039 79 79 } IDVInfo; 80 80 #endif 81 #if H_3D_VSP 81 #if H_3D_VSP && !FIX_TICKET_79 82 82 typedef struct _InheritedVSPDisCand 83 83 { -
trunk/source/Lib/TLibCommon/TComPrediction.cpp
r976 r1039 423 423 424 424 UInt dimType = getDimType ( uiIntraMode ); 425 Bool dimDeltaDC = isDimDeltaDC( uiIntraMode ); 425 #if !HS_DMM_SIGNALLING_I0120 426 Bool dimDeltaDC = isDimDeltaDC( uiIntraMode ); 427 #endif 426 428 Bool isDmmMode = (dimType < DMM_NUM_TYPE); 427 429 … … 438 440 case( DMM1_IDX ): 439 441 { 442 #if SHARP_DMM1_I0110 443 dmmSegmentation = pcCU->isDMM1UpscaleMode((UInt)iWidth) ? 444 &(g_dmmWedgeLists[ g_aucConvertToBit[pcCU->getDMM1BasePatternWidth((UInt)iWidth)] ][ pcCU->getDmmWedgeTabIdx( dimType, uiAbsPartIdx ) ]) : 445 &(g_dmmWedgeLists[ g_aucConvertToBit[iWidth] ][ pcCU->getDmmWedgeTabIdx( dimType, uiAbsPartIdx ) ]); 446 #else 440 447 dmmSegmentation = &(g_dmmWedgeLists[ g_aucConvertToBit[iWidth] ][ pcCU->getDmmWedgeTabIdx( dimType, uiAbsPartIdx ) ]); 448 #endif 441 449 } break; 442 450 case( DMM4_IDX ): … … 456 464 } 457 465 assert( dmmSegmentation ); 466 #if SHARP_DMM1_I0110 467 if( dimType == DMM1_IDX && pcCU->isDMM1UpscaleMode((UInt)iWidth) ) 468 { 469 biSegPattern = dmmSegmentation->getScaledPattern((UInt)iWidth); 470 patternStride = iWidth; 471 } 472 else 473 { 474 biSegPattern = dmmSegmentation->getPattern(); 475 patternStride = dmmSegmentation->getStride (); 476 } 477 #else 458 478 biSegPattern = dmmSegmentation->getPattern(); 459 479 patternStride = dmmSegmentation->getStride (); 480 #endif 460 481 } 461 482 #endif … … 474 495 Pel segDC1 = 0; 475 496 Pel segDC2 = 0; 497 #if HS_DMM_SIGNALLING_I0120 498 if( !pcCU->getSDCFlag( uiAbsPartIdx ) ) 499 #else 476 500 if( dimDeltaDC ) 501 #endif 477 502 { 478 503 Pel deltaDC1 = pcCU->getDimDeltaDC( dimType, 0, uiAbsPartIdx ); … … 543 568 pcCU->getSPAbsPartIdx(uiPartAddr, iSPWidth, iSPHeight, i, iNumSPInOneLine, uiSPAddr[i]); 544 569 } 570 #if SHARP_ARP_CHROMA_I0104 571 if( pcCU->getARPW( uiPartAddr ) != 0 ) 572 { 573 return; 574 } 575 #endif 545 576 // horizontal sub-PU merge 546 577 for (Int i=0; i<iNumSP; i++) … … 714 745 Int uiMinDepth = MAX_INT; 715 746 Int uiMaxDepth = 0; 747 #if SEC_DBBP_DMM4_THRESHOLD_I0076 748 iSumDepth = pDepthPels[ 0 ]; 749 iSumDepth += pDepthPels[ uiWidth - 1 ]; 750 iSumDepth += pDepthPels[ uiDepthStride * (uiHeight - 1) ]; 751 iSumDepth += pDepthPels[ uiDepthStride * (uiHeight - 1) + uiWidth - 1 ]; 752 753 uiMinDepth = pDepthPels[ 0 ]; 754 uiMinDepth = std::min( uiMinDepth, (Int)pDepthPels[ uiWidth - 1 ]); 755 uiMinDepth = std::min( uiMinDepth, (Int)pDepthPels[ uiDepthStride * (uiHeight - 1) ]); 756 uiMinDepth = std::min( uiMinDepth, (Int)pDepthPels[ uiDepthStride * (uiHeight - 1) + uiWidth - 1 ]); 757 758 uiMaxDepth = pDepthPels[ 0 ]; 759 uiMaxDepth = std::max( uiMaxDepth, (Int)pDepthPels[ uiWidth - 1 ]); 760 uiMaxDepth = std::max( uiMaxDepth, (Int)pDepthPels[ uiDepthStride * (uiHeight - 1) ]); 761 uiMaxDepth = std::max( uiMaxDepth, (Int)pDepthPels[ uiDepthStride * (uiHeight - 1) + uiWidth - 1 ]); 762 #else 716 763 for (Int y=0; y<uiHeight; y++) 717 764 { … … 734 781 pDepthPels += uiDepthStride; 735 782 } 783 #endif 736 784 737 785 // don't generate mask for blocks with small depth range (encoder decision) … … 742 790 743 791 AOF(uiWidth==uiHeight); 792 #if SEC_DBBP_DMM4_THRESHOLD_I0076 793 Int iMean = iSumDepth >> 2; 794 #else 744 795 Int iSizeInBits = g_aucConvertToBit[uiWidth]+2; 745 796 Int iMean = iSumDepth >> iSizeInBits*2; // iMean /= (uiWidth*uiHeight); 797 #endif 746 798 747 799 // start again for segmentation … … 790 842 } 791 843 844 #if SHARP_DBBP_SIMPLE_FLTER_I0109 845 Void TComPrediction::combineSegmentsWithMask( TComYuv* pInYuv[2], TComYuv* pOutYuv, Bool* pMask, UInt uiWidth, UInt uiHeight, UInt uiPartAddr, UInt partSize ) 846 #else 792 847 Void TComPrediction::combineSegmentsWithMask( TComYuv* pInYuv[2], TComYuv* pOutYuv, Bool* pMask, UInt uiWidth, UInt uiHeight, UInt uiPartAddr ) 848 #endif 793 849 { 794 850 Pel* piSrc[2] = {pInYuv[0]->getLumaAddr(uiPartAddr), pInYuv[1]->getLumaAddr(uiPartAddr)}; … … 798 854 799 855 UInt uiMaskStride= MAX_CU_SIZE; 856 #if !SHARP_DBBP_SIMPLE_FLTER_I0109 800 857 Pel filSrc = 0; 858 #endif 801 859 Pel* tmpTar = 0; 802 860 tmpTar = (Pel *)xMalloc(Pel, uiWidth*uiHeight); … … 822 880 } 823 881 882 #if SHARP_DBBP_SIMPLE_FLTER_I0109 883 if (partSize == SIZE_Nx2N) 884 { 885 for (Int y=0; y<uiHeight; y++) 886 { 887 for (Int x=0; x<uiWidth; x++) 888 { 889 Bool l = (x==0)?pMaskStart[y*uiMaskStride+x]:pMaskStart[y*uiMaskStride+x-1]; 890 Bool r = (x==uiWidth-1)?pMaskStart[y*uiMaskStride+x]:pMaskStart[y*uiMaskStride+x+1]; 891 892 Pel left, right; 893 left = (x==0) ? tmpTar[y*uiWidth+x] : tmpTar[y*uiWidth+x-1]; 894 right = (x==uiWidth-1) ? tmpTar[y*uiWidth+x] : tmpTar[y*uiWidth+x+1]; 895 896 piDst[x] = (l!=r) ? ClipY( Pel(( left + (tmpTar[y*uiWidth+x] << 1) + right ) >> 2 )) : tmpTar[y*uiWidth+x]; 897 } 898 piDst += uiDstStride; 899 } 900 } 901 else // SIZE_2NxN 902 { 903 for (Int y=0; y<uiHeight; y++) 904 { 905 for (Int x=0; x<uiWidth; x++) 906 { 907 Bool t = (y==0)?pMaskStart[y*uiMaskStride+x]:pMaskStart[(y-1)*uiMaskStride+x]; 908 Bool b = (y==uiHeight-1)?pMaskStart[y*uiMaskStride+x]:pMaskStart[(y+1)*uiMaskStride+x]; 909 910 Pel top, bottom; 911 top = (y==0) ? tmpTar[y*uiWidth+x] : tmpTar[(y-1)*uiWidth+x]; 912 bottom = (y==uiHeight-1) ? tmpTar[y*uiWidth+x] : tmpTar[(y+1)*uiWidth+x]; 913 914 piDst[x] = (t!=b) ? ClipY( Pel(( top + (tmpTar[y*uiWidth+x] << 1) + bottom ) >> 2 )) : tmpTar[y*uiWidth+x]; 915 } 916 piDst += uiDstStride; 917 } 918 } 919 #else 824 920 for (Int y=0; y<uiHeight; y++) 825 921 { … … 855 951 piDst += uiDstStride; 856 952 } 953 #endif 954 857 955 if ( tmpTar ) { xFree(tmpTar); tmpTar = NULL; } 858 956 … … 891 989 } 892 990 991 #if SHARP_DBBP_SIMPLE_FLTER_I0109 992 if (partSize == SIZE_Nx2N) 993 { 994 for (Int y=0; y<uiHeightC; y++) 995 { 996 for (Int x=0; x<uiWidthC; x++) 997 { 998 Bool l = (x==0)?pMaskStart[y*2*uiMaskStride+x*2]:pMaskStart[y*2*uiMaskStride+(x-1)*2]; 999 Bool r = (x==uiWidthC-1)?pMaskStart[y*2*uiMaskStride+x*2]:pMaskStart[y*2*uiMaskStride+(x+1)*2]; 1000 1001 Pel leftU, rightU; 1002 leftU = (x==0) ? tmpTarU[y*uiWidthC+x] : tmpTarU[y*uiWidthC+x-1]; 1003 rightU = (x==uiWidthC-1) ? tmpTarU[y*uiWidthC+x] : tmpTarU[y*uiWidthC+x+1]; 1004 Pel leftV, rightV; 1005 leftV = (x==0) ? tmpTarV[y*uiWidthC+x] : tmpTarV[y*uiWidthC+x-1]; 1006 rightV = (x==uiWidthC-1) ? tmpTarV[y*uiWidthC+x] : tmpTarV[y*uiWidthC+x+1]; 1007 1008 if (l!=r) 1009 { 1010 filSrcU = ClipC( Pel(( leftU + (tmpTarU[y*uiWidthC+x] << 1) + rightU ) >> 2 )); 1011 filSrcV = ClipC( Pel(( leftV + (tmpTarV[y*uiWidthC+x] << 1) + rightV ) >> 2 )); 1012 } 1013 else 1014 { 1015 filSrcU = tmpTarU[y*uiWidthC+x]; 1016 filSrcV = tmpTarV[y*uiWidthC+x]; 1017 } 1018 piDstU[x] = filSrcU; 1019 piDstV[x] = filSrcV; 1020 } 1021 piDstU += uiDstStrideC; 1022 piDstV += uiDstStrideC; 1023 } 1024 } 1025 else 1026 { 1027 for (Int y=0; y<uiHeightC; y++) 1028 { 1029 for (Int x=0; x<uiWidthC; x++) 1030 { 1031 Bool t = (y==0)?pMaskStart[y*2*uiMaskStride+x*2]:pMaskStart[(y-1)*2*uiMaskStride+x*2]; 1032 Bool b = (y==uiHeightC-1)?pMaskStart[y*2*uiMaskStride+x*2]:pMaskStart[(y+1)*2*uiMaskStride+x*2]; 1033 1034 Pel topU, bottomU; 1035 topU = (y==0) ? tmpTarU[y*uiWidthC+x] : tmpTarU[(y-1)*uiWidthC+x]; 1036 bottomU = (y==uiHeightC-1) ? tmpTarU[y*uiWidthC+x] : tmpTarU[(y+1)*uiWidthC+x]; 1037 Pel topV, bottomV; 1038 topV = (y==0) ? tmpTarV[y*uiWidthC+x] : tmpTarV[(y-1)*uiWidthC+x]; 1039 bottomV = (y==uiHeightC-1) ? tmpTarV[y*uiWidthC+x] : tmpTarV[(y+1)*uiWidthC+x]; 1040 1041 if (t!=b) 1042 { 1043 filSrcU = ClipC( Pel(( topU + (tmpTarU[y*uiWidthC+x] << 1) + bottomU ) >> 2 )); 1044 filSrcV = ClipC( Pel(( topV + (tmpTarV[y*uiWidthC+x] << 1) + bottomV ) >> 2 )); 1045 } 1046 else 1047 { 1048 filSrcU = tmpTarU[y*uiWidthC+x]; 1049 filSrcV = tmpTarV[y*uiWidthC+x]; 1050 } 1051 piDstU[x] = filSrcU; 1052 piDstV[x] = filSrcV; 1053 } 1054 piDstU += uiDstStrideC; 1055 piDstV += uiDstStrideC; 1056 } 1057 } 1058 #else 893 1059 for (Int y=0; y<uiHeightC; y++) 894 1060 { … … 936 1102 piDstV += uiDstStrideC; 937 1103 } 1104 #endif 938 1105 if ( tmpTarU ) { xFree(tmpTarU); tmpTarU = NULL; } 939 1106 if ( tmpTarV ) { xFree(tmpTarV); tmpTarV = NULL; } … … 1308 1475 pcCU->clipMv(cMv); 1309 1476 TComPicYuv* pcPicYuvRef = pcCU->getSlice()->getRefPic( eRefPicList, iRefIdx )->getPicYuvRec(); 1477 #if QC_I0129_ARP_FIX 1478 xPredInterLumaBlk ( pcCU, pcPicYuvRef, uiPartAddr, &cMv, iWidth, iHeight, rpcYuvPred, bi || ( dW > 0 ), true ); 1479 xPredInterChromaBlk( pcCU, pcPicYuvRef, uiPartAddr, &cMv, iWidth, iHeight, rpcYuvPred, bi || ( dW > 0 ), true ); 1480 #else 1310 1481 xPredInterLumaBlk ( pcCU, pcPicYuvRef, uiPartAddr, &cMv, iWidth, iHeight, rpcYuvPred, bi, true ); 1311 1482 xPredInterChromaBlk( pcCU, pcPicYuvRef, uiPartAddr, &cMv, iWidth, iHeight, rpcYuvPred, bi, true ); 1312 1483 #endif 1313 1484 if( dW > 0 ) 1314 1485 { … … 1318 1489 TComMv cMVwithDisparity = cMv + cDistparity.m_acNBDV; 1319 1490 pcCU->clipMv(cMVwithDisparity); 1491 #if SHARP_ARP_CHROMA_I0104 1492 if (iWidth <= 8) 1493 { 1494 pYuvB0->clear(); pYuvB1->clear(); 1495 } 1496 #endif 1320 1497 1321 1498 assert ( cDistparity.bDV ); … … 1326 1503 1327 1504 pcPicYuvRef = pcPicYuvBaseCol->getPicYuvRec(); 1505 #if QC_I0129_ARP_FIX 1506 xPredInterLumaBlk ( pcCU, pcPicYuvRef, uiPartAddr, &cNBDV, iWidth, iHeight, pYuvB0, true, true ); 1507 #if SHARP_ARP_CHROMA_I0104 1508 if (iWidth > 8) 1509 #endif 1510 xPredInterChromaBlk( pcCU, pcPicYuvRef, uiPartAddr, &cNBDV, iWidth, iHeight, pYuvB0, true, true ); 1511 #else 1328 1512 xPredInterLumaBlk ( pcCU, pcPicYuvRef, uiPartAddr, &cNBDV, iWidth, iHeight, pYuvB0, bi, true ); 1329 1513 xPredInterChromaBlk( pcCU, pcPicYuvRef, uiPartAddr, &cNBDV, iWidth, iHeight, pYuvB0, bi, true ); 1514 #endif 1330 1515 #else 1331 1516 pcPicYuvRef = pcPicYuvBaseCol->getPicYuvRec(); … … 1335 1520 1336 1521 pcPicYuvRef = pcPicYuvBaseRef->getPicYuvRec(); 1522 #if QC_I0129_ARP_FIX 1523 xPredInterLumaBlk ( pcCU, pcPicYuvRef, uiPartAddr, &cMVwithDisparity, iWidth, iHeight, pYuvB1, true, true ); 1524 #if SHARP_ARP_CHROMA_I0104 1525 if (iWidth > 8) 1526 #endif 1527 xPredInterChromaBlk( pcCU, pcPicYuvRef, uiPartAddr, &cMVwithDisparity, iWidth, iHeight, pYuvB1, true, true ); 1528 #else 1337 1529 xPredInterLumaBlk ( pcCU, pcPicYuvRef, uiPartAddr, &cMVwithDisparity, iWidth, iHeight, pYuvB1, bi, true ); 1338 1530 xPredInterChromaBlk( pcCU, pcPicYuvRef, uiPartAddr, &cMVwithDisparity, iWidth, iHeight, pYuvB1, bi, true ); 1339 1531 #endif 1340 1532 pYuvB0->subtractARP( pYuvB0 , pYuvB1 , uiPartAddr , iWidth , iHeight ); 1341 1533 … … 1347 1539 } 1348 1540 } 1541 1542 #if QC_I0051_ARP_SIMP 1543 Bool TComPrediction::xCheckBiInterviewARP( TComDataCU* pcCU, UInt uiPartAddr, Int iWidth, Int iHeight, RefPicList eBaseRefPicList, TComPic*& pcPicYuvCurrTRef, TComMv& cBaseTMV, Int& iCurrTRefPoc ) 1544 { 1545 Int iRefIdx = pcCU->getCUMvField( eBaseRefPicList )->getRefIdx( uiPartAddr ); 1546 TComMv cDMv = pcCU->getCUMvField( eBaseRefPicList )->getMv( uiPartAddr ); 1547 TComPic* pcPicYuvBaseCol = pcCU->getSlice()->getRefPic( eBaseRefPicList, iRefIdx ); 1548 TComPicYuv* pcYuvBaseCol = pcPicYuvBaseCol->getPicYuvRec(); 1549 Int uiLCUAddr,uiAbsPartAddr; 1550 Int irefPUX = pcCU->getCUPelX() + g_auiRasterToPelX[g_auiZscanToRaster[uiPartAddr]] + iWidth/2 + ((cDMv.getHor() + 2)>>2); 1551 Int irefPUY = pcCU->getCUPelY() + g_auiRasterToPelY[g_auiZscanToRaster[uiPartAddr]] + iHeight/2 + ((cDMv.getVer() + 2)>>2); 1552 1553 irefPUX = (Int)Clip3<Int>(0, pcCU->getSlice()->getSPS()-> getPicWidthInLumaSamples()-1, irefPUX); 1554 irefPUY = (Int)Clip3<Int>(0, pcCU->getSlice()->getSPS()->getPicHeightInLumaSamples()-1, irefPUY); 1555 pcYuvBaseCol->getCUAddrAndPartIdx( irefPUX, irefPUY, uiLCUAddr, uiAbsPartAddr); 1556 TComDataCU *pColCU = pcPicYuvBaseCol->getCU( uiLCUAddr ); 1557 1558 TComPic* pcPicYuvBaseTRef = NULL; 1559 pcPicYuvCurrTRef = NULL; 1560 1561 //If there is available motion in base reference list, use it 1562 if(!pColCU->isIntra(uiAbsPartAddr)) 1563 { 1564 for(Int iList = 0; iList < (pColCU->getSlice()->isInterB() ? 2: 1); iList ++) 1565 { 1566 RefPicList eRefPicListCurr = RefPicList(iList); 1567 Int iRef = pColCU->getCUMvField(eRefPicListCurr)->getRefIdx(uiAbsPartAddr); 1568 if( iRef != -1) 1569 { 1570 pcPicYuvBaseTRef = pColCU->getSlice()->getRefPic(eRefPicListCurr, iRef); 1571 Int iCurrPOC = pColCU->getSlice()->getPOC(); 1572 Int iCurrRefPOC = pcPicYuvBaseTRef->getPOC(); 1573 Int iCurrRef = pcCU->getSlice()->getFirstTRefIdx(eRefPicListCurr); 1574 #if MTK_I0072_IVARP_SCALING_FIX 1575 if( iCurrRef >= 0 && iCurrPOC != iCurrRefPOC) 1576 #else 1577 if( iCurrRef >= 0) 1578 #endif 1579 { 1580 pcPicYuvCurrTRef = pcCU->getSlice()->getRefPic(eRefPicListCurr,iCurrRef); 1581 Int iTargetPOC = pcPicYuvCurrTRef->getPOC(); 1582 pcPicYuvBaseTRef = pcCU->getSlice()->getBaseViewRefPic(iTargetPOC, pcPicYuvBaseCol->getViewIndex() ); 1583 if(pcPicYuvBaseTRef) 1584 { 1585 cBaseTMV = pColCU->getCUMvField(eRefPicListCurr)->getMv(uiAbsPartAddr); 1586 Int iScale = pcCU-> xGetDistScaleFactor(iCurrPOC, iTargetPOC, iCurrPOC, iCurrRefPOC); 1587 if ( iScale != 4096 ) 1588 { 1589 cBaseTMV = cBaseTMV.scaleMv( iScale ); 1590 } 1591 iCurrTRefPoc = iTargetPOC; 1592 return true; 1593 } 1594 } 1595 } 1596 } 1597 } 1598 1599 //If there is no available motion in base reference list, use ( 0, 0 ) 1600 if( pcCU->getSlice()->getFirstTRefIdx( eBaseRefPicList ) >= 0 ) 1601 { 1602 cBaseTMV.set( 0, 0 ); 1603 pcPicYuvCurrTRef = pcCU->getSlice()->getRefPic( eBaseRefPicList, pcCU->getSlice()->getFirstTRefIdx( eBaseRefPicList ) ); 1604 iCurrTRefPoc = pcPicYuvCurrTRef->getPOC(); 1605 return true; 1606 } 1607 1608 return false; 1609 } 1610 #endif 1611 1349 1612 Void TComPrediction::xPredInterUniARPviewRef( TComDataCU* pcCU, UInt uiPartAddr, Int iWidth, Int iHeight, RefPicList eRefPicList, TComYuv*& rpcYuvPred, Bool bi, TComMvField * pNewMvFiled ) 1350 1613 { … … 1380 1643 pcYuvBaseCol->getCUAddrAndPartIdx( irefPUX, irefPUY, uiLCUAddr, uiAbsPartAddr); 1381 1644 TComDataCU *pColCU = pcPicYuvBaseCol->getCU( uiLCUAddr ); 1382 1645 #if QC_I0051_ARP_SIMP 1646 if( pcCU->getSlice()->isInterB() && !pcCU->getSlice()->getIsDepth() ) 1647 { 1648 RefPicList eOtherRefList = ( eRefPicList == REF_PIC_LIST_0 ) ? REF_PIC_LIST_1 : REF_PIC_LIST_0; 1649 Int iOtherRefIdx = pcCU->getCUMvField( eOtherRefList )->getRefIdx( uiPartAddr ); 1650 //The other prediction direction is temporal ARP 1651 if( iOtherRefIdx >= 0 && pcCU->getSlice()->getViewIndex() == pcCU->getSlice()->getRefPic( eOtherRefList, iOtherRefIdx )->getViewIndex() ) 1652 { 1653 bTMVAvai = true; 1654 pcPicYuvBaseTRef = pcCU->getSlice()->getRefPic( eOtherRefList, iOtherRefIdx ); 1655 Int iCurrPOC = pcCU->getSlice()->getPOC(); 1656 Int iCurrRefPOC = pcPicYuvBaseTRef->getPOC(); 1657 Int iCurrRef = pcCU->getSlice()->getFirstTRefIdx( eOtherRefList ); 1658 1659 if( iCurrRef >= 0 ) 1660 { 1661 pcPicYuvCurrTRef = pcCU->getSlice()->getRefPic( eOtherRefList,iCurrRef ); 1662 Int iTargetPOC = pcPicYuvCurrTRef->getPOC(); 1663 pcPicYuvBaseTRef = pcCU->getSlice()->getBaseViewRefPic( iTargetPOC, pcPicYuvBaseCol->getViewIndex() ); 1664 if( pcPicYuvBaseTRef ) 1665 { 1666 cBaseTMV = pcCU->getCUMvField( eOtherRefList )->getMv( uiPartAddr ); 1667 Int iScale = pcCU-> xGetDistScaleFactor( iCurrPOC, iTargetPOC, iCurrPOC, iCurrRefPOC ); 1668 if ( iScale != 4096 ) 1669 { 1670 cBaseTMV = cBaseTMV.scaleMv( iScale ); 1671 } 1672 } 1673 else 1674 { 1675 dW = 0; 1676 } 1677 } 1678 else 1679 { 1680 dW = 0; 1681 } 1682 } 1683 1684 //Both prediction directions are inter-view ARP 1685 if ( iOtherRefIdx >= 0 && !bTMVAvai ) 1686 { 1687 RefPicList eBaseList = REF_PIC_LIST_0; 1688 Int iCurrTRefPoc; 1689 bTMVAvai = ( eBaseList != eRefPicList ) && ( pcCU->getSlice()->getViewIndex() != pcCU->getSlice()->getRefPic( eOtherRefList, iOtherRefIdx )->getViewIndex() ); 1690 1691 if ( bTMVAvai ) 1692 { 1693 if( xCheckBiInterviewARP( pcCU, uiPartAddr, iWidth, iHeight, eBaseList, pcPicYuvCurrTRef, cBaseTMV, iCurrTRefPoc ) ) 1694 { 1695 pcPicYuvBaseTRef = pcCU->getSlice()->getBaseViewRefPic( iCurrTRefPoc, pcPicYuvBaseCol->getViewIndex() ); 1696 if ( pcPicYuvBaseTRef == NULL ) 1697 { 1698 dW = 0; 1699 } 1700 } 1701 else 1702 { 1703 dW = 0; 1704 } 1705 } 1706 } 1707 } 1708 1709 if( !pColCU->isIntra( uiAbsPartAddr ) && !bTMVAvai ) 1710 #else 1383 1711 if(!pColCU->isIntra(uiAbsPartAddr)) 1712 #endif 1384 1713 { 1385 1714 TComMvField puMVField; … … 1394 1723 Int iCurrRefPOC = pcPicYuvBaseTRef->getPOC(); 1395 1724 Int iCurrRef = pcCU->getSlice()->getFirstTRefIdx(eRefPicListCurr); 1725 #if MTK_I0072_IVARP_SCALING_FIX 1726 if (iCurrRef >= 0 && iCurrRefPOC != iCurrPOC) 1727 #else 1396 1728 if( iCurrRef >= 0) 1729 #endif 1397 1730 { 1398 1731 pcPicYuvCurrTRef = pcCU->getSlice()->getRefPic(eRefPicListCurr,iCurrRef); … … 1421 1754 pcPicYuvCurrTRef = pcCU->getSlice()->getRefPic (eRefPicList, pcCU->getSlice()->getFirstTRefIdx(eRefPicList)); 1422 1755 } 1423 1756 #if QC_I0129_ARP_FIX 1757 xPredInterLumaBlk ( pcCU, pcYuvBaseCol, uiPartAddr, &cTempDMv, iWidth, iHeight, rpcYuvPred, bi || ( dW > 0 && bTMVAvai ), bTMVAvai); 1758 xPredInterChromaBlk( pcCU, pcYuvBaseCol, uiPartAddr, &cTempDMv, iWidth, iHeight, rpcYuvPred, bi || ( dW > 0 && bTMVAvai ), bTMVAvai); 1759 #else 1424 1760 xPredInterLumaBlk ( pcCU, pcYuvBaseCol, uiPartAddr, &cTempDMv, iWidth, iHeight, rpcYuvPred, bi, bTMVAvai); 1425 1761 xPredInterChromaBlk( pcCU, pcYuvBaseCol, uiPartAddr, &cTempDMv, iWidth, iHeight, rpcYuvPred, bi, bTMVAvai); 1426 1762 #endif 1427 1763 if( dW > 0 && bTMVAvai ) 1428 1764 { … … 1435 1771 pcCU->clipMv(cBaseTMV); 1436 1772 pcCU->clipMv(cTempMv); 1437 1773 #if SHARP_ARP_CHROMA_I0104 1774 if (iWidth <= 8) 1775 { 1776 pYuvCurrTRef->clear(); pYuvBaseTRef->clear(); 1777 } 1778 #endif 1779 #if QC_I0129_ARP_FIX 1780 xPredInterLumaBlk ( pcCU, pcYuvCurrTref, uiPartAddr, &cBaseTMV, iWidth, iHeight, pYuvCurrTRef, true, true); 1781 #if SHARP_ARP_CHROMA_I0104 1782 if (iWidth > 8) 1783 #endif 1784 xPredInterChromaBlk( pcCU, pcYuvCurrTref, uiPartAddr, &cBaseTMV, iWidth, iHeight, pYuvCurrTRef, true, true); 1785 xPredInterLumaBlk ( pcCU, pcYuvBaseTref, uiPartAddr, &cTempMv, iWidth, iHeight, pYuvBaseTRef, true, true); 1786 #if SHARP_ARP_CHROMA_I0104 1787 if (iWidth > 8) 1788 #endif 1789 xPredInterChromaBlk( pcCU, pcYuvBaseTref, uiPartAddr, &cTempMv, iWidth, iHeight, pYuvBaseTRef, true, true); 1790 #else 1438 1791 xPredInterLumaBlk ( pcCU, pcYuvCurrTref, uiPartAddr, &cBaseTMV, iWidth, iHeight, pYuvCurrTRef, bi, true); 1439 1792 xPredInterChromaBlk( pcCU, pcYuvCurrTref, uiPartAddr, &cBaseTMV, iWidth, iHeight, pYuvCurrTRef, bi, true); … … 1441 1794 xPredInterChromaBlk( pcCU, pcYuvBaseTref, uiPartAddr, &cTempMv, iWidth, iHeight, pYuvBaseTRef, bi, true); 1442 1795 1796 #endif 1443 1797 pYuvCurrTRef->subtractARP( pYuvCurrTRef , pYuvBaseTRef , uiPartAddr , iWidth , iHeight ); 1444 1798 if(dW == 2) … … 1974 2328 Int iRecStride = ( eType == TEXT_LUMA ) ? pRecPic->getStride() : pRecPic->getCStride(); 1975 2329 Int iRefStride = ( eType == TEXT_LUMA ) ? pRefPic->getStride() : pRefPic->getCStride(); 2330 #if SEC_IC_NEIGHBOR_CLIP_I0080 2331 Int iRefOffset, iHor, iVer; 2332 #else 1976 2333 Int iCUPelX, iCUPelY, iRefX, iRefY, iRefOffset, iHor, iVer; 1977 2334 1978 2335 iCUPelX = pcCU->getCUPelX() + g_auiRasterToPelX[g_auiZscanToRaster[pcCU->getZorderIdxInCU()]]; 1979 2336 iCUPelY = pcCU->getCUPelY() + g_auiRasterToPelY[g_auiZscanToRaster[pcCU->getZorderIdxInCU()]]; 2337 #endif 1980 2338 iHor = pcCU->getSlice()->getIsDepth() ? pMv->getHor() : ( ( pMv->getHor() + 2 ) >> 2 ); 1981 2339 iVer = pcCU->getSlice()->getIsDepth() ? pMv->getVer() : ( ( pMv->getVer() + 2 ) >> 2 ); 2340 #if !SEC_IC_NEIGHBOR_CLIP_I0080 1982 2341 iRefX = iCUPelX + iHor; 1983 2342 iRefY = iCUPelY + iVer; 2343 #endif 1984 2344 if( eType != TEXT_LUMA ) 1985 2345 { … … 1997 2357 Int precShift = std::max(0, (( eType == TEXT_LUMA ) ? g_bitDepthY : g_bitDepthC) - 12); 1998 2358 2359 #if SEC_IC_NEIGHBOR_CLIP_I0080 2360 if( pcCU->getPUAbove( uiTmpPartIdx, pcCU->getZorderIdxInCU() ) ) 2361 #else 1999 2362 if( pcCU->getPUAbove( uiTmpPartIdx, pcCU->getZorderIdxInCU() ) && iCUPelY > 0 && iRefY > 0 ) 2363 #endif 2000 2364 { 2001 2365 iRefOffset = iHor + iVer * iRefStride - iRefStride; … … 2027 2391 } 2028 2392 2029 2393 #if SEC_IC_NEIGHBOR_CLIP_I0080 2394 if( pcCU->getPULeft( uiTmpPartIdx, pcCU->getZorderIdxInCU() ) ) 2395 #else 2030 2396 if( pcCU->getPULeft( uiTmpPartIdx, pcCU->getZorderIdxInCU() ) && iCUPelX > 0 && iRefX > 0 ) 2397 #endif 2031 2398 { 2032 2399 iRefOffset = iHor + iVer * iRefStride - 1; … … 2061 2428 iCountShift += iCountShift > 0 ? 1 : ( g_aucConvertToBit[ uiWidth ] + 1 ); 2062 2429 } 2430 2431 #if FIX_TICKET_71 2432 if( iCountShift == 0 ) 2433 { 2434 a = ( 1 << IC_CONST_SHIFT ); 2435 b = 0; 2436 return; 2437 } 2438 #endif 2063 2439 2064 2440 xy += xx >> IC_REG_COST_SHIFT; … … 2177 2553 // find contour for texture luma block 2178 2554 UInt iDC = 0; 2555 #if SEC_DBBP_DMM4_THRESHOLD_I0076 2556 iDC = piRefBlkY[ 0 ]; 2557 iDC += piRefBlkY[ uiWidth - 1 ]; 2558 iDC += piRefBlkY[ uiWidth * (uiHeight - 1) ]; 2559 iDC += piRefBlkY[ uiWidth * (uiHeight - 1) + uiWidth - 1 ]; 2560 iDC = iDC >> 2; 2561 #else 2179 2562 for( UInt k = 0; k < (uiWidth*uiHeight); k++ ) 2180 2563 { … … 2184 2567 Int cuMaxLog2Size = g_aucConvertToBit[g_uiMaxCUWidth]+2; // 2185 2568 iDC = iDC >> (cuMaxLog2Size - pcCU->getDepth(0))*2; // iDC /= (uiWidth*uiHeight); 2569 #endif 2186 2570 2187 2571 piRefBlkY = cTempYuv.getLumaAddr(); -
trunk/source/Lib/TLibCommon/TComPrediction.h
r884 r1039 90 90 #if H_3D_ARP 91 91 Void xPredInterUniARP ( TComDataCU* pcCU, UInt uiPartAddr, Int iWidth, Int iHeight, RefPicList eRefPicList, TComYuv*& rpcYuvPred, Bool bi=false, TComMvField * pNewMvFiled = NULL ); 92 #if QC_I0051_ARP_SIMP 93 Bool xCheckBiInterviewARP ( TComDataCU* pcCU, UInt uiPartAddr, Int iWidth, Int iHeight, RefPicList eBaseRefPicList, TComPic*& pcPicYuvCurrTRef, TComMv& cBaseTMV, Int& iCurrTRefPoc ); 94 #endif 92 95 Void xPredInterUniARPviewRef( TComDataCU* pcCU, UInt uiPartAddr, Int iWidth, Int iHeight, RefPicList eRefPicList, TComYuv*& rpcYuvPred, Bool bi, TComMvField * pNewMvFiled = NULL ); 93 96 #endif … … 176 179 PartSize getPartitionSizeFromDepth(Pel* pDepthPels, UInt uiDepthStride, UInt uiSize); 177 180 Bool getSegmentMaskFromDepth( Pel* pDepthPels, UInt uiDepthStride, UInt uiWidth, UInt uiHeight, Bool* pMask ); 181 #if SHARP_DBBP_SIMPLE_FLTER_I0109 182 Void combineSegmentsWithMask( TComYuv* pInYuv[2], TComYuv* pOutYuv, Bool* pMask, UInt uiWidth, UInt uiHeight, UInt uiPartAddr, UInt partSize ); 183 #else 178 184 Void combineSegmentsWithMask( TComYuv* pInYuv[2], TComYuv* pOutYuv, Bool* pMask, UInt uiWidth, UInt uiHeight, UInt uiPartAddr = 0 ); 185 #endif 179 186 #endif 180 187 -
trunk/source/Lib/TLibCommon/TComRom.cpp
r976 r1039 336 336 HALF_PEL, // 8x8 337 337 FULL_PEL, // 16x16 338 #if SHARP_DMM1_I0110 339 FULL_PEL, // 32x32 340 FULL_PEL, // 64x64 341 FULL_PEL // 128x128 342 #else 338 343 DOUBLE_PEL, // 32x32 339 344 DOUBLE_PEL, // 64x64 340 345 DOUBLE_PEL // 128x128 346 #endif 341 347 }; 342 348 … … 348 354 { //2x2 4x4 8x8 16x16 32x32 64x64 349 355 0, 4, 7, 8, 8, 0 }; 356 357 #if SHARP_DMM1_I0110 358 Bool g_wedgePattern[32*32]; 359 #endif 350 360 351 361 extern std::vector< std::vector<TComWedgelet> > g_dmmWedgeLists; … … 646 656 if( !g_dmmWedgeLists.empty() ) return; 647 657 658 #if SHARP_DMM1_I0110 659 for( UInt ui = g_aucConvertToBit[DIM_MIN_SIZE]; ui < (g_aucConvertToBit[DIM_MAX_SIZE]); ui++ ) 660 #else 648 661 for( UInt ui = g_aucConvertToBit[DIM_MIN_SIZE]; ui < (g_aucConvertToBit[DIM_MAX_SIZE]+1); ui++ ) 662 #endif 649 663 { 650 664 UInt uiWedgeBlockSize = ((UInt)DIM_MIN_SIZE)<<ui; … … 730 744 switch( eWedgeRes ) 731 745 { 746 #if !SHARP_DMM1_I0110 732 747 case( DOUBLE_PEL ): { uiBlockSize = (uiWidth>>1); break; } 748 #endif 733 749 case( FULL_PEL ): { uiBlockSize = uiWidth; break; } 734 750 case( HALF_PEL ): { uiBlockSize = (uiWidth<<1); break; } -
trunk/source/Lib/TLibCommon/TComRom.h
r976 r1039 166 166 extern const UChar g_dmm3IntraTabIdxBits[6]; 167 167 168 #if SHARP_DMM1_I0110 169 extern Bool g_wedgePattern[32*32]; 170 #endif 171 168 172 extern std::vector< std::vector<TComWedgelet> > g_dmmWedgeLists; 169 173 extern std::vector< std::vector<TComWedgeRef> > g_dmmWedgeRefLists; -
trunk/source/Lib/TLibCommon/TComSlice.cpp
r976 r1039 139 139 , m_depthToDisparityF ( NULL ) 140 140 #endif 141 #if MTK_SINGLE_DEPTH_MODE_I0095 142 , m_bApplySingleDepthMode (false) 143 #endif 141 144 #endif 142 145 { … … 644 647 645 648 TComPic** refPicSetStCurr [2] = { RefPicSetStCurr0, RefPicSetStCurr1 }; 649 #if FIX_WARNING 650 Int numPocStCurr[2] = { (Int)NumPocStCurr0, (Int)NumPocStCurr1 }; 651 #else 646 652 Int numPocStCurr[2] = { NumPocStCurr0, NumPocStCurr1 }; 653 #endif 647 654 648 655 for (Int li = 0; li < ((m_eSliceType==B_SLICE) ? 2 : 1); li++) … … 1091 1098 m_interLayerPredLayerIdc[ layer ] = pSrc->m_interLayerPredLayerIdc[ layer ]; 1092 1099 } 1100 #endif 1101 #if MTK_SINGLE_DEPTH_MODE_I0095 1102 m_bApplySingleDepthMode = pSrc->m_bApplySingleDepthMode; 1093 1103 #endif 1094 1104 #if H_3D_IC … … 1942 1952 m_viewIndex [i] = -1; 1943 1953 m_vpsDepthModesFlag [i] = false; 1954 #if SEC_HLS_CLEANUP_I0100 1955 m_ivMvScalingFlag[i] = true; 1956 #else 1944 1957 m_ivMvScalingFlag = true; 1958 #endif 1959 #if SEPARATE_FLAG_I0085 1960 m_bIVPFlag [i] = false; 1961 #endif 1945 1962 #endif 1946 1963 … … 1974 1991 #endif 1975 1992 #endif 1993 #if MTK_I0099_VPS_EX2 1994 m_bLimQtPredFlag [ i ] = false; 1995 #endif 1976 1996 #if H_3D_VSP 1977 1997 m_viewSynthesisPredFlag[ i ] = false; … … 1982 2002 #if H_3D_INTER_SDC 1983 2003 m_bInterSDCFlag [ i ] = false; 2004 #endif 2005 #if SEPARATE_FLAG_I0085 2006 m_bIVPFlag [ i ] = false; 1984 2007 #endif 1985 2008 #if H_3D_DBBP … … 2502 2525 , m_pcmLog2MaxSize ( 5) 2503 2526 , m_uiPCMLog2MinSize ( 7) 2527 #if !MTK_I0099_VPS_EX2 2504 2528 #if H_3D_QTLPC 2505 2529 , m_bUseQTL (false) 2506 2530 , m_bUsePC (false) 2531 #endif 2507 2532 #endif 2508 2533 , m_bitDepthY ( 8) … … 2774 2799 // allocate some memory and initialize with default mapping 2775 2800 m_iNumDepthmapValues[i] = ((1 << m_uiDepthViewBitDepth)-1)+1; 2801 #if !FIX_TICKET_77 2776 2802 m_iBitsPerDepthValue[i] = numBitsForValue(m_iNumDepthmapValues[i]); 2777 2803 #endif 2778 2804 m_iDepthValue2Idx[i] = (Int*) xMalloc(Int, m_iNumDepthmapValues[i]); 2779 2805 m_iIdx2DepthValue[i] = (Int*) xMalloc(Int, m_iNumDepthmapValues[i]); … … 2864 2890 // update DLT variables 2865 2891 m_iNumDepthmapValues[layerIdInVps] = iNumDepthValues; 2892 #if !FIX_TICKET_77 2866 2893 m_iBitsPerDepthValue[layerIdInVps] = numBitsForValue(m_iNumDepthmapValues[layerIdInVps]); 2894 #endif 2867 2895 } 2868 2896 -
trunk/source/Lib/TLibCommon/TComSlice.h
r976 r1039 798 798 #if H_3D_IV_MERGE 799 799 Bool m_ivMvPredFlag [ MAX_NUM_LAYERS ]; 800 #if SEC_HLS_CLEANUP_I0100 801 Bool m_ivMvScalingFlag [ MAX_NUM_LAYERS ]; 802 #endif 800 803 #if H_3D_SPIVMP 801 804 Int m_iSubPULog2Size [MAX_NUM_LAYERS ]; 805 #if MTK_I0099_VPS_EX2 806 Int m_iSubPUMPILog2Size [MAX_NUM_LAYERS ]; 807 #else 802 808 Int m_iSubPUMPILog2Size; 803 809 #endif 810 #endif 811 #endif 812 #if MTK_I0099_VPS_EX2 813 Bool m_bLimQtPredFlag [ MAX_NUM_LAYERS ]; 804 814 #endif 805 815 #if H_3D_VSP … … 810 820 #endif 811 821 Bool m_vpsDepthModesFlag [MAX_NUM_LAYERS ]; 822 #if SEPARATE_FLAG_I0085 823 Bool m_bIVPFlag [MAX_NUM_LAYERS ]; 824 #endif 812 825 813 826 #if H_3D … … 817 830 Int ***m_aaaiCodedScale ; 818 831 Int ***m_aaaiCodedOffset; 832 833 #if !SEC_HLS_CLEANUP_I0100 819 834 Bool m_ivMvScalingFlag; 835 #endif 836 820 837 #endif 821 838 #if H_3D_INTER_SDC … … 1130 1147 Int getSubPULog2Size(Int layerIdInVps) { return m_iSubPULog2Size[layerIdInVps]; } 1131 1148 Void setSubPULog2Size(Int layerIdInVps, Int u) { m_iSubPULog2Size[layerIdInVps] = u;} 1149 #if MTK_I0099_VPS_EX2 1150 Int getSubPUMPILog2Size(Int layerIdInVps) { return m_iSubPUMPILog2Size[layerIdInVps]; } 1151 Void setSubPUMPILog2Size(Int layerIdInVps, Int u) { m_iSubPUMPILog2Size[layerIdInVps] = u;} 1152 #else 1132 1153 Int getSubPUMPILog2Size( ) { return m_iSubPUMPILog2Size; } 1133 1154 Void setSubPUMPILog2Size( Int u ) { m_iSubPUMPILog2Size = u; } 1134 1155 #endif 1156 #endif 1157 #endif 1158 #if MTK_I0099_VPS_EX2 1159 Void setLimQtPredFlag ( Int layerIdInVps, Bool val ) { m_bLimQtPredFlag[ layerIdInVps ] = val; } 1160 Bool getLimQtPredFlag ( Int layerIdInVps ) { return m_bLimQtPredFlag[layerIdInVps];} 1135 1161 #endif 1136 1162 #if H_3D_VSP … … 1144 1170 Void setVpsDepthModesFlag( Int layerIdInVps, Bool val ) { m_vpsDepthModesFlag[ layerIdInVps ] = val; } 1145 1171 Bool getVpsDepthModesFlag( Int layerIdInVps ) { return m_vpsDepthModesFlag[ layerIdInVps ]; } 1146 1172 #if SEPARATE_FLAG_I0085 1173 Void setIVPFlag( Int layerIdInVps, Bool val ) { m_bIVPFlag[ layerIdInVps ] = val; } 1174 Bool getIVPFlag( Int layerIdInVps ) { return m_bIVPFlag[ layerIdInVps ]; } 1175 #endif 1176 1177 #if SEC_HLS_CLEANUP_I0100 1178 Bool getIvMvScalingFlag ( Int layerIdInVps ) { return m_ivMvScalingFlag[ layerIdInVps ]; } 1179 Void setIvMvScalingFlag (Int layerIdInVps, Bool b ) { m_ivMvScalingFlag[ layerIdInVps ] = b; } 1180 #else 1147 1181 Bool getIvMvScalingFlag ( ) { return m_ivMvScalingFlag; } 1148 1182 Void setIvMvScalingFlag ( Bool b ) { m_ivMvScalingFlag = b; } 1183 #endif 1184 1149 1185 #if H_3D_INTER_SDC 1150 1186 Bool getInterSDCFlag ( Int layerIdInVps ) { return m_bInterSDCFlag[layerIdInVps]; } … … 1171 1207 Bool m_bInterViewDltPredEnableFlag[ MAX_NUM_LAYERS ]; 1172 1208 1209 #if !FIX_TICKET_77 1173 1210 Int m_iBitsPerDepthValue [ MAX_NUM_LAYERS ]; 1211 #endif 1174 1212 Int m_iNumDepthmapValues [ MAX_NUM_LAYERS ]; 1175 1213 Int* m_iDepthValue2Idx [ MAX_NUM_LAYERS ]; … … 1198 1236 UInt getDepthViewBitDepth() { return m_uiDepthViewBitDepth; } 1199 1237 1238 #if !FIX_TICKET_77 1200 1239 Int getBitsPerDepthValue( Int layerIdInVps ) { return getUseDLTFlag(layerIdInVps)?m_iBitsPerDepthValue[layerIdInVps]:g_bitDepthY; } 1240 #endif 1201 1241 Int getNumDepthValues( Int layerIdInVps ) { return getUseDLTFlag(layerIdInVps)?m_iNumDepthmapValues[layerIdInVps]:((1 << g_bitDepthY)-1); } 1202 1242 Int depthValue2idx( Int layerIdInVps, Pel value ) { return getUseDLTFlag(layerIdInVps)?m_iDepthValue2Idx[layerIdInVps][value]:value; } 1243 #if RWTH_DLT_CLIP_I0057 1244 Pel idx2DepthValue( Int layerIdInVps, UInt uiIdx ) { return getUseDLTFlag(layerIdInVps)?m_iIdx2DepthValue[layerIdInVps][ClipY(uiIdx)]:uiIdx; } 1245 #else 1203 1246 Pel idx2DepthValue( Int layerIdInVps, UInt uiIdx ) { return getUseDLTFlag(layerIdInVps)?m_iIdx2DepthValue[layerIdInVps][uiIdx]:uiIdx; } 1247 #endif 1204 1248 Void setDepthLUTs( Int layerIdInVps, Int* idx2DepthValue = NULL, Int iNumDepthValues = 0 ); 1205 1249 #if H_3D_DELTA_DLT … … 1466 1510 Bool m_useAMP; 1467 1511 1512 #if !MTK_I0099_VPS_EX2 1468 1513 #if H_3D_QTLPC 1469 1514 Bool m_bUseQTL; 1470 1515 Bool m_bUsePC; 1516 #endif 1471 1517 #endif 1472 1518 // Parameter … … 1732 1778 1733 1779 #endif 1780 #if !MTK_I0099_VPS_EX2 1734 1781 #if H_3D_QTLPC 1735 1782 Void setUseQTL( Bool b ) { m_bUseQTL = b; } … … 1737 1784 Void setUsePC ( Bool b ) { m_bUsePC = b; } 1738 1785 Bool getUsePC () { return m_bUsePC; } 1786 #endif 1739 1787 #endif 1740 1788 #if H_MV … … 2205 2253 UInt m_aiDDDShift [MAX_NUM_LAYERS]; 2206 2254 #endif 2207 2255 #if MTK_SINGLE_DEPTH_MODE_I0095 2256 Bool m_bApplySingleDepthMode; 2257 #endif 2208 2258 public: 2209 2259 TComSlice(); … … 2275 2325 #if H_3D 2276 2326 TComPic* getTexturePic () { return m_ivPicsCurrPoc[0][ m_viewIndex ]; } 2327 #endif 2328 #if MTK_SINGLE_DEPTH_MODE_I0095 2329 Void setApplySingleDepthMode( Bool b ) { m_bApplySingleDepthMode = b; } 2330 Bool getApplySingleDepthMode() { return m_bApplySingleDepthMode; } 2277 2331 #endif 2278 2332 #if H_3D_IC … … 2509 2563 Int* getDepthToDisparityF( Int refViewIdx ) { return m_depthToDisparityF[ refViewIdx ]; }; 2510 2564 Bool getVpsDepthModesFlag () { return getVPS()->getVpsDepthModesFlag( getVPS()->getLayerIdInVps( m_layerId ) ); } 2511 2565 #if SEPARATE_FLAG_I0085 2566 Bool getIVPFlag () { return getVPS()->getIVPFlag( getVPS()->getLayerIdInVps( m_layerId ) ); } 2567 #endif 2512 2568 #endif 2513 2569 #if H_MV -
trunk/source/Lib/TLibCommon/TComWedgelet.cpp
r655 r1039 68 68 m_uiHeight ( rcWedge.m_uiHeight ), 69 69 m_pbPattern( (Bool*)xMalloc( Bool, (m_uiWidth * m_uiHeight) ) ) 70 #if SHARP_DMM1_I0110 71 ,m_pbScaledPattern( g_wedgePattern ) 72 #endif 70 73 { 71 74 ::memcpy( m_pbPattern, rcWedge.m_pbPattern, sizeof(Bool) * (m_uiWidth * m_uiHeight)); … … 85 88 86 89 m_pbPattern = (Bool*)xMalloc( Bool, (m_uiWidth * m_uiHeight) ); 90 #if SHARP_DMM1_I0110 91 m_pbScaledPattern = g_wedgePattern; 92 #endif 87 93 } 88 94 … … 181 187 switch( m_eWedgeRes ) 182 188 { 189 #if !SHARP_DMM1_I0110 183 190 case( DOUBLE_PEL ): { uiTempBlockSize = m_uiWidth; uhXs = (m_uhXs<<1); uhYs = (m_uhYs<<1); uhXe = (m_uhXe<<1); uhYe = (m_uhYe<<1); } break; 191 #endif 184 192 case( FULL_PEL ): { uiTempBlockSize = m_uiWidth; uhXs = m_uhXs; uhYs = m_uhYs; uhXe = m_uhXe; uhYe = m_uhYe; } break; 185 193 case( HALF_PEL ): { uiTempBlockSize = (m_uiWidth<<1); uhXs = m_uhXs; uhYs = m_uhYs; uhXe = m_uhXe; uhYe = m_uhYe; } break; 186 194 } 187 195 196 #if !SHARP_DMM1_I0110 188 197 if( m_eWedgeRes == DOUBLE_PEL) // adjust line-end for DOUBLE_PEL resolution 189 198 { … … 194 203 if( m_uhOri == 5 ) { uhXs = uiTempBlockSize-1; } 195 204 } 205 #endif 196 206 197 207 Bool* pbTempPattern = new Bool[ (uiTempBlockSize * uiTempBlockSize) ]; … … 223 233 switch( m_eWedgeRes ) 224 234 { 235 #if !SHARP_DMM1_I0110 225 236 case( DOUBLE_PEL ): { for( UInt k = 0; k < (m_uiWidth * m_uiHeight); k++ ) { m_pbPattern[k] = pbTempPattern[k]; }; } break; 237 #endif 226 238 case( FULL_PEL ): { for( UInt k = 0; k < (m_uiWidth * m_uiHeight); k++ ) { m_pbPattern[k] = pbTempPattern[k]; }; } break; 227 239 case( HALF_PEL ): // sub-sampling by factor 2 … … 315 327 } 316 328 329 #if SHARP_DMM1_I0110 330 Bool* TComWedgelet::getScaledPattern(UInt uiDstSize) 331 { 332 Bool *pbSrcPat = this->getPattern(); 333 UInt uiSrcSize = this->getStride(); 334 335 Int scale = (g_aucConvertToBit[uiDstSize] - g_aucConvertToBit[uiSrcSize]); 336 assert(scale>=0); 337 for (Int y=0; y<uiDstSize; y++) 338 { 339 for (Int x=0; x<uiDstSize; x++) 340 { 341 Int srcX = x>>scale; 342 Int srcY = y>>scale; 343 m_pbScaledPattern[y*uiDstSize + x] = pbSrcPat[ srcY*uiSrcSize + srcX ]; 344 } 345 } 346 return m_pbScaledPattern; 347 } 348 #endif 349 317 350 TComWedgeNode::TComWedgeNode() 318 351 { -
trunk/source/Lib/TLibCommon/TComWedgelet.h
r773 r1039 58 58 #define DIM_NO_IDX MAX_UINT 59 59 60 #if HS_DMM_SIGNALLING_I0120 61 __inline UInt getDimType ( Int intraMode ) 62 { 63 Int dimType = intraMode-DIM_OFFSET; 64 return (dimType >= 0 && dimType < DIM_NUM_TYPE) ? (UInt)dimType : DIM_NO_IDX; 65 } 66 #else 60 67 __inline UInt getDimType ( Int intraMode ) { Int dimType = (intraMode-DIM_OFFSET)/2; return (dimType >= 0 && dimType < DIM_NUM_TYPE) ? (UInt)dimType : DIM_NO_IDX; } 68 #endif 61 69 __inline Bool isDimMode ( Int intraMode ) { return (getDimType( intraMode ) < DIM_NUM_TYPE); } 70 #if !HS_DMM_SIGNALLING_I0120 62 71 __inline Bool isDimDeltaDC( Int intraMode ) { return (isDimMode( intraMode ) && ((intraMode-DIM_OFFSET)%2) == 1); } 72 #endif 63 73 #endif 64 74 … … 69 79 enum WedgeResolution 70 80 { 81 #if !SHARP_DMM1_I0110 71 82 DOUBLE_PEL, 83 #endif 72 84 FULL_PEL, 73 85 HALF_PEL … … 94 106 95 107 Bool* m_pbPattern; 108 #if SHARP_DMM1_I0110 109 Bool* m_pbScaledPattern; 110 #endif 96 111 97 112 Void xGenerateWedgePattern(); … … 119 134 Bool getIsCoarse() { return m_bIsCoarse; } 120 135 UInt getAng () { return m_uiAng; } 136 #if SHARP_DMM1_I0110 137 Bool* getScaledPattern(UInt uiWidth); 138 #endif 121 139 122 140 Void setWedgelet( UChar uhXs, UChar uhYs, UChar uhXe, UChar uhYe, UChar uhOri, WedgeResolution eWedgeRes, Bool bIsCoarse = false ); -
trunk/source/Lib/TLibCommon/TComYuv.cpp
r872 r1039 689 689 UInt iSrc1Stride = pcYuvSrc1->getStride(); 690 690 UInt iDstStride = getStride(); 691 #if QC_I0129_ARP_FIX 692 Int iIFshift = IF_INTERNAL_PREC - g_bitDepthY; 693 Int iOffSet = ( 1 << ( iIFshift - 1 ) ) + IF_INTERNAL_OFFS; 694 #endif 691 695 for ( y = uiHeight-1; y >= 0; y-- ) 692 696 { … … 696 700 if( bClip ) 697 701 { 702 #if QC_I0129_ARP_FIX 703 pDst[x] = ClipY( ( pDst[x] + iOffSet ) >> iIFshift ); 704 #else 698 705 pDst[x] = ClipY( pDst[x] ); 706 #endif 699 707 } 700 708 } … … 719 727 UInt iSrc1Stride = pcYuvSrc1->getCStride(); 720 728 UInt iDstStride = getCStride(); 729 #if QC_I0129_ARP_FIX 730 Int iIFshift = IF_INTERNAL_PREC - g_bitDepthC; 731 Int iOffSet = ( 1 << ( iIFshift - 1 ) ) + IF_INTERNAL_OFFS; 732 #endif 721 733 for ( y = uiHeight-1; y >= 0; y-- ) 722 734 { … … 727 739 if( bClip ) 728 740 { 741 #if QC_I0129_ARP_FIX 742 pDstU[x] = ClipC( ( pDstU[x] + iOffSet ) >> iIFshift ); 743 pDstV[x] = ClipC( ( pDstV[x] + iOffSet ) >> iIFshift ); 744 #else 729 745 pDstU[x] = ClipC( pDstU[x] ); 730 746 pDstV[x] = ClipC( pDstV[x] ); 747 #endif 731 748 } 732 749 } … … 744 761 { 745 762 subtractARPLuma ( pcYuvSrc0, pcYuvSrc1, uiAbsPartIdx, uiWidth , uiHeight ); 763 #if SHARP_ARP_CHROMA_I0104 764 if (uiWidth > 8) 765 #endif 746 766 subtractARPChroma( pcYuvSrc0, pcYuvSrc1, uiAbsPartIdx, uiWidth>>1 , uiHeight>>1 ); 747 767 } … … 803 823 { 804 824 multiplyARPLuma( uiAbsPartIdx , uiWidth , uiHeight , dW ); 825 #if SHARP_ARP_CHROMA_I0104 826 if (uiWidth > 8) 827 #endif 805 828 multiplyARPChroma( uiAbsPartIdx , uiWidth >> 1 , uiHeight >> 1 , dW ); 806 829 } -
trunk/source/Lib/TLibCommon/TypeDef.h
r976 r1039 68 68 #define BUG_FIX_TK65 1 69 69 70 #define MTK_I0093 1 70 71 ///////////////////////////////////////////////////////////////////////////////////////// 71 72 /////////////////////////////////// MAJOR DEFINES /////////////////////////////////// … … 123 124 // MTK_LOW_LATENCY_IC_ENCODING_H0086 Low-latency IC encoding in JCT3V-H0086 124 125 126 #define SEC_IC_NEIGHBOR_CLIP_I0080 1 // Clipping of neighboring sample position, JCT3V-I0080 127 125 128 126 129 #if H_3D_NBDV … … 172 175 // MTK_DIS_SPBIP8X4_H0205 Disable bi-prediction for 8x4 and 4x8 sub PU and remove the SPIVMP 2Nx2N restriction 173 176 // SEC_ADAPT_DISABLE_IVMP Disalbing IVMP merge candidates when IC is enabled, JCT3V-H0070 177 178 #define SEC_SIMP_SHIFTED_DV_I0086 1 // Simplification of Shifted DV candidate, JCT3V-I0086 174 179 175 180 #define H_3D_TMVP 1 // QC_TMVP_C0047 … … 215 220 // MTK_DLT_CODING_FIX_H0091 216 221 222 #define MTK_SINGLE_DEPTH_MODE_I0095 1 // Single depth mode proposed in JCT3V-I0095 223 #if MTK_SINGLE_DEPTH_MODE_I0095 224 #define MTK_SINGLE_DEPTH_MODE_CANDIDATE_LIST_SIZE 2 // size of the sample candidate list 225 #endif 217 226 218 227 #define H_3D_INTER_SDC 1 // INTER SDC, Inter simplified depth coding … … 233 242 // 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. 234 243 244 #define SEC_DBBP_EXPLICIT_SIG_I0077 1 // Remove the partition derivation and signal dbbp_flag only when the partion mode is 2NxN/Nx2N, JCT3V-I0077 245 #define SEC_DBBP_DISALLOW_8x8_I0078 1 // Disallow DBBP in 8x8 CU, JCT3V-I0078 246 #define SHARP_DBBP_SIMPLE_FLTER_I0109 1 // Simple condition and one dimensional dilter for DBBP 247 #define SEC_DBBP_DMM4_THRESHOLD_I0076 1 // Simplification of threshold derivation for DBBP and DMM4, JCT3V-I0076 248 235 249 236 250 #define H_3D_DDD 1 // Disparity derived depth coding … … 238 252 #define H_3D_FCO 0 // Flexible coding order for 3D 239 253 240 254 #define SCU_HS_FAST_INTRA_SDC_I0123 1 241 255 242 256 // OTHERS … … 250 264 #endif 251 265 266 #define MTK_I0099_VPS_EX2 1 ///< JCT3V-I0099, sub-PU size signaling and lim_qt_pred_flag in VPS extension 2 267 #define MTK_I0099_FIX 1 ///< Fix the problem of removing encoder only QTL 268 252 269 // Rate Control 253 270 #define KWU_FIX_URQ 1 … … 255 272 #define KWU_RC_MADPRED_E0227 0 ///< JCT3V-E0227, inter-view MAD prediction 256 273 274 #define SEC_VPS_CLEANUP_I0090 1 275 #define SEC_HLS_CLEANUP_I0100 1 276 257 277 #endif // H_3D 258 278 … … 262 282 /////////////////////////////////// DERIVED DEFINES /////////////////////////////////// 263 283 ///////////////////////////////////////////////////////////////////////////////////////// 284 285 // Fixes 286 #define FIX_TICKET_79 1 // Unused VSP code 287 #define FIX_TICKET_75 1 // Bi-pred restriction bug in VSP 288 #define FIX_TICKET_68 1 // MV clipping bug in the sub-PU MPI default MV generation 289 #define FIX_TICKET_71 1 // IC parameters is meaningless in HTM when no training samples are available 290 #define FIX_TICKET_77 1 // Unused variable m_iBitsPerDepthValue 291 #define FIX_TICKET_76 1 // unused functions 292 #define FIX_TICKET_62 1 // buffer overflow for print 293 #define FIX_TICKET_61 1 // layerIdsInSets size check 264 294 265 295 ///// ***** VIEW SYNTHESIS OPTIMIZAION ********* … … 283 313 #if H_3D_ARP 284 314 #define H_3D_ARP_WFNR 3 315 #define QC_I0129_ARP_FIX 1 316 #define QC_I0051_ARP_SIMP 1 317 #define SHARP_ARP_CHROMA_I0104 1 318 #define MTK_I0072_IVARP_SCALING_FIX 1 285 319 #endif 286 320 … … 290 324 #define H_3D_DIM_SDC 1 // Simplified Depth Coding method 291 325 #define H_3D_DIM_DLT 1 // Depth Lookup Table 326 #define HS_DMM_SIGNALLING_I0120 1 327 #define SHARP_DMM1_I0110 1 // LUT size reduction for DMM1 proposed in JCT3V-I0110 328 #define FIX_WARNING 1 // fix narrowing conversion of NumPocStCurr0,NumPocStCurr1 at TComSlice.cpp 329 #define FAST_SDC_OFFSET_DECISION_I0084 1 330 #define SEPARATE_FLAG_I0085 1 292 331 293 332 #if H_3D_DIM_DLT 294 333 #define H_3D_DELTA_DLT 1 334 #define RWTH_DLT_CLIP_I0057 1 295 335 #endif 296 336 #define H_3D_DIM_ENC 1 // Depth Intra encoder optimizations, includes: 297 337 // HHI_DEPTH_INTRA_SEARCH_RAU_C0160 298 338 // LG_ZEROINTRADEPTHRESI_A0087 339 #define HHI_DMM4_ENC_I0066 1 299 340 #endif 300 341 ///// ***** VIEW SYNTHESIS PREDICTION ********* … … 381 422 382 423 // OTHERS 383 //#define H_MV_HLS_8_HSB_Q0041_03 0 // #3 (HS /Q0041/hybrid scalability) The proposed text was endorsed, with non-editorial open issues considered as follows 384 :// #define H_MV_HLS_7_OTHER_P0187_1 0 // (OTHER/P0187/NoOutputOfPriorPicsFlag) #1 Inference of NoOutputOfPriorPicsFlag and proposes to take into account colour format and bit depth for the inference in addition to spatial resolution 424 //#define H_MV_HLS_8_HSB_Q0041_03 0 // #3 (HS /Q0041/hybrid scalability) The proposed text was endorsed, with non-editorial open issues considered as follows ?// #define H_MV_HLS_7_OTHER_P0187_1 0 // (OTHER/P0187/NoOutputOfPriorPicsFlag) #1 Inference of NoOutputOfPriorPicsFlag and proposes to take into account colour format and bit depth for the inference in addition to spatial resolution 385 425 //#define H_MV_HLS_8_MIS_Q0078_24 0 // #24 (MISC /Q0078/scan and pic type) , Items 3 b,c and 4, clarifying which pictures in an output layer sets are applied the values of general_progressive_source_flag, general_interlaced_source_flag, general_non_packed_constraint_flag and general_frame_only_constraint_flag. 386 426 //#define H_MV_HLS_7_HRD_P0138_6 0 // (HRD/P0138/HRD parameters for bitstreams excluding) #6 Decision: Adopt (as revised in updated contribution, with the specification of a flag in the BP SEI (HRD/P0192/sub-DPB) #12 Establish sub-DPBs based on the representation format indicated at the VPS level. It was suggested that the expressed shared capacity limit would need to be less than or equal to the sum of the individual capacity limits. Decision: Adopt as modified. Further study is encouraged on profile/level constraint selections. -
trunk/source/Lib/TLibDecoder/TDecCAVLC.cpp
r976 r1039 1051 1051 Void TDecCavlc::parseSPSExtension2( TComSPS* pcSPS, Int viewIndex, Bool depthFlag ) 1052 1052 { 1053 #if !MTK_I0099_VPS_EX2 1053 1054 UInt uiCode; 1054 1055 #if H_3D_QTLPC … … 1061 1062 pcSPS->setUsePC( uiCode ); 1062 1063 } 1064 #endif 1063 1065 #endif 1064 1066 } … … 1756 1758 { 1757 1759 UInt uiCode; 1760 #if SEC_VPS_CLEANUP_I0090 1761 for( Int i = 1; i <= pcVPS->getMaxLayersMinus1(); i++ ) 1762 #else 1758 1763 for( Int i = 0; i <= pcVPS->getMaxLayersMinus1(); i++ ) 1764 #endif 1759 1765 { 1760 1766 #if H_3D_ARP … … 1765 1771 pcVPS->setSubPULog2Size(i, 0); 1766 1772 #endif 1773 #if !SEC_VPS_CLEANUP_I0090 1767 1774 if ( i != 0 ) 1768 { 1775 #endif 1776 { 1777 #if MTK_I0099_VPS_EX2 1778 READ_FLAG( uiCode, "iv_mv_pred_flag[i]"); pcVPS->setIvMvPredFlag ( i, uiCode == 1 ? true : false ); 1779 #if SEC_HLS_CLEANUP_I0100 1780 READ_FLAG( uiCode, "iv_mv_scaling_flag[i]"); pcVPS->setIvMvScalingFlag ( i, uiCode == 1 ? true : false ); 1781 #endif 1782 #endif 1769 1783 if( !( pcVPS->getDepthId( i ) == 1 ) ) 1770 1784 { 1771 1785 #if H_3D_IV_MERGE 1786 #if !MTK_I0099_VPS_EX2 1772 1787 READ_FLAG( uiCode, "iv_mv_pred_flag[i]"); pcVPS->setIvMvPredFlag ( i, uiCode == 1 ? true : false ); 1788 #endif 1773 1789 if( !pcVPS->getNumDirectRefLayers(i) ) 1774 1790 { … … 1802 1818 else 1803 1819 { 1820 #if !MTK_I0099_VPS_EX2 1804 1821 #if H_3D_IV_MERGE 1805 1822 if(i!=1) … … 1818 1835 } 1819 1836 #endif 1837 #endif 1820 1838 #if H_3D_IV_MERGE 1821 1839 READ_FLAG( uiCode, "mpi_flag[i]" ); pcVPS->setMPIFlag( i, uiCode == 1 ? true : false ); 1822 1840 #endif 1841 #if MTK_I0099_VPS_EX2 1842 READ_UVLC (uiCode, "log2_mpi_sub_PU_size_minus3[i]"); pcVPS->setSubPUMPILog2Size(i, uiCode+3); 1843 #endif 1823 1844 READ_FLAG( uiCode, "vps_depth_modes_flag[i]" ); pcVPS->setVpsDepthModesFlag( i, uiCode == 1 ? true : false ); 1824 // READ_FLAG( uiCode, "lim_qt_pred_flag[i]"); pcVPS->setLimQtPreFlag ( i, uiCode == 1 ? true : false ); 1845 #if SEPARATE_FLAG_I0085 1846 READ_FLAG( uiCode, "ivp_flag[i]" ); pcVPS->setIVPFlag( i, uiCode == 1 ? true : false ); 1847 #endif 1848 #if MTK_I0099_VPS_EX2 1849 READ_FLAG( uiCode, "lim_qt_pred_flag[i]"); pcVPS->setLimQtPredFlag ( i, uiCode == 1 ? true : false ); 1850 #endif 1825 1851 #if H_3D_INTER_SDC 1826 1852 READ_FLAG( uiCode, "depth_inter_SDC_flag" ); pcVPS->setInterSDCFlag( i, uiCode ? true : false ); … … 1835 1861 1836 1862 READ_UVLC( uiCamParPrecision, "cp_precision" ); 1863 #if SEC_VPS_CLEANUP_I0090 1864 for (UInt viewIndex=1; viewIndex<pcVPS->getNumViews(); viewIndex++) 1865 #else 1837 1866 for (UInt viewIndex=0; viewIndex<pcVPS->getNumViews(); viewIndex++) 1867 #endif 1838 1868 { 1839 1869 pcVPS->setCamParPresent ( viewIndex, false ); … … 1857 1887 } 1858 1888 } 1889 #if !MTK_I0099_VPS_EX2 1859 1890 READ_UVLC (uiCode, "log2_sub_PU_MPI_size_minus3"); pcVPS->setSubPUMPILog2Size( uiCode + 3 ); 1891 #endif 1892 #if !SEC_HLS_CLEANUP_I0100 1860 1893 READ_FLAG( uiCode, "iv_mv_scaling_flag"); pcVPS->setIvMvScalingFlag( uiCode == 1 ? true : false ); 1894 #endif 1861 1895 } 1862 1896 #endif … … 2459 2493 } 2460 2494 #if H_3D_IC 2495 #if SEC_HLS_CLEANUP_I0100 2496 else if( rpcSlice->getViewIndex() && ( rpcSlice->getSliceType() == P_SLICE || rpcSlice->getSliceType() == B_SLICE ) && !rpcSlice->getIsDepth() && vps->getNumDirectRefLayers( layerId ) > 0 ) 2497 #else 2461 2498 else if( rpcSlice->getViewIndex() && ( rpcSlice->getSliceType() == P_SLICE || rpcSlice->getSliceType() == B_SLICE ) && !rpcSlice->getIsDepth()) 2499 #endif 2462 2500 { 2463 2501 UInt uiCodeTmp = 0; … … 2471 2509 rpcSlice->setIcSkipParseFlag( uiCodeTmp ); 2472 2510 } 2511 } 2512 #endif 2513 #if MTK_SINGLE_DEPTH_MODE_I0095 2514 if(rpcSlice->getIsDepth()) 2515 { 2516 UInt uiCodeTmp = 0; 2517 READ_FLAG( uiCodeTmp, "slice_enable_single_depth_mode" ); 2518 rpcSlice->setApplySingleDepthMode(uiCodeTmp); 2473 2519 } 2474 2520 #endif … … 2843 2889 assert(0); 2844 2890 } 2845 2891 #if MTK_SINGLE_DEPTH_MODE_I0095 2892 Void TDecCavlc::parseSingleDepthMode( TComDataCU* /*pcCU*/, UInt /*uiAbsPartIdx*/, UInt /*uiDepth*/ ) 2893 { 2894 assert(0); 2895 } 2896 #endif 2846 2897 Void TDecCavlc::parseCUTransquantBypassFlag( TComDataCU* /*pcCU*/, UInt /*uiAbsPartIdx*/, UInt /*uiDepth*/ ) 2847 2898 { -
trunk/source/Lib/TLibDecoder/TDecCAVLC.h
r976 r1039 119 119 120 120 Void parseSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 121 #if MTK_SINGLE_DEPTH_MODE_I0095 122 Void parseSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 123 #endif 121 124 Void parseCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 122 125 Void parseMergeFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth, UInt uiPUIdx ); -
trunk/source/Lib/TLibDecoder/TDecCu.cpp
r976 r1039 420 420 Int vspFlag[MRG_MAX_NUM_CANDS_MEM]; 421 421 memset(vspFlag, 0, sizeof(Int)*MRG_MAX_NUM_CANDS_MEM); 422 #if !FIX_TICKET_79 422 423 InheritedVSPDisInfo inheritedVSPDisInfo[MRG_MAX_NUM_CANDS_MEM]; 424 #endif 423 425 #if H_3D_SPIVMP 424 426 Bool bSPIVMPFlag[MRG_MAX_NUM_CANDS_MEM]; … … 432 434 m_ppcCU[uiDepth]->getInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand, uiMergeIndex ); 433 435 m_ppcCU[uiDepth]->xGetInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours 436 #if !FIX_TICKET_79 434 437 , inheritedVSPDisInfo 438 #endif 435 439 #if H_3D_SPIVMP 436 440 , pcMvFieldSP, puhInterDirSP … … 453 457 #endif 454 458 #endif 455 #if H_3D_VSP 459 #if H_3D_VSP && !FIX_TICKET_79 456 460 if(vspFlag[uiMergeIndex]) 457 461 { … … 542 546 return; 543 547 } 544 548 #if MTK_SINGLE_DEPTH_MODE_I0095 549 m_pcEntropyDecoder->decodeSingleDepthMode( pcCU, uiAbsPartIdx, uiDepth ); 550 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx)) 551 { 552 #endif 545 553 m_pcEntropyDecoder->decodePredMode( pcCU, uiAbsPartIdx, uiDepth ); 546 554 m_pcEntropyDecoder->decodePartSize( pcCU, uiAbsPartIdx, uiDepth ); … … 572 580 m_pcEntropyDecoder->decodeCoeff( pcCU, uiAbsPartIdx, uiDepth, uiCurrWidth, uiCurrHeight, bCodeDQP ); 573 581 setdQPFlag( bCodeDQP ); 582 #if MTK_SINGLE_DEPTH_MODE_I0095 583 } 584 #endif 574 585 xFinishDecodeCU( pcCU, uiAbsPartIdx, uiDepth, ruiIsLast ); 575 586 #if H_3D_IV_MERGE … … 671 682 break; 672 683 case MODE_INTRA: 684 #if MTK_SINGLE_DEPTH_MODE_I0095 685 if( m_ppcCU[uiDepth]->getSingleDepthFlag(0) ) 686 xReconIntraSingleDepth( m_ppcCU[uiDepth], 0, uiDepth ); 687 #if H_3D_DIM_SDC 688 else if( m_ppcCU[uiDepth]->getSDCFlag(0) ) 689 xReconIntraSDC( m_ppcCU[uiDepth], 0, uiDepth ); 690 #endif 691 else 692 #else 673 693 #if H_3D_DIM_SDC 674 694 if( m_ppcCU[uiDepth]->getSDCFlag(0) ) 675 695 xReconIntraSDC( m_ppcCU[uiDepth], 0, uiDepth ); 676 696 else 697 #endif 677 698 #endif 678 699 xReconIntraQT( m_ppcCU[uiDepth], uiDepth ); … … 709 730 } 710 731 } 711 732 #if MTK_SINGLE_DEPTH_MODE_I0095 733 Void TDecCu::xReconIntraSingleDepth( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 734 { 735 UInt uiWidth = pcCU->getWidth ( 0 ); 736 UInt uiHeight = pcCU->getHeight ( 0 ); 737 738 TComYuv* pcRecoYuv = m_ppcYuvReco[uiDepth]; 739 740 UInt uiStride = pcRecoYuv->getStride (); 741 Pel* piReco = pcRecoYuv->getLumaAddr( uiAbsPartIdx ); 742 743 744 AOF( uiWidth == uiHeight ); 745 AOF( uiAbsPartIdx == 0 ); 746 747 //construction of depth candidates 748 Pel testDepth; 749 Pel DepthNeighbours[5]; 750 Int index =0; 751 for( Int i = 0; (i < 5) && (index<MTK_SINGLE_DEPTH_MODE_CANDIDATE_LIST_SIZE) ; i++ ) 752 { 753 if(!pcCU->getNeighDepth (0, uiAbsPartIdx, &testDepth, i)) 754 { 755 continue; 756 } 757 DepthNeighbours[index]=testDepth; 758 index++; 759 for(Int j=0;j<index-1;j++) 760 { 761 if( (DepthNeighbours[index-1]==DepthNeighbours[j]) ) 762 { 763 index--; 764 break; 765 } 766 } 767 } 768 769 if(index==0) 770 { 771 DepthNeighbours[index]=1<<(g_bitDepthY-1); 772 index++; 773 } 774 775 if(index==1) 776 { 777 DepthNeighbours[index]=ClipY(DepthNeighbours[0] + 1 ); 778 index++; 779 } 780 781 for( UInt uiY = 0; uiY < uiHeight; uiY++ ) 782 { 783 for( UInt uiX = 0; uiX < uiWidth; uiX++ ) 784 { 785 piReco[ uiX ] =DepthNeighbours[(Int)pcCU->getSingleDepthValue(uiAbsPartIdx)]; 786 } 787 piReco += uiStride; 788 } 789 790 // clear UV 791 UInt uiStrideC = pcRecoYuv->getCStride(); 792 Pel *pRecCb = pcRecoYuv->getCbAddr(); 793 Pel *pRecCr = pcRecoYuv->getCrAddr(); 794 795 for (Int y=0; y<uiHeight/2; y++) 796 { 797 for (Int x=0; x<uiWidth/2; x++) 798 { 799 pRecCb[x] = 1<<(g_bitDepthC-1); 800 pRecCr[x] = 1<<(g_bitDepthC-1); 801 } 802 803 pRecCb += uiStrideC; 804 pRecCr += uiStrideC; 805 } 806 } 807 #endif 712 808 #if H_3D_INTER_SDC 713 809 Void TDecCu::xReconInterSDC( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) … … 832 928 833 929 // reconstruct final prediction signal by combining both segments 930 #if SHARP_DBBP_SIMPLE_FLTER_I0109 931 m_pcPrediction->combineSegmentsWithMask(apSegPredYuv, m_ppcYuvReco[uiDepth], pMask, pcCU->getWidth(0), pcCU->getHeight(0), 0, ePartSize); 932 #else 834 933 m_pcPrediction->combineSegmentsWithMask(apSegPredYuv, m_ppcYuvReco[uiDepth], pMask, pcCU->getWidth(0), pcCU->getHeight(0)); 934 #endif 835 935 836 936 // inter recon … … 1206 1306 { 1207 1307 Int uiTabIdx = pcCU->getDmmWedgeTabIdx(DMM1_IDX, uiAbsPartIdx); 1208 1308 1309 #if SHARP_DMM1_I0110 1310 WedgeList* pacWedgeList = pcCU->isDMM1UpscaleMode(uiWidth) ? &g_dmmWedgeLists[(g_aucConvertToBit[pcCU->getDMM1BasePatternWidth(uiWidth)])] : &g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])]; 1311 #else 1209 1312 WedgeList* pacWedgeList = &g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])]; 1313 #endif 1210 1314 TComWedgelet* pcWedgelet = &(pacWedgeList->at( uiTabIdx )); 1211 1315 1212 1316 uiNumSegments = 2; 1317 1318 #if SHARP_DMM1_I0110 1319 pbMask = pcCU->isDMM1UpscaleMode( uiWidth ) ? pcWedgelet->getScaledPattern(uiWidth) : pcWedgelet->getPattern(); 1320 uiMaskStride = pcCU->isDMM1UpscaleMode( uiWidth ) ? uiWidth : pcWedgelet->getStride(); 1321 #else 1213 1322 pbMask = pcWedgelet->getPattern(); 1214 1323 uiMaskStride = pcWedgelet->getStride(); 1324 #endif 1215 1325 } 1216 1326 if( getDimType( uiLumaPredMode ) == DMM4_IDX ) -
trunk/source/Lib/TLibDecoder/TDecCu.h
r872 r1039 123 123 Void setdQPFlag ( Bool b ) { m_bDecodeDQP = b; } 124 124 Void xFillPCMBuffer (TComDataCU* pCU, UInt depth); 125 #if MTK_SINGLE_DEPTH_MODE_I0095 126 Void xReconIntraSingleDepth( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 127 #endif 125 128 #if H_3D_DIM_SDC 126 129 Void xReconIntraSDC ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); -
trunk/source/Lib/TLibDecoder/TDecEntropy.cpp
r976 r1039 52 52 m_pcEntropyDecoderIf->parseSkipFlag( pcCU, uiAbsPartIdx, uiDepth ); 53 53 } 54 54 #if MTK_SINGLE_DEPTH_MODE_I0095 55 Void TDecEntropy::decodeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 56 { 57 if ( !pcCU->getSlice()->getIsDepth() ) 58 { 59 return; 60 } 61 if(!pcCU->getSlice()->getApplySingleDepthMode()) 62 { 63 return; 64 } 65 m_pcEntropyDecoderIf->parseSingleDepthMode( pcCU, uiAbsPartIdx, uiDepth ); 66 } 67 #endif 55 68 Void TDecEntropy::decodeCUTransquantBypassFlag(TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 56 69 { … … 140 153 #if H_3D_DBBP 141 154 155 #if SEC_DBBP_EXPLICIT_SIG_I0077 156 #if SEC_DBBP_DISALLOW_8x8_I0078 157 if( pcCU->getSlice()->getVPS()->getUseDBBP(pcCU->getSlice()->getLayerIdInVps()) && (pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_2NxN || pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_Nx2N) && pcCU->getWidth(uiAbsPartIdx) > 8 ) 158 #else 159 if( pcCU->getSlice()->getVPS()->getUseDBBP(pcCU->getSlice()->getLayerIdInVps()) && (pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_2NxN || pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_Nx2N) ) 160 #endif 161 #else 162 #if SEC_DBBP_DISALLOW_8x8_I0078 163 if( pcCU->getSlice()->getVPS()->getUseDBBP(pcCU->getSlice()->getLayerIdInVps()) && pcCU->getWidth(uiAbsPartIdx) > 8 ) 164 #else 142 165 if( pcCU->getSlice()->getVPS()->getUseDBBP(pcCU->getSlice()->getLayerIdInVps()) ) 166 #endif 167 #endif 143 168 { 144 169 decodeDBBPFlag(pcCU, uiAbsPartIdx, uiDepth); 145 170 #if !SEC_DBBP_EXPLICIT_SIG_I0077 146 171 if( pcCU->getDBBPFlag(uiAbsPartIdx) ) 147 172 { … … 167 192 pcCU->setDBBPFlagSubParts(true, uiAbsPartIdx+uiPUOffset, 1, uiDepth); 168 193 } 194 #endif 169 195 } 170 196 #endif … … 285 311 Int vspFlag[MRG_MAX_NUM_CANDS_MEM]; 286 312 memset(vspFlag, 0, sizeof(Int)*MRG_MAX_NUM_CANDS_MEM); 313 #if !FIX_TICKET_79 287 314 InheritedVSPDisInfo inheritedVSPDisInfo[MRG_MAX_NUM_CANDS_MEM]; 315 #endif 288 316 #if H_3D_SPIVMP 289 317 memset(bSPIVMPFlag, false, sizeof(Bool)*MRG_MAX_NUM_CANDS_MEM); … … 292 320 pcSubCU->getInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand); 293 321 pcSubCU->xGetInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours 322 #if !FIX_TICKET_79 294 323 , inheritedVSPDisInfo 324 #endif 295 325 #if H_3D_SPIVMP 296 326 , pcMvFieldSP, puhInterDirSP … … 304 334 pcCU->setVSPFlagSubParts( vspFlag[uiMergeIndex], uiSubPartIdx, uiPartIdx, uiDepth ); 305 335 336 #if !FIX_TICKET_79 306 337 if(vspFlag[uiMergeIndex]) 307 338 { 308 339 pcCU->setDvInfoSubParts(inheritedVSPDisInfo[uiMergeIndex].m_acDvInfo, uiSubPartIdx, uiPartIdx, uiDepth); 309 340 } 341 #endif 310 342 #else 311 343 #if H_3D … … 328 360 Int vspFlag[MRG_MAX_NUM_CANDS_MEM]; 329 361 memset(vspFlag, 0, sizeof(Int)*MRG_MAX_NUM_CANDS_MEM); 362 #if !FIX_TICKET_79 330 363 InheritedVSPDisInfo inheritedVSPDisInfo[MRG_MAX_NUM_CANDS_MEM]; 364 #endif 331 365 #if H_3D_SPIVMP 332 366 memset(bSPIVMPFlag, false, sizeof(Bool)*MRG_MAX_NUM_CANDS_MEM); … … 335 369 pcSubCU->getInterMergeCandidates( uiSubPartIdx-uiAbsPartIdx, uiPartIdx, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand, uiMergeIndex ); 336 370 pcSubCU->xGetInterMergeCandidates( uiSubPartIdx-uiAbsPartIdx, uiPartIdx, cMvFieldNeighbours, uhInterDirNeighbours 371 #if !FIX_TICKET_79 337 372 , inheritedVSPDisInfo 373 #endif 338 374 #if H_3D_SPIVMP 339 375 , pcMvFieldSP, puhInterDirSP … … 346 382 ,numValidMergeCand ); 347 383 pcCU->setVSPFlagSubParts( vspFlag[uiMergeIndex], uiSubPartIdx, uiPartIdx, uiDepth ); 384 #if !FIX_TICKET_79 348 385 if(vspFlag[uiMergeIndex]) 349 386 { 350 387 pcCU->setDvInfoSubParts(inheritedVSPDisInfo[uiMergeIndex].m_acDvInfo, uiSubPartIdx, uiPartIdx, uiDepth); 351 388 } 389 #endif 352 390 #else 353 391 #if H_3D … … 447 485 #endif 448 486 } 449 #if H_3D_VSP 487 #if H_3D_VSP && !FIX_TICKET_75 450 488 if ( (pcCU->getInterDir(uiSubPartIdx) == 3) && pcSubCU->isBipredRestriction(uiPartIdx) && (pcCU->getVSPFlag(uiSubPartIdx) == 0)) 451 489 #else -
trunk/source/Lib/TLibDecoder/TDecEntropy.h
r976 r1039 89 89 public: 90 90 virtual Void parseSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0; 91 #if MTK_SINGLE_DEPTH_MODE_I0095 92 virtual Void parseSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0; 93 #endif 91 94 virtual Void parseCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0; 92 95 virtual Void parseSplitFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) = 0; … … 176 179 Void decodeSplitFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 177 180 Void decodeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 181 #if MTK_SINGLE_DEPTH_MODE_I0095 182 Void decodeSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) ; 183 #endif 178 184 Void decodeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 179 185 Void decodeMergeFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth, UInt uiPUIdx ); -
trunk/source/Lib/TLibDecoder/TDecSbac.cpp
r976 r1039 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 MTK_SINGLE_DEPTH_MODE_I0095 55 , m_cCUSingleDepthFlagSCModel ( 1, 1, NUM_SINGLEDEPTH_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels) 56 , m_cSingleDepthValueSCModel ( 1, 1, NUM_SINGLE_DEPTH_VALUE_DATA_CTX , m_contextModels + m_numContextModels, m_numContextModels) 57 #endif 54 58 , m_cCUMergeFlagExtSCModel ( 1, 1, NUM_MERGE_FLAG_EXT_CTX , m_contextModels + m_numContextModels, m_numContextModels) 55 59 , m_cCUMergeIdxExtSCModel ( 1, 1, NUM_MERGE_IDX_EXT_CTX , m_contextModels + m_numContextModels, m_numContextModels) … … 132 136 m_cCUSplitFlagSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_SPLIT_FLAG ); 133 137 m_cCUSkipFlagSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_SKIP_FLAG ); 138 #if MTK_SINGLE_DEPTH_MODE_I0095 139 m_cCUSingleDepthFlagSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_SINGLEDEPTH_FLAG ); 140 m_cSingleDepthValueSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA ); 141 #endif 134 142 m_cCUMergeFlagExtSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_MERGE_FLAG_EXT ); 135 143 m_cCUMergeIdxExtSCModel.initBuffer ( sliceType, qp, (UChar*)INIT_MERGE_IDX_EXT ); … … 199 207 m_cCUSplitFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SPLIT_FLAG ); 200 208 m_cCUSkipFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SKIP_FLAG ); 209 #if MTK_SINGLE_DEPTH_MODE_I0095 210 m_cCUSingleDepthFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLEDEPTH_FLAG ); 211 m_cSingleDepthValueSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA ); 212 #endif 201 213 m_cCUMergeFlagExtSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_MERGE_FLAG_EXT ); 202 214 m_cCUMergeIdxExtSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_MERGE_IDX_EXT ); … … 420 432 #endif 421 433 434 #if !FIX_TICKET_76 422 435 #if H_3D_DIM_SDC 423 436 Void TDecSbac::xParseSDCResidualData ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth, UInt uiSegment ) … … 499 512 #endif 500 513 #endif 501 514 #endif 502 515 /** Parse I_PCM information. 503 516 * \param pcCU … … 636 649 #endif 637 650 } 638 651 #if MTK_SINGLE_DEPTH_MODE_I0095 652 Void TDecSbac::parseSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 653 { 654 pcCU->setSingleDepthFlagSubParts( false, uiAbsPartIdx, uiDepth ); 655 UInt uiSymbol = 0; 656 m_pcTDecBinIf->decodeBin( uiSymbol, m_cCUSingleDepthFlagSCModel.get( 0, 0, 0 ) ); 657 if( uiSymbol ) 658 { 659 pcCU->setSingleDepthFlagSubParts( true, uiAbsPartIdx, uiDepth ); 660 pcCU->setSkipFlagSubParts( false, uiAbsPartIdx, uiDepth ); 661 pcCU->setSDCFlagSubParts( false, uiAbsPartIdx, uiDepth ); 662 pcCU->setPredModeSubParts( MODE_INTRA, uiAbsPartIdx, uiDepth ); 663 pcCU->setPartSizeSubParts( SIZE_2Nx2N, uiAbsPartIdx, uiDepth ); 664 pcCU->setLumaIntraDirSubParts (DC_IDX, uiAbsPartIdx, uiDepth ); 665 pcCU->setSizeSubParts( g_uiMaxCUWidth>>uiDepth, g_uiMaxCUHeight>>uiDepth, uiAbsPartIdx, uiDepth ); 666 pcCU->setMergeFlagSubParts( false , uiAbsPartIdx, 0, uiDepth ); 667 pcCU->setTrIdxSubParts(0, uiAbsPartIdx, uiDepth); 668 pcCU->setCbfSubParts(0, 1, 1, uiAbsPartIdx, uiDepth); 669 670 UInt absValDeltaDC = 0; 671 672 UInt uiUnaryIdx = 0; 673 UInt uiNumCand = MTK_SINGLE_DEPTH_MODE_CANDIDATE_LIST_SIZE; 674 if ( uiNumCand > 1 ) 675 { 676 for( ; uiUnaryIdx < uiNumCand - 1; ++uiUnaryIdx ) 677 { 678 UInt uiSymbol2 = 0; 679 if ( uiUnaryIdx==0 ) 680 { 681 m_pcTDecBinIf->decodeBin( uiSymbol2, m_cSingleDepthValueSCModel.get( 0, 0, 0 ) ); 682 } 683 else 684 { 685 m_pcTDecBinIf->decodeBinEP( uiSymbol2); 686 } 687 if( uiSymbol2 == 0 ) 688 { 689 break; 690 } 691 } 692 } 693 absValDeltaDC = uiUnaryIdx; 694 pcCU->setSingleDepthValueSubParts((Pel)absValDeltaDC,uiAbsPartIdx, 0, uiDepth); 695 } 696 } 697 698 #endif 639 699 /** parse merge flag 640 700 * \param pcCU … … 721 781 Bool bParseSplitFlag = true; 722 782 783 #if MTK_I0099_VPS_EX2 784 TComVPS *vps = pcCU->getPic()->getSlice(0)->getVPS(); 785 Bool bLimQtPredFlag = vps->getLimQtPredFlag(pcCU->getPic()->getSlice(0)->getLayerId()); 786 #else 723 787 TComSPS *sps = pcCU->getPic()->getSlice(0)->getSPS(); 788 #endif 724 789 TComPic *pcTexture = pcCU->getSlice()->getTexturePic(); 725 790 Bool bDepthMapDetect = (pcTexture != NULL); … … 728 793 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); 729 794 795 #if MTK_I0099_VPS_EX2 796 if(bDepthMapDetect && !bIntraSliceDetect && !rapPic && bLimQtPredFlag) 797 #else 730 798 if(bDepthMapDetect && !bIntraSliceDetect && !rapPic && sps->getUseQTL() && sps->getUsePC()) 799 #endif 731 800 { 732 801 TComDataCU *pcTextureCU = pcTexture->getCU(pcCU->getAddr()); … … 770 839 #if H_3D_QTLPC 771 840 Bool bParsePartSize = true; 841 #if MTK_I0099_VPS_EX2 842 TComVPS *vps = pcCU->getPic()->getSlice(0)->getVPS(); 843 Bool bLimQtPredFlag = vps->getLimQtPredFlag(pcCU->getPic()->getSlice(0)->getLayerId()); 844 #else 772 845 TComSPS *sps = pcCU->getPic()->getSlice(0)->getSPS(); 846 #endif 773 847 TComPic *pcTexture = pcCU->getSlice()->getTexturePic(); 774 848 Bool bDepthMapDetect = (pcTexture != NULL); … … 779 853 Bool depthDependent = false; 780 854 UInt uiTexturePart = uiMode; 855 #if MTK_I0099_VPS_EX2 856 if(bDepthMapDetect && !bIntraSliceDetect && !rapPic && bLimQtPredFlag ) 857 #else 781 858 if(bDepthMapDetect && !bIntraSliceDetect && !rapPic && sps->getUseQTL() && sps->getUsePC()) 859 #endif 782 860 { 783 861 TComDataCU *pcTextureCU = pcTexture->getCU(pcCU->getAddr()); … … 990 1068 { 991 1069 #if H_3D_DIM 1070 #if SEPARATE_FLAG_I0085 1071 if( pcCU->getSlice()->getVpsDepthModesFlag() || pcCU->getSlice()->getIVPFlag() ) 1072 #else 992 1073 if( pcCU->getSlice()->getVpsDepthModesFlag() ) 1074 #endif 993 1075 { 994 1076 parseIntraDepth( pcCU, absPartIdx+partOffset*j, depth ); … … 1132 1214 if( uiIsDimMode ) 1133 1215 { 1216 #if SEPARATE_FLAG_I0085 1217 if( pcCU->getSlice()->getVpsDepthModesFlag() && pcCU->getSlice()->getIVPFlag() ) 1218 { 1219 m_pcTDecBinIf->decodeBin( uiSymbol, m_cDepthIntraModeSCModel.get( 0, 0, 0 ) ); 1220 if( !uiSymbol ) 1221 { 1222 #if HS_DMM_SIGNALLING_I0120 1223 pcCU->setLumaIntraDirSubParts( DIM_OFFSET, absPartIdx, depth ); 1224 #else 1225 pcCU->setLumaIntraDirSubParts( ( 2 * DMM1_IDX + DIM_OFFSET ), absPartIdx, depth ); 1226 #endif 1227 } 1228 else 1229 { 1230 #if HS_DMM_SIGNALLING_I0120 1231 pcCU->setLumaIntraDirSubParts( ( 1+ DIM_OFFSET ), absPartIdx, depth ); 1232 #else 1233 pcCU->setLumaIntraDirSubParts( ( 2 * DMM4_IDX + DIM_OFFSET ), absPartIdx, depth ); 1234 #endif 1235 } 1236 } 1237 else if ( pcCU->getSlice()->getVpsDepthModesFlag() ) 1238 { 1239 #if HS_DMM_SIGNALLING_I0120 1240 pcCU->setLumaIntraDirSubParts( DIM_OFFSET, absPartIdx, depth ); 1241 #else 1242 pcCU->setLumaIntraDirSubParts( ( 2 * DMM1_IDX + DIM_OFFSET ), absPartIdx, depth ); 1243 #endif 1244 } 1245 else if( pcCU->getSlice()->getIVPFlag() ) 1246 { 1247 #if HS_DMM_SIGNALLING_I0120 1248 pcCU->setLumaIntraDirSubParts( ( 1+ DIM_OFFSET ), absPartIdx, depth ); 1249 #else 1250 pcCU->setLumaIntraDirSubParts( ( 2 * DMM4_IDX + DIM_OFFSET ), absPartIdx, depth ); 1251 #endif 1252 } 1253 #else 1134 1254 m_pcTDecBinIf->decodeBin( uiSymbol, m_cDepthIntraModeSCModel.get( 0, 0, 0 ) ); 1135 1255 if( !uiSymbol ) 1136 1256 { 1257 #if HS_DMM_SIGNALLING_I0120 1258 pcCU->setLumaIntraDirSubParts( DIM_OFFSET, absPartIdx, depth ); 1259 #else 1137 1260 pcCU->setLumaIntraDirSubParts( ( 2 * DMM1_IDX + DIM_OFFSET ), absPartIdx, depth ); 1261 #endif 1138 1262 } 1139 1263 else 1140 1264 { 1265 #if HS_DMM_SIGNALLING_I0120 1266 pcCU->setLumaIntraDirSubParts( ( 1+ DIM_OFFSET ), absPartIdx, depth ); 1267 #else 1141 1268 pcCU->setLumaIntraDirSubParts( ( 2 * DMM4_IDX + DIM_OFFSET ), absPartIdx, depth ); 1142 } 1269 #endif 1270 } 1271 #endif 1143 1272 } 1144 1273 } … … 2053 2182 } 2054 2183 2184 #if HS_DMM_SIGNALLING_I0120 2185 UInt symbol = 1; 2186 UInt uiNumSegments = isDimMode( pcCU->getLumaIntraDir( absPartIdx ) ) ? 2 : 1; 2187 #else 2055 2188 UInt symbol = 0; 2056 2189 UInt uiNumSegments = 0; 2057 2190 #endif 2191 2192 #if HS_DMM_SIGNALLING_I0120 2193 if( pcCU->isIntra( absPartIdx ) && pcCU->getSDCFlag( absPartIdx )) 2194 { 2195 #else 2058 2196 if( pcCU->isIntra( absPartIdx ) ) 2059 2197 { 2060 2198 UInt dir = pcCU->getLumaIntraDir( absPartIdx ); 2061 2199 uiNumSegments = isDimMode( dir ) ? 2 : 1; 2200 #endif 2062 2201 m_pcTDecBinIf->decodeBin( symbol, m_cDdcFlagSCModel.get( 0, 0, 0 ) ); 2202 #if !HS_DMM_SIGNALLING_I0120 2063 2203 if( pcCU->getSDCFlag( absPartIdx ) ) 2064 2204 { 2205 #endif 2065 2206 assert( pcCU->getPartitionSize( absPartIdx ) == SIZE_2Nx2N ); 2066 2207 pcCU->setTrIdxSubParts( 0, absPartIdx, depth ); 2067 2208 pcCU->setCbfSubParts( 1, 1, 1, absPartIdx, depth ); 2068 2209 } 2210 #if !HS_DMM_SIGNALLING_I0120 2069 2211 else 2070 2212 { … … 2077 2219 symbol = 1; 2078 2220 } 2221 #endif 2079 2222 2080 2223 … … 2138 2281 m_pcTDecBinIf->decodeBin( uiSymbol, m_cDBBPFlagSCModel.get( 0, 0, 0 ) ); 2139 2282 2283 #if SEC_DBBP_EXPLICIT_SIG_I0077 2284 PartSize ePartSize = pcCU->getPartitionSize( uiAbsPartIdx ); 2285 AOF( ePartSize == SIZE_2NxN || ePartSize == SIZE_Nx2N ); 2286 UInt uiPUOffset = ( g_auiPUOffset[UInt( ePartSize )] << ( ( pcCU->getSlice()->getSPS()->getMaxCUDepth() - uiDepth ) << 1 ) ) >> 4; 2287 pcCU->setDBBPFlagSubParts(uiSymbol, uiAbsPartIdx, 0, uiDepth); 2288 pcCU->setDBBPFlagSubParts(uiSymbol, uiAbsPartIdx+uiPUOffset, 1, uiDepth); 2289 #else 2140 2290 if( uiSymbol ) 2141 2291 { … … 2144 2294 pcCU->setDBBPFlagSubParts(true, uiAbsPartIdx + 2*uiCurrPartNumQ, 1, uiDepth); 2145 2295 } 2296 #endif 2146 2297 } 2147 2298 #endif -
trunk/source/Lib/TLibDecoder/TDecSbac.h
r976 r1039 129 129 130 130 Void parseSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 131 #if MTK_SINGLE_DEPTH_MODE_I0095 132 Void parseSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 133 #endif 131 134 Void parseCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); 132 135 Void parseSplitFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ); … … 179 182 ContextModel3DBuffer m_cCUSplitFlagSCModel; 180 183 ContextModel3DBuffer m_cCUSkipFlagSCModel; 184 #if MTK_SINGLE_DEPTH_MODE_I0095 185 ContextModel3DBuffer m_cCUSingleDepthFlagSCModel; 186 ContextModel3DBuffer m_cSingleDepthValueSCModel; 187 #endif 181 188 ContextModel3DBuffer m_cCUMergeFlagExtSCModel; 182 189 ContextModel3DBuffer m_cCUMergeIdxExtSCModel; -
trunk/source/Lib/TLibEncoder/TEncCavlc.cpp
r976 r1039 887 887 { 888 888 #if H_3D_QTLPC 889 #if !MTK_I0099_VPS_EX2 889 890 //GT: This has to go to VPS 890 891 if( depthFlag ) … … 893 894 WRITE_FLAG( pcSPS->getUsePC() ? 1 : 0, "use_pc_flag"); 894 895 } 896 #endif 895 897 #endif 896 898 } … … 1558 1560 Void TEncCavlc::codeVPSExtension2( TComVPS* pcVPS ) 1559 1561 { 1562 #if SEC_VPS_CLEANUP_I0090 1563 for( Int i = 1; i <= pcVPS->getMaxLayersMinus1(); i++ ) 1564 #else 1560 1565 for( Int i = 0; i <= pcVPS->getMaxLayersMinus1(); i++ ) 1561 { 1566 #endif 1567 { 1568 #if !SEC_VPS_CLEANUP_I0090 1562 1569 if (i!= 0) 1563 { 1570 #endif 1571 { 1572 #if MTK_I0099_VPS_EX2 1573 WRITE_FLAG( pcVPS->getIvMvPredFlag ( i ) ? 1 : 0 , "iv_mv_pred_flag[i]"); 1574 #if SEC_HLS_CLEANUP_I0100 1575 WRITE_FLAG( pcVPS->getIvMvScalingFlag( i ) ? 1 : 0 , "iv_mv_scaling_flag[i]" ); 1576 #endif 1577 1578 #endif 1564 1579 if ( !( pcVPS->getDepthId( i ) == 1 ) ) 1565 1580 { 1566 1581 #if H_3D_IV_MERGE 1582 #if !MTK_I0099_VPS_EX2 1567 1583 WRITE_FLAG( pcVPS->getIvMvPredFlag ( i ) ? 1 : 0 , "iv_mv_pred_flag[i]"); 1584 #endif 1568 1585 #if H_3D_SPIVMP 1569 1586 WRITE_UVLC( pcVPS->getSubPULog2Size(i)-3, "log2_sub_PU_size_minus3[i]"); … … 1585 1602 else 1586 1603 { 1604 #if !MTK_I0099_VPS_EX2 1587 1605 if(i!=1) 1588 1606 { … … 1595 1613 } 1596 1614 #endif 1615 #endif 1597 1616 #if H_3D_IV_MERGE 1598 1617 WRITE_FLAG( pcVPS->getMPIFlag( i ) ? 1 : 0 , "mpi_flag[i]" ); 1599 1618 #endif 1619 #if MTK_I0099_VPS_EX2 1620 WRITE_UVLC( pcVPS->getSubPUMPILog2Size(i)-3, "log2_mpi_sub_PU_size_minus3[i]"); 1621 #endif 1600 1622 WRITE_FLAG( pcVPS->getVpsDepthModesFlag( i ) ? 1 : 0 , "vps_depth_modes_flag[i]" ); 1601 //WRITE_FLAG( pcVPS->getLimQtPredFlag ( i ) ? 1 : 0 , "lim_qt_pred_flag[i]" ); 1623 #if SEPARATE_FLAG_I0085 1624 WRITE_FLAG( pcVPS->getIVPFlag( i ) ? 1 : 0 , "IVP_flag[i]" ); 1625 #endif 1626 #if MTK_I0099_VPS_EX2 1627 WRITE_FLAG( pcVPS->getLimQtPredFlag ( i ) ? 1 : 0 , "lim_qt_pred_flag[i]" ); 1628 #endif 1629 1602 1630 #if H_3D_INTER_SDC 1603 1631 WRITE_FLAG( pcVPS->getInterSDCFlag( i ) ? 1 : 0, "depth_inter_SDC_flag" ); … … 1607 1635 } 1608 1636 WRITE_UVLC( pcVPS->getCamParPrecision(), "cp_precision" ); 1637 #if SEC_VPS_CLEANUP_I0090 1638 for (UInt viewIndex=1; viewIndex<pcVPS->getNumViews(); viewIndex++) 1639 #else 1609 1640 for (UInt viewIndex=0; viewIndex<pcVPS->getNumViews(); viewIndex++) 1641 #endif 1610 1642 { 1611 1643 WRITE_FLAG( pcVPS->getCamParPresent(viewIndex) ? 1 : 0, "cp_present_flag[i]" ); … … 1625 1657 } 1626 1658 } 1659 #if !MTK_I0099_VPS_EX2 1627 1660 WRITE_UVLC( pcVPS->getSubPUMPILog2Size( ) - 3, "log2_sub_PU_MPI_size_minus3"); 1661 #endif 1628 1662 #if H_3D_TMVP 1663 #if !SEC_HLS_CLEANUP_I0100 1629 1664 WRITE_FLAG( pcVPS->getIvMvScalingFlag( ) ? 1 : 0 , "iv_mv_scaling_flag" ); 1665 #endif 1630 1666 #endif 1631 1667 } … … 2013 2049 } 2014 2050 #if H_3D_IC 2051 #if SEC_HLS_CLEANUP_I0100 2052 else if( pcSlice->getViewIndex() && ( pcSlice->getSliceType() == P_SLICE || pcSlice->getSliceType() == B_SLICE ) && !pcSlice->getIsDepth() && vps->getNumDirectRefLayers( layerId ) > 0 ) 2053 #else 2015 2054 else if( pcSlice->getViewIndex() && ( pcSlice->getSliceType() == P_SLICE || pcSlice->getSliceType() == B_SLICE ) && !pcSlice->getIsDepth()) 2055 #endif 2016 2056 { 2017 2057 WRITE_FLAG( pcSlice->getApplyIC() ? 1 : 0, "slice_ic_enable_flag" ); … … 2022 2062 } 2023 2063 #endif 2024 2064 #if MTK_SINGLE_DEPTH_MODE_I0095 2065 if(pcSlice->getIsDepth()) 2066 { 2067 WRITE_FLAG( pcSlice->getApplySingleDepthMode() ? 1 : 0, "slice_enable_single_depth_mode" ); 2068 } 2069 #endif 2025 2070 #if H_3D_IV_MERGE 2026 2071 assert(pcSlice->getMaxNumMergeCand()<=MRG_MAX_NUM_CANDS_MEM); … … 2408 2453 assert(0); 2409 2454 } 2410 2455 #if MTK_SINGLE_DEPTH_MODE_I0095 2456 Void TEncCavlc::codeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx ) 2457 { 2458 assert(0); 2459 } 2460 #endif 2411 2461 Void TEncCavlc::codeSplitFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiDepth ) 2412 2462 { -
trunk/source/Lib/TLibEncoder/TEncCavlc.h
r884 r1039 123 123 Void codeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx ); 124 124 Void codeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ); 125 #if MTK_SINGLE_DEPTH_MODE_I0095 126 Void codeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx ); 127 #endif 125 128 Void codeMergeFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ); 126 129 Void codeMergeIndex ( TComDataCU* pcCU, UInt uiAbsPartIdx ); -
trunk/source/Lib/TLibEncoder/TEncCfg.h
r976 r1039 414 414 #if H_3D_DIM 415 415 Bool m_useDMM; 416 #if SEPARATE_FLAG_I0085 417 Bool m_useIVP; 418 #endif 416 419 Bool m_useSDC; 417 420 Bool m_useDLT; 418 421 #endif 422 #if MTK_SINGLE_DEPTH_MODE_I0095 423 Bool m_useSingleDepthMode; 424 #endif 419 425 #if H_3D_IV_MERGE 420 426 Bool m_useMPI; 421 427 #endif 428 #if !MTK_I0099_VPS_EX2 || MTK_I0099_FIX 422 429 #if H_3D_QTLPC 423 430 Bool m_bUseQTL; 431 #if !MTK_I0099_VPS_EX2 424 432 Bool m_bUsePC; 433 #endif 434 #endif 425 435 #endif 426 436 #endif … … 1003 1013 Bool getUseDMM () { return m_useDMM; } 1004 1014 Void setUseDMM ( Bool b) { m_useDMM = b; } 1015 #if SEPARATE_FLAG_I0085 1016 Bool getUseIVP () { return m_useIVP; } 1017 Void setUseIVP ( Bool b) { m_useIVP = b; } 1018 #endif 1005 1019 Bool getUseSDC () { return m_useSDC; } 1006 1020 Void setUseSDC ( Bool b) { m_useSDC = b; } … … 1008 1022 Void setUseDLT ( Bool b) { m_useDLT = b; } 1009 1023 #endif 1024 #if MTK_SINGLE_DEPTH_MODE_I0095 1025 Void setUseSingleDepthMode ( Bool bVal ) { m_useSingleDepthMode = bVal; } 1026 Bool getUseSingleDepthMode () { return m_useSingleDepthMode; } 1027 #endif 1028 #if !MTK_I0099_VPS_EX2 || MTK_I0099_FIX 1010 1029 #if H_3D_QTLPC 1011 1030 Void setUseQTL ( Bool b ) { m_bUseQTL = b; } 1012 1031 Bool getUseQTL () { return m_bUseQTL; } 1032 #if !MTK_I0099_VPS_EX2 1013 1033 Void setUsePC ( Bool b ) { m_bUsePC = b; } 1014 1034 Bool getUsePC () { return m_bUsePC; } 1035 #endif 1036 #endif 1015 1037 #endif 1016 1038 #if H_3D_IV_MERGE -
trunk/source/Lib/TLibEncoder/TEncCu.cpp
r976 r1039 409 409 410 410 #if H_3D_QTLPC 411 #if MTK_I0099_VPS_EX2 412 TComVPS *vps = pcPic->getSlice(0)->getVPS(); 413 Bool bLimQtPredFalg = vps->getLimQtPredFlag(pcPic->getSlice(0)->getLayerId()); 414 #else 411 415 TComSPS *sps = pcPic->getSlice(0)->getSPS(); 416 #endif 412 417 TComPic *pcTexture = rpcBestCU->getSlice()->getTexturePic(); 413 418 … … 531 536 //logic for setting bTrySplit using the partition information that is stored of the texture colocated CU 532 537 538 #if MTK_I0099_VPS_EX2 539 #if MTK_I0099_FIX 540 if(depthMapDetect && !bIntraSliceDetect && !rapPic && ( m_pcEncCfg->getUseQTL() || bLimQtPredFalg )) 541 #else 542 if(depthMapDetect && !bIntraSliceDetect && !rapPic && bLimQtPredFalg) 543 #endif 544 #else 533 545 if(depthMapDetect && !bIntraSliceDetect && !rapPic && sps->getUseQTL()) 546 #endif 534 547 { 535 548 TComDataCU* pcTextureCU = pcTexture->getCU( rpcBestCU->getAddr() ); //Corresponding texture LCU … … 685 698 686 699 #if H_3D_QTLPC 700 #if MTK_I0099_VPS_EX2 701 #if MTK_I0099_FIX 702 if(depthMapDetect && !bIntraSliceDetect && !rapPic && ( m_pcEncCfg->getUseQTL() || bLimQtPredFalg )) 703 #else 704 if(depthMapDetect && !bIntraSliceDetect && !rapPic && bLimQtPredFalg) 705 #endif 706 #else 687 707 if(depthMapDetect && !bIntraSliceDetect && !rapPic && sps->getUseQTL()) 708 #endif 688 709 { 689 710 bTrySplitDQP = bTrySplit; … … 709 730 } 710 731 #endif 711 732 #if MTK_SINGLE_DEPTH_MODE_I0095 733 rpcTempCU->initEstData( uiDepth, iMinQP, isAddLowestQP ); 734 if(rpcBestCU->getSlice()->getApplySingleDepthMode()) 735 { 736 xCheckRDCostSingleDepth( rpcBestCU, rpcTempCU, SIZE_2Nx2N ); 737 rpcTempCU->initEstData( uiDepth, iMinQP, isAddLowestQP ); 738 } 739 #endif 712 740 if(!earlyDetectionSkipMode) 713 741 { … … 1021 1049 // speedup for inter frames 1022 1050 if( rpcBestCU->getSlice()->getSliceType() == I_SLICE || 1023 rpcBestCU->getCbf( 0, TEXT_LUMA ) != 0 ||1024 rpcBestCU->getCbf( 0, TEXT_CHROMA_U ) != 0 ||1051 rpcBestCU->getCbf( 0, TEXT_LUMA ) != 0 || 1052 rpcBestCU->getCbf( 0, TEXT_CHROMA_U ) != 0 || 1025 1053 rpcBestCU->getCbf( 0, TEXT_CHROMA_V ) != 0 1026 1054 #if H_3D_DIM_ENC 1055 #if HHI_DMM4_ENC_I0066 1056 || rpcBestCU->getSlice()->getIsDepth() 1057 #else 1027 1058 || ( rpcBestCU->getSlice()->getIsDepth() && rpcBestCU->getSlice()->isIRAP() ) 1059 #endif 1028 1060 #endif 1029 1061 ) // avoid very complex intra if it is unlikely 1030 1062 { 1063 #if HHI_DMM4_ENC_I0066 1064 Bool bOnlyIVP = false; 1065 if( rpcBestCU->getSlice()->getIsDepth() && !(rpcBestCU->getSlice()->isIRAP()) && 1066 rpcBestCU->getSlice()->getSliceType() != I_SLICE && 1067 rpcBestCU->getCbf( 0, TEXT_LUMA ) == 0 && 1068 rpcBestCU->getCbf( 0, TEXT_CHROMA_U ) == 0 && 1069 rpcBestCU->getCbf( 0, TEXT_CHROMA_V ) == 0 1070 ) 1071 { 1072 bOnlyIVP = true; 1073 } 1074 xCheckRDCostIntra( rpcBestCU, rpcTempCU, SIZE_2Nx2N, bOnlyIVP ); 1075 #else 1031 1076 xCheckRDCostIntra( rpcBestCU, rpcTempCU, SIZE_2Nx2N ); 1077 #endif 1032 1078 1033 1079 #if KWU_RC_MADPRED_E0227 … … 1048 1094 if( rpcTempCU->getWidth(0) > ( 1 << rpcTempCU->getSlice()->getSPS()->getQuadtreeTULog2MinSize() ) ) 1049 1095 { 1096 #if HHI_DMM4_ENC_I0066 1097 xCheckRDCostIntra( rpcBestCU, rpcTempCU, SIZE_NxN, bOnlyIVP ); 1098 #else 1050 1099 xCheckRDCostIntra( rpcBestCU, rpcTempCU, SIZE_NxN ); 1100 #endif 1051 1101 rpcTempCU->initEstData( uiDepth, iQP, bIsLosslessMode ); 1052 1102 } … … 1536 1586 return; 1537 1587 } 1588 #if MTK_SINGLE_DEPTH_MODE_I0095 1589 m_pcEntropyCoder->encodeSingleDepthMode( pcCU, uiAbsPartIdx ); 1590 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx)) 1591 { 1592 #endif 1538 1593 m_pcEntropyCoder->encodePredMode( pcCU, uiAbsPartIdx ); 1539 1594 … … 1568 1623 m_pcEntropyCoder->encodeCoeff( pcCU, uiAbsPartIdx, uiDepth, pcCU->getWidth (uiAbsPartIdx), pcCU->getHeight(uiAbsPartIdx), bCodeDQP ); 1569 1624 setdQPFlag( bCodeDQP ); 1570 1625 #if MTK_SINGLE_DEPTH_MODE_I0095 1626 } 1627 #endif 1571 1628 // --- write terminating bit --- 1572 1629 finishCU(pcCU,uiAbsPartIdx,uiDepth); … … 1802 1859 Int vspFlag[MRG_MAX_NUM_CANDS_MEM]; 1803 1860 memset(vspFlag, 0, sizeof(Int)*MRG_MAX_NUM_CANDS_MEM); 1861 #if !FIX_TICKET_79 1804 1862 InheritedVSPDisInfo inheritedVSPDisInfo[MRG_MAX_NUM_CANDS_MEM]; 1863 #endif 1805 1864 #if H_3D_SPIVMP 1806 1865 Bool bSPIVMPFlag[MRG_MAX_NUM_CANDS_MEM]; … … 1815 1874 rpcTempCU->getInterMergeCandidates( 0, 0, cMvFieldNeighbours, uhInterDirNeighbours, numValidMergeCand ); 1816 1875 rpcTempCU->xGetInterMergeCandidates( 0, 0, cMvFieldNeighbours,uhInterDirNeighbours 1876 #if !FIX_TICKET_79 1817 1877 , inheritedVSPDisInfo 1878 #endif 1818 1879 #if H_3D_SPIVMP 1819 1880 , pcMvFieldSP, puhInterDirSP … … 1830 1891 1831 1892 #else 1893 #if FIX_TICKET_79 1894 rpcTempCU->getInterMergeCandidates( 0, 0, cMvFieldNeighbours,uhInterDirNeighbours, vspFlag, numValidMergeCand ); 1895 #else 1832 1896 rpcTempCU->getInterMergeCandidates( 0, 0, cMvFieldNeighbours,uhInterDirNeighbours, vspFlag, inheritedVSPDisInfo, numValidMergeCand ); 1833 1897 #endif 1898 #endif 1899 1834 1900 1835 1901 #endif … … 1872 1938 #if H_3D_VSP 1873 1939 rpcTempCU->setVSPFlagSubParts( vspFlag[uiMergeCand], 0, 0, uhDepth ); 1940 #if !FIX_TICKET_79 1874 1941 rpcTempCU->setDvInfoSubParts(inheritedVSPDisInfo[uiMergeCand].m_acDvInfo, 0, 0, uhDepth ); 1942 #endif 1875 1943 #endif 1876 1944 #if H_3D_DDD … … 1971 2039 1972 2040 rpcTempCU->setSkipFlagSubParts( rpcTempCU->getQtRootCbf(0) == 0, 0, uhDepth ); 2041 #if MTK_SINGLE_DEPTH_MODE_I0095 2042 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uhDepth ); 2043 #endif 1973 2044 #if H_3D_VSP // possible bug fix 1974 2045 if( rpcTempCU->getSkipFlag(0) ) … … 1986 2057 if( rpcTempCU->getSlice()->getVPS()->getInterSDCFlag( rpcTempCU->getSlice()->getLayerIdInVps() ) && rpcTempCU->getSlice()->getIsDepth() && !uiNoResidual ) 1987 2058 { 2059 #if FAST_SDC_OFFSET_DECISION_I0084 2060 Double dOffsetCost[3] = {MAX_DOUBLE,MAX_DOUBLE,MAX_DOUBLE}; 2061 for( Int uiOffest = 1 ; uiOffest <= 5 ; uiOffest++ ) 2062 #else 1988 2063 for( Int uiOffest = -2 ; uiOffest <= 2 ; uiOffest++ ) 2064 #endif 1989 2065 { 2066 #if FAST_SDC_OFFSET_DECISION_I0084 2067 if( uiOffest > 3) 2068 { 2069 if ( dOffsetCost[0] < (0.9*dOffsetCost[1]) && dOffsetCost[0] < (0.9*dOffsetCost[2]) ) 2070 { 2071 continue; 2072 } 2073 if ( dOffsetCost[1] < dOffsetCost[0] && dOffsetCost[0] < dOffsetCost[2] && uiOffest == 5) 2074 { 2075 continue; 2076 } 2077 if ( dOffsetCost[0] < dOffsetCost[1] && dOffsetCost[2] < dOffsetCost[0] && uiOffest == 4) 2078 { 2079 continue; 2080 } 2081 } 2082 #endif 1990 2083 if( rpcTempCU != rpcTempCUPre ) 1991 2084 { … … 1994 2087 } 1995 2088 rpcTempCU->setSkipFlagSubParts( false, 0, uhDepth ); 2089 #if MTK_SINGLE_DEPTH_MODE_I0095 2090 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uhDepth ); 2091 #endif 1996 2092 rpcTempCU->setTrIdxSubParts( 0, 0, uhDepth ); 1997 2093 rpcTempCU->setCbfSubParts( 1, 1, 1, 0, uhDepth ); … … 2006 2102 } 2007 2103 #endif 2104 #if FAST_SDC_OFFSET_DECISION_I0084 2105 Int iSdcOffset = 0; 2106 if(uiOffest % 2 == 0) 2107 { 2108 iSdcOffset = uiOffest >> 1; 2109 } 2110 else 2111 { 2112 iSdcOffset = -1 * (uiOffest >> 1); 2113 } 2114 m_pcPredSearch->encodeResAndCalcRdInterSDCCU( rpcTempCU, 2115 m_ppcOrigYuv[uhDepth], 2116 ( rpcTempCU != rpcTempCUPre ) ? m_ppcPredYuvBest[uhDepth] : m_ppcPredYuvTemp[uhDepth], 2117 m_ppcResiYuvTemp[uhDepth], 2118 m_ppcRecoYuvTemp[uhDepth], 2119 iSdcOffset, 2120 uhDepth ); 2121 if (uiOffest <= 3 ) 2122 { 2123 dOffsetCost [uiOffest -1] = rpcTempCU->getTotalCost(); 2124 } 2125 #else 2008 2126 m_pcPredSearch->encodeResAndCalcRdInterSDCCU( rpcTempCU, 2009 2127 m_ppcOrigYuv[uhDepth], … … 2013 2131 uiOffest, 2014 2132 uhDepth ); 2133 #endif 2015 2134 2016 2135 xCheckDQP( rpcTempCU ); … … 2130 2249 2131 2250 rpcTempCU->setSkipFlagSubParts( false, 0, uhDepth ); 2132 2251 #if MTK_SINGLE_DEPTH_MODE_I0095 2252 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uhDepth ); 2253 #endif 2133 2254 rpcTempCU->setPartSizeSubParts ( ePartSize, 0, uhDepth ); 2134 2255 rpcTempCU->setPredModeSubParts ( MODE_INTER, 0, uhDepth ); … … 2217 2338 if( rpcTempCU->getSlice()->getVPS()->getInterSDCFlag( rpcTempCU->getSlice()->getLayerIdInVps() ) && rpcTempCU->getSlice()->getIsDepth() && ePartSize == SIZE_2Nx2N) 2218 2339 { 2340 #if FAST_SDC_OFFSET_DECISION_I0084 2341 Double dOffsetCost[3] = {MAX_DOUBLE,MAX_DOUBLE,MAX_DOUBLE}; 2342 for( Int uiOffest = 1 ; uiOffest <= 5 ; uiOffest++ ) 2343 #else 2219 2344 for( Int uiOffest = -2 ; uiOffest <= 2 ; uiOffest++ ) 2220 { 2345 #endif 2346 { 2347 #if FAST_SDC_OFFSET_DECISION_I0084 2348 if( uiOffest > 3) 2349 { 2350 if ( dOffsetCost[0] < (0.9*dOffsetCost[1]) && dOffsetCost[0] < (0.9*dOffsetCost[2]) ) 2351 { 2352 continue; 2353 } 2354 if ( dOffsetCost[1] < dOffsetCost[0] && dOffsetCost[0] < dOffsetCost[2] && uiOffest == 5) 2355 { 2356 continue; 2357 } 2358 if ( dOffsetCost[0] < dOffsetCost[1] && dOffsetCost[2] < dOffsetCost[0] && uiOffest == 4) 2359 { 2360 continue; 2361 } 2362 } 2363 #endif 2221 2364 if( rpcTempCU != rpcTempCUPre ) 2222 2365 { … … 2226 2369 } 2227 2370 rpcTempCU->setSkipFlagSubParts( false, 0, uhDepth ); 2371 #if MTK_SINGLE_DEPTH_MODE_I0095 2372 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uhDepth ); 2373 #endif 2228 2374 rpcTempCU->setTrIdxSubParts( 0, 0, uhDepth ); 2229 2375 rpcTempCU->setCbfSubParts( 1, 1, 1, 0, uhDepth ); … … 2239 2385 #endif 2240 2386 2387 #if FAST_SDC_OFFSET_DECISION_I0084 2388 Int iSdcOffset = 0; 2389 if(uiOffest % 2 == 0) 2390 { 2391 iSdcOffset = uiOffest >> 1; 2392 } 2393 else 2394 { 2395 iSdcOffset = -1 * (uiOffest >> 1); 2396 } 2397 m_pcPredSearch->encodeResAndCalcRdInterSDCCU( rpcTempCU, 2398 m_ppcOrigYuv[uhDepth], 2399 ( rpcTempCU != rpcTempCUPre ) ? m_ppcPredYuvBest[uhDepth] : m_ppcPredYuvTemp[uhDepth], 2400 m_ppcResiYuvTemp[uhDepth], 2401 m_ppcRecoYuvTemp[uhDepth], 2402 iSdcOffset, 2403 uhDepth ); 2404 if (uiOffest <= 3 ) 2405 { 2406 dOffsetCost [uiOffest -1] = rpcTempCU->getTotalCost(); 2407 } 2408 #else 2241 2409 m_pcPredSearch->encodeResAndCalcRdInterSDCCU( rpcTempCU, 2242 2410 m_ppcOrigYuv[uhDepth], … … 2246 2414 uiOffest, 2247 2415 uhDepth ); 2416 #endif 2248 2417 2249 2418 xCheckDQP( rpcTempCU ); … … 2320 2489 } 2321 2490 } 2322 2491 #if MTK_SINGLE_DEPTH_MODE_I0095 2492 Void TEncCu::xCheckRDCostSingleDepth( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize eSize ) 2493 { 2494 UInt uiDepth = rpcTempCU->getDepth( 0 ); 2495 if( !rpcBestCU->getSlice()->getIsDepth() || (eSize != SIZE_2Nx2N)) 2496 { 2497 return; 2498 } 2499 2500 #if H_3D_VSO // M5 2501 if( m_pcRdCost->getUseRenModel() ) 2502 { 2503 UInt uiWidth = m_ppcOrigYuv[uiDepth]->getWidth (); 2504 UInt uiHeight = m_ppcOrigYuv[uiDepth]->getHeight (); 2505 Pel* piSrc = m_ppcOrigYuv[uiDepth]->getLumaAddr(); 2506 UInt uiSrcStride = m_ppcOrigYuv[uiDepth]->getStride (); 2507 m_pcRdCost->setRenModelData( rpcTempCU, 0, piSrc, uiSrcStride, uiWidth, uiHeight ); 2508 } 2509 #endif 2510 2511 rpcTempCU->setSkipFlagSubParts( false, 0, uiDepth ); 2512 rpcTempCU->setPartSizeSubParts( SIZE_2Nx2N, 0, uiDepth ); 2513 rpcTempCU->setPredModeSubParts( MODE_INTRA, 0, uiDepth ); 2514 rpcTempCU->setCUTransquantBypassSubParts( rpcTempCU->getCUTransquantBypass(0), 0, uiDepth ); 2515 2516 rpcTempCU->setTrIdxSubParts(0, 0, uiDepth); 2517 rpcTempCU->setCbfSubParts(0, 1, 1, 0, uiDepth); 2518 rpcTempCU->setSingleDepthFlagSubParts(true, 0, uiDepth); 2519 rpcTempCU->setLumaIntraDirSubParts (DC_IDX, 0, uiDepth); 2520 #if H_3D_DIM_SDC 2521 rpcTempCU->setSDCFlagSubParts( false, 0, uiDepth); 2522 #endif 2523 2524 UInt uiPreCalcDistC; 2525 m_pcPredSearch ->estIntraPredSingleDepth ( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], uiPreCalcDistC, false ); 2526 2527 2528 m_ppcRecoYuvTemp[uiDepth]->copyToPicLuma(rpcTempCU->getPic()->getPicYuvRec(), rpcTempCU->getAddr(), rpcTempCU->getZorderIdxInCU() ); 2529 2530 2531 m_pcEntropyCoder->resetBits(); 2532 if ( rpcTempCU->getSlice()->getPPS()->getTransquantBypassEnableFlag()) 2533 { 2534 m_pcEntropyCoder->encodeCUTransquantBypassFlag( rpcTempCU, 0, true ); 2535 } 2536 m_pcEntropyCoder->encodeSkipFlag ( rpcTempCU, 0, true ); 2537 m_pcEntropyCoder->encodeSingleDepthMode( rpcTempCU, 0, true ); 2538 2539 2540 m_pcRDGoOnSbacCoder->store(m_pppcRDSbacCoder[uiDepth][CI_TEMP_BEST]); 2541 2542 rpcTempCU->getTotalBits() = m_pcEntropyCoder->getNumberOfWrittenBits(); 2543 rpcTempCU->getTotalBins() = ((TEncBinCABAC *)((TEncSbac*)m_pcEntropyCoder->m_pcEntropyCoderIf)->getEncBinIf())->getBinsCoded(); 2544 2545 2546 #if H_3D_VSO // M6 2547 if( m_pcRdCost->getUseLambdaScaleVSO()) 2548 rpcTempCU->getTotalCost() = m_pcRdCost->calcRdCostVSO( rpcTempCU->getTotalBits(), rpcTempCU->getTotalDistortion() ); 2549 else 2550 #endif 2551 rpcTempCU->getTotalCost() = m_pcRdCost->calcRdCost( rpcTempCU->getTotalBits(), rpcTempCU->getTotalDistortion() ); 2552 2553 2554 xCheckDQP( rpcTempCU ); 2555 xCheckBestMode(rpcBestCU, rpcTempCU, uiDepth); 2556 } 2557 #endif 2323 2558 Void TEncCu::xCheckRDCostInterDBBP( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, Bool bUseMRG ) 2324 2559 { … … 2341 2576 UInt uiHeight = rpcTempCU->getHeight(0); 2342 2577 AOF( uiWidth == uiHeight ); 2578 2579 #if SEC_DBBP_DISALLOW_8x8_I0078 2580 if(uiWidth <= 8) 2581 { 2582 return; 2583 } 2584 #endif 2343 2585 2344 2586 rpcTempCU->setPartSizeSubParts( SIZE_2Nx2N, 0, uhDepth ); … … 2438 2680 2439 2681 // reconstruct final prediction signal by combining both segments 2682 #if SHARP_DBBP_SIMPLE_FLTER_I0109 2683 m_pcPredSearch->combineSegmentsWithMask(apPredYuv, m_ppcPredYuvTemp[uhDepth], pMask, uiWidth, uiHeight, 0, eVirtualPartSize); 2684 #else 2440 2685 m_pcPredSearch->combineSegmentsWithMask(apPredYuv, m_ppcPredYuvTemp[uhDepth], pMask, uiWidth, uiHeight); 2686 #endif 2441 2687 2442 2688 m_pcPredSearch->encodeResAndCalcRdInterCU( rpcTempCU, m_ppcOrigYuv[uhDepth], m_ppcPredYuvTemp[uhDepth], m_ppcResiYuvTemp[uhDepth], m_ppcResiYuvBest[uhDepth], m_ppcRecoYuvTemp[uhDepth], false ); … … 2447 2693 #endif 2448 2694 2695 #if HHI_DMM4_ENC_I0066 2696 Void TEncCu::xCheckRDCostIntra( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize eSize, Bool bOnlyIVP ) 2697 #else 2449 2698 Void TEncCu::xCheckRDCostIntra( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize eSize ) 2699 #endif 2450 2700 { 2451 2701 UInt uiDepth = rpcTempCU->getDepth( 0 ); … … 2463 2713 2464 2714 rpcTempCU->setSkipFlagSubParts( false, 0, uiDepth ); 2465 2715 #if MTK_SINGLE_DEPTH_MODE_I0095 2716 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uiDepth ); 2717 #endif 2466 2718 rpcTempCU->setPartSizeSubParts( eSize, 0, uiDepth ); 2467 2719 rpcTempCU->setPredModeSubParts( MODE_INTRA, 0, uiDepth ); … … 2473 2725 m_pcPredSearch->preestChromaPredMode( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth] ); 2474 2726 } 2727 #if HHI_DMM4_ENC_I0066 2728 m_pcPredSearch ->estIntraPredQT ( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], uiPreCalcDistC, bSeparateLumaChroma, bOnlyIVP ); 2729 #else 2475 2730 m_pcPredSearch ->estIntraPredQT ( rpcTempCU, m_ppcOrigYuv[uiDepth], m_ppcPredYuvTemp[uiDepth], m_ppcResiYuvTemp[uiDepth], m_ppcRecoYuvTemp[uiDepth], uiPreCalcDistC, bSeparateLumaChroma ); 2476 2731 #endif 2477 2732 m_ppcRecoYuvTemp[uiDepth]->copyToPicLuma(rpcTempCU->getPic()->getPicYuvRec(), rpcTempCU->getAddr(), rpcTempCU->getZorderIdxInCU() ); 2478 2733 … … 2488 2743 } 2489 2744 m_pcEntropyCoder->encodeSkipFlag ( rpcTempCU, 0, true ); 2745 #if MTK_SINGLE_DEPTH_MODE_I0095 2746 m_pcEntropyCoder->encodeSingleDepthMode( rpcTempCU, 0, true ); 2747 if(!rpcTempCU->getSingleDepthFlag(0)) 2748 { 2749 #endif 2490 2750 m_pcEntropyCoder->encodePredMode( rpcTempCU, 0, true ); 2491 2751 m_pcEntropyCoder->encodePartSize( rpcTempCU, 0, uiDepth, true ); … … 2500 2760 m_pcEntropyCoder->encodeCoeff( rpcTempCU, 0, uiDepth, rpcTempCU->getWidth (0), rpcTempCU->getHeight(0), bCodeDQP ); 2501 2761 setdQPFlag( bCodeDQP ); 2502 2762 #if MTK_SINGLE_DEPTH_MODE_I0095 2763 } 2764 #endif 2503 2765 m_pcRDGoOnSbacCoder->store(m_pppcRDSbacCoder[uiDepth][CI_TEMP_BEST]); 2504 2766 … … 2528 2790 2529 2791 rpcTempCU->setSkipFlagSubParts( false, 0, uiDepth ); 2530 2792 #if MTK_SINGLE_DEPTH_MODE_I0095 2793 rpcTempCU->setSingleDepthFlagSubParts( false, 0, uiDepth ); 2794 #endif 2531 2795 rpcTempCU->setIPCMFlag(0, true); 2532 2796 rpcTempCU->setIPCMFlagSubParts (true, 0, rpcTempCU->getDepth(0)); … … 2545 2809 } 2546 2810 m_pcEntropyCoder->encodeSkipFlag ( rpcTempCU, 0, true ); 2811 #if MTK_SINGLE_DEPTH_MODE_I0095 2812 m_pcEntropyCoder->encodeSingleDepthMode( rpcTempCU, 0, true ); 2813 #endif 2547 2814 m_pcEntropyCoder->encodePredMode ( rpcTempCU, 0, true ); 2548 2815 m_pcEntropyCoder->encodePartSize ( rpcTempCU, 0, uiDepth, true ); -
trunk/source/Lib/TLibEncoder/TEncCu.h
r872 r1039 159 159 Void xCheckRDCostInterDBBP( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, Bool bUseMRG = false ); 160 160 #endif 161 #if MTK_SINGLE_DEPTH_MODE_I0095 162 Void xCheckRDCostSingleDepth ( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize ePartSize ); 163 #endif 164 #if HHI_DMM4_ENC_I0066 165 Void xCheckRDCostIntra ( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize ePartSize, Bool bOnlyIVP ); 166 #else 161 167 Void xCheckRDCostIntra ( TComDataCU*& rpcBestCU, TComDataCU*& rpcTempCU, PartSize ePartSize ); 168 #endif 162 169 Void xCheckDQP ( TComDataCU* pcCU ); 163 170 -
trunk/source/Lib/TLibEncoder/TEncEntropy.cpp
r976 r1039 119 119 m_pcEntropyCoderIf->codeSkipFlag( pcCU, uiAbsPartIdx ); 120 120 } 121 121 #if MTK_SINGLE_DEPTH_MODE_I0095 122 Void TEncEntropy::encodeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD ) 123 { 124 if ( !pcCU->getSlice()->getIsDepth() ) 125 { 126 return; 127 } 128 if(!pcCU->getSlice()->getApplySingleDepthMode()) 129 { 130 return; 131 } 132 133 if( bRD ) 134 { 135 uiAbsPartIdx = 0; 136 } 137 m_pcEntropyCoderIf->codeSingleDepthMode( pcCU, uiAbsPartIdx ); 138 } 139 #endif 122 140 /** encode merge flag 123 141 * \param pcCU … … 244 262 245 263 #if H_3D_DBBP 264 #if! SEC_DBBP_EXPLICIT_SIG_I0077 246 265 PartSize eVirtualPartSize = pcCU->getPartitionSize(uiAbsPartIdx); 247 266 if( pcCU->getDBBPFlag(uiAbsPartIdx) ) … … 253 272 } 254 273 #endif 274 #endif 255 275 256 276 m_pcEntropyCoderIf->codePartSize( pcCU, uiAbsPartIdx, uiDepth ); 257 277 258 278 #if H_3D_DBBP 279 #if SEC_DBBP_EXPLICIT_SIG_I0077 280 #if SEC_DBBP_DISALLOW_8x8_I0078 281 if( pcCU->getSlice()->getVPS()->getUseDBBP(pcCU->getSlice()->getLayerIdInVps()) && (pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_2NxN || pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_Nx2N) && pcCU->getWidth(uiAbsPartIdx) > 8 ) 282 #else 283 if( pcCU->getSlice()->getVPS()->getUseDBBP(pcCU->getSlice()->getLayerIdInVps()) && (pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_2NxN || pcCU->getPartitionSize(uiAbsPartIdx) == SIZE_Nx2N) ) 284 #endif 285 #else 286 #if SEC_DBBP_DISALLOW_8x8_I0078 287 if( pcCU->getSlice()->getVPS()->getUseDBBP(pcCU->getSlice()->getLayerIdInVps()) && pcCU->getWidth(uiAbsPartIdx) > 8 ) 288 #else 259 289 if( pcCU->getSlice()->getVPS()->getUseDBBP(pcCU->getSlice()->getLayerIdInVps()) ) 290 #endif 291 #endif 260 292 { 261 293 encodeDBBPFlag(pcCU, uiAbsPartIdx, bRD); 262 294 #if !SEC_DBBP_EXPLICIT_SIG_I0077 263 295 if( pcCU->getDBBPFlag(uiAbsPartIdx) ) 264 296 { … … 266 298 pcCU->setPartSizeSubParts(eVirtualPartSize, uiAbsPartIdx, uiDepth); 267 299 } 300 #endif 268 301 } 269 302 #endif -
trunk/source/Lib/TLibEncoder/TEncEntropy.h
r884 r1039 86 86 virtual Void codeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0; 87 87 virtual Void codeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0; 88 #if MTK_SINGLE_DEPTH_MODE_I0095 89 virtual Void codeSingleDepthMode ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0; 90 #endif 88 91 virtual Void codeMergeFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0; 89 92 virtual Void codeMergeIndex ( TComDataCU* pcCU, UInt uiAbsPartIdx ) = 0; … … 171 174 Void encodeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD = false ); 172 175 Void encodeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD = false ); 176 #if MTK_SINGLE_DEPTH_MODE_I0095 177 Void encodeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD=false ); 178 #endif 173 179 Void encodePUWise ( TComDataCU* pcCU, UInt uiAbsPartIdx, Bool bRD = false ); 174 180 Void encodeInterDirPU ( TComDataCU* pcSubCU, UInt uiAbsPartIdx ); -
trunk/source/Lib/TLibEncoder/TEncGOP.cpp
r976 r1039 934 934 pcSlice->setRefPicList ( rcListPic ); 935 935 #endif 936 936 #if MTK_SINGLE_DEPTH_MODE_I0095 937 TEncTop* pcEncTop = (TEncTop*) m_pcCfg; 938 bool enableSingleDepthMode=false; 939 if(pcEncTop->getUseSingleDepthMode()) 940 { 941 if(pcSlice->getIsDepth()) 942 { 943 enableSingleDepthMode=true; 944 } 945 } 946 pcSlice->setApplySingleDepthMode(enableSingleDepthMode); 947 #endif 937 948 #if H_3D_ARP 938 949 //GT: This seems to be broken when layerId in vps is not equal to layerId in nuh -
trunk/source/Lib/TLibEncoder/TEncSbac.cpp
r976 r1039 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 MTK_SINGLE_DEPTH_MODE_I0095 61 , m_cCUSingleDepthFlagSCModel ( 1, 1, NUM_SINGLEDEPTH_FLAG_CTX , m_contextModels + m_numContextModels, m_numContextModels) 62 , m_cSingleDepthValueSCModel ( 1, 1, NUM_SINGLE_DEPTH_VALUE_DATA_CTX , m_contextModels + m_numContextModels, m_numContextModels) 63 #endif 60 64 , m_cCUMergeFlagExtSCModel ( 1, 1, NUM_MERGE_FLAG_EXT_CTX , m_contextModels + m_numContextModels, m_numContextModels) 61 65 , m_cCUMergeIdxExtSCModel ( 1, 1, NUM_MERGE_IDX_EXT_CTX , m_contextModels + m_numContextModels, m_numContextModels) … … 130 134 131 135 m_cCUSkipFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SKIP_FLAG ); 136 #if MTK_SINGLE_DEPTH_MODE_I0095 137 m_cCUSingleDepthFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLEDEPTH_FLAG ); 138 m_cSingleDepthValueSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA ); 139 #endif 132 140 m_cCUMergeFlagExtSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_MERGE_FLAG_EXT); 133 141 m_cCUMergeIdxExtSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_MERGE_IDX_EXT); … … 206 214 curCost = m_cCUSplitFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_SPLIT_FLAG ); 207 215 curCost += m_cCUSkipFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_SKIP_FLAG ); 216 #if MTK_SINGLE_DEPTH_MODE_I0095 217 curCost += m_cCUSingleDepthFlagSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_SINGLEDEPTH_FLAG ); 218 curCost += m_cSingleDepthValueSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA ); 219 #endif 208 220 curCost += m_cCUMergeFlagExtSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_MERGE_FLAG_EXT); 209 221 curCost += m_cCUMergeIdxExtSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_MERGE_IDX_EXT); … … 243 255 curCost += m_CUTransquantBypassFlagSCModel.calcCost( curSliceType, qp, (UChar*)INIT_CU_TRANSQUANT_BYPASS_FLAG ); 244 256 #if H_3D_DIM 257 #if SEPARATE_FLAG_I0085 258 if( m_pcSlice->getVpsDepthModesFlag() || m_pcSlice->getIVPFlag() ) 259 #else 245 260 if( m_pcSlice->getVpsDepthModesFlag() ) 261 #endif 246 262 { 247 263 curCost += m_cDepthIntraModeSCModel.calcCost ( curSliceType, qp, (UChar*)INIT_DEPTH_INTRA_MODE ); … … 275 291 276 292 m_cCUSkipFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SKIP_FLAG ); 293 #if MTK_SINGLE_DEPTH_MODE_I0095 294 m_cCUSingleDepthFlagSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLEDEPTH_FLAG ); 295 m_cSingleDepthValueSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_SINGLE_DEPTH_VALUE_DATA ); 296 #endif 277 297 m_cCUMergeFlagExtSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_MERGE_FLAG_EXT); 278 298 m_cCUMergeIdxExtSCModel.initBuffer ( eSliceType, iQp, (UChar*)INIT_MERGE_IDX_EXT); … … 434 454 m_pcBinIf->encodeBinsEP( bins, numBins ); 435 455 } 436 456 #if MTK_SINGLE_DEPTH_MODE_I0095 457 Void TEncSbac::codeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx ) 458 { 459 UInt uiSymbol = pcCU->getSingleDepthFlag(uiAbsPartIdx ) ? 1 : 0; 460 m_pcBinIf->encodeBin( uiSymbol, m_cCUSingleDepthFlagSCModel.get( 0, 0, 0 ) ); 461 if(uiSymbol) 462 { 463 UInt uiUnaryIdx = (UInt) pcCU->getSingleDepthValue(uiAbsPartIdx); 464 UInt uiNumCand = MTK_SINGLE_DEPTH_MODE_CANDIDATE_LIST_SIZE; 465 if ( uiNumCand > 1 ) 466 { 467 for( UInt ui = 0; ui < uiNumCand - 1; ++ui ) 468 { 469 const UInt uiSymbol2 = ui == uiUnaryIdx ? 0 : 1; 470 if ( ui==0 ) 471 { 472 m_pcBinIf->encodeBin( uiSymbol2, m_cSingleDepthValueSCModel.get( 0, 0, 0 ) ); 473 } 474 else 475 { 476 m_pcBinIf->encodeBinEP( uiSymbol2 ); 477 } 478 if( uiSymbol2 == 0 ) 479 { 480 break; 481 } 482 } 483 } 484 } 485 } 486 #endif 437 487 /** Coding of coeff_abs_level_minus3 438 488 * \param uiSymbol value of coeff_abs_level_minus3 … … 514 564 #endif 515 565 566 #if !FIX_TICKET_76 516 567 #if H_3D_DIM_SDC 517 568 Void TEncSbac::xCodeSDCResidualData ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiSegment ) … … 600 651 #endif 601 652 #endif 653 #endif 654 602 655 603 656 // SBAC RD … … 664 717 PartSize eSize = pcCU->getPartitionSize( uiAbsPartIdx ); 665 718 #if H_3D_QTLPC 719 #if MTK_I0099_VPS_EX2 720 TComVPS *vps = pcCU->getPic()->getSlice(0)->getVPS(); 721 Bool bLimQtPredFlag = vps->getLimQtPredFlag(pcCU->getPic()->getSlice(0)->getLayerId()); 722 #else 666 723 TComSPS *sps = pcCU->getPic()->getSlice(0)->getSPS(); 724 #endif 667 725 TComPic *pcTexture = pcCU->getSlice()->getTexturePic(); 668 726 Bool bDepthMapDetect = (pcTexture != NULL); … … 673 731 Bool depthDependent = false; 674 732 UInt uiTexturePart = eSize; 733 #if MTK_I0099_VPS_EX2 734 if(bDepthMapDetect && !bIntraSliceDetect && !rapPic && pcCU->getPic()->getReduceBitsFlag() && bLimQtPredFlag ) 735 #else 675 736 if(bDepthMapDetect && !bIntraSliceDetect && !rapPic && pcCU->getPic()->getReduceBitsFlag() && sps->getUseQTL() && sps->getUsePC() ) 737 #endif 676 738 { 677 739 TComDataCU *pcTextureCU = pcTexture->getCU(pcCU->getAddr()); … … 1031 1093 Bool bCodeSplitFlag = true; 1032 1094 1095 #if MTK_I0099_VPS_EX2 1096 TComVPS *vps = pcCU->getPic()->getSlice(0)->getVPS(); 1097 Bool bLimQtPredFlag = vps->getLimQtPredFlag(pcCU->getPic()->getSlice(0)->getLayerId()); 1098 #else 1033 1099 TComSPS *sps = pcCU->getPic()->getSlice(0)->getSPS(); 1100 #endif 1034 1101 TComPic *pcTexture = pcCU->getSlice()->getTexturePic(); 1035 1102 Bool bDepthMapDetect = (pcTexture != NULL); … … 1038 1105 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); 1039 1106 1107 #if MTK_I0099_VPS_EX2 1108 if(bDepthMapDetect && !bIntraSliceDetect && !rapPic && pcCU->getPic()->getReduceBitsFlag() && bLimQtPredFlag ) 1109 #else 1040 1110 if(bDepthMapDetect && !bIntraSliceDetect && !rapPic && pcCU->getPic()->getReduceBitsFlag() && sps->getUseQTL() && sps->getUsePC()) 1111 #endif 1041 1112 { 1042 1113 TComDataCU *pcTextureCU = pcTexture->getCU(pcCU->getAddr()); … … 1088 1159 dir[j] = pcCU->getLumaIntraDir( absPartIdx+partOffset*j ); 1089 1160 #if H_3D_DIM 1161 #if SEPARATE_FLAG_I0085 1162 if( pcCU->getSlice()->getVpsDepthModesFlag() || pcCU->getSlice()->getIVPFlag() ) 1163 #else 1090 1164 if( pcCU->getSlice()->getVpsDepthModesFlag() ) 1165 #endif 1091 1166 { 1092 1167 codeIntraDepth( pcCU, absPartIdx+partOffset*j ); … … 1234 1309 } 1235 1310 //mode coding 1311 #if SEPARATE_FLAG_I0085 1312 if( pcCU->getSlice()->getVpsDepthModesFlag() && pcCU->getSlice()->getIVPFlag()) 1313 { 1314 m_pcBinIf->encodeBin( uiCodeIdx == 0 ? 0 : 1, m_cDepthIntraModeSCModel.get( 0, 0, 0 ) ); 1315 } 1316 #else 1236 1317 m_pcBinIf->encodeBin( uiCodeIdx == 0 ? 0 : 1, m_cDepthIntraModeSCModel.get( 0, 0, 0 ) ); 1318 #endif 1237 1319 } 1238 1320 } … … 2278 2360 } 2279 2361 2362 #if HS_DMM_SIGNALLING_I0120 2363 UInt uiNumSegments = isDimMode( pcCU->getLumaIntraDir( absPartIdx ) ) ? 2 : 1; 2364 UInt dimDeltaDC = 1; 2365 #else 2280 2366 UInt uiNumSegments = 0; 2281 2367 UInt dimDeltaDC = 0; 2282 2368 #endif 2369 2370 #if HS_DMM_SIGNALLING_I0120 2371 if( pcCU->isIntra( absPartIdx ) && pcCU->getSDCFlag( absPartIdx )) 2372 { 2373 #else 2283 2374 if( pcCU->isIntra( absPartIdx ) ) 2284 2375 { … … 2288 2379 if( pcCU->getSDCFlag( absPartIdx ) ) 2289 2380 { 2381 #endif 2290 2382 if( uiNumSegments == 1 ) 2291 2383 { … … 2296 2388 dimDeltaDC = ( pcCU->getSDCSegmentDCOffset( 0, absPartIdx ) || pcCU->getSDCSegmentDCOffset( 1, absPartIdx ) ) ? 1 : 0; 2297 2389 } 2390 #if !HS_DMM_SIGNALLING_I0120 2298 2391 } 2299 2392 else … … 2301 2394 dimDeltaDC = isDimDeltaDC( dir ); 2302 2395 } 2396 #endif 2303 2397 m_pcBinIf->encodeBin( dimDeltaDC, m_cDdcFlagSCModel.get( 0, 0, 0 ) ); 2304 2398 } 2399 #if !HS_DMM_SIGNALLING_I0120 2305 2400 else //all-zero inter SDC is not allowed 2306 2401 { … … 2308 2403 dimDeltaDC = 1; 2309 2404 } 2405 #endif 2310 2406 2311 2407 if( dimDeltaDC ) … … 2343 2439 Void TEncSbac::codeDBBPFlag( TComDataCU* pcCU, UInt uiAbsPartIdx ) 2344 2440 { 2441 #if SEC_DBBP_EXPLICIT_SIG_I0077 2442 PartSize ePartSize = pcCU->getPartitionSize( uiAbsPartIdx ); 2443 AOF( ePartSize == SIZE_2NxN || ePartSize == SIZE_Nx2N ); 2444 #endif 2345 2445 AOF( pcCU->getSlice()->getVPS()->getUseDBBP(pcCU->getSlice()->getLayerIdInVps()) ); 2346 2446 AOF( !pcCU->getSlice()->getIsDepth() ); -
trunk/source/Lib/TLibEncoder/TEncSbac.h
r976 r1039 130 130 Void xCodeDmm1WedgeIdx ( UInt uiTabIdx, Int iNumBit ); 131 131 #endif 132 #if !FIX_TICKET_76 132 133 #if H_3D_DIM_SDC 133 134 Void xCodeSDCResidualData ( TComDataCU* pcCU, UInt uiAbsPartIdx, UInt uiSegment ); 135 #endif 134 136 #endif 135 137 #endif … … 153 155 Void codeCUTransquantBypassFlag( TComDataCU* pcCU, UInt uiAbsPartIdx ); 154 156 Void codeSkipFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ); 157 #if MTK_SINGLE_DEPTH_MODE_I0095 158 Void codeSingleDepthMode( TComDataCU* pcCU, UInt uiAbsPartIdx ); 159 #endif 155 160 Void codeMergeFlag ( TComDataCU* pcCU, UInt uiAbsPartIdx ); 156 161 Void codeMergeIndex ( TComDataCU* pcCU, UInt uiAbsPartIdx ); … … 219 224 ContextModel3DBuffer m_cCUSplitFlagSCModel; 220 225 ContextModel3DBuffer m_cCUSkipFlagSCModel; 226 #if MTK_SINGLE_DEPTH_MODE_I0095 227 ContextModel3DBuffer m_cCUSingleDepthFlagSCModel; 228 ContextModel3DBuffer m_cSingleDepthValueSCModel; 229 #endif 221 230 ContextModel3DBuffer m_cCUMergeFlagExtSCModel; 222 231 ContextModel3DBuffer m_cCUMergeIdxExtSCModel; -
trunk/source/Lib/TLibEncoder/TEncSearch.cpp
r976 r1039 915 915 } 916 916 m_pcEntropyCoder->encodeSkipFlag( pcCU, 0, true ); 917 #if MTK_SINGLE_DEPTH_MODE_I0095 918 m_pcEntropyCoder->encodeSingleDepthMode(pcCU, 0, true ); 919 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx)) 920 #endif 917 921 m_pcEntropyCoder->encodePredMode( pcCU, 0, true ); 918 922 } 919 923 #if MTK_SINGLE_DEPTH_MODE_I0095 924 else 925 { 926 m_pcEntropyCoder->encodeSingleDepthMode(pcCU, 0, true ); 927 } 928 #endif 929 #if MTK_SINGLE_DEPTH_MODE_I0095 930 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx)) 931 { 932 #endif 920 933 m_pcEntropyCoder ->encodePartSize( pcCU, 0, pcCU->getDepth(0), true ); 921 934 … … 932 945 } 933 946 } 934 } 947 #if MTK_SINGLE_DEPTH_MODE_I0095 948 } 949 #endif 950 } 951 #if MTK_SINGLE_DEPTH_MODE_I0095 952 if(!pcCU->getSingleDepthFlag(uiAbsPartIdx)) 953 { 954 #endif 935 955 // luma prediction mode 936 956 if( pcCU->getPartitionSize(0) == SIZE_2Nx2N ) … … 975 995 } 976 996 } 977 997 #if MTK_SINGLE_DEPTH_MODE_I0095 998 } 999 #endif 978 1000 } 979 1001 if( bChroma ) … … 1837 1859 dRDCost += dSingleCost; 1838 1860 } 1839 1861 #if MTK_SINGLE_DEPTH_MODE_I0095 1862 Void TEncSearch::xIntraCodingSingleDepth( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, Int iTestDepthIdx, Pel *DepthNeighbor ) 1863 { 1864 UInt uiWidth = pcCU ->getWidth ( 0 ); 1865 UInt uiHeight = pcCU ->getHeight ( 0 ); 1866 UInt uiStride = pcOrgYuv ->getStride (); 1867 Pel* piOrg = pcOrgYuv ->getLumaAddr( uiAbsPartIdx ); 1868 Pel* piPred = pcPredYuv->getLumaAddr( uiAbsPartIdx ); 1869 1870 AOF( uiWidth == uiHeight ); 1871 AOF( uiAbsPartIdx == 0 ); 1872 pcCU->setSingleDepthValueSubParts((Pel)iTestDepthIdx,uiAbsPartIdx, 0, pcCU->getDepth(0)); 1873 //===== reconstruction ===== 1874 1875 for( UInt uiY = 0; uiY < uiHeight; uiY++ ) 1876 { 1877 for( UInt uiX = 0; uiX < uiWidth; uiX++ ) 1878 { 1879 piPred[ uiX ] = DepthNeighbor[iTestDepthIdx]; 1880 } 1881 piPred += uiStride; 1882 } 1883 1884 // clear UV 1885 UInt uiStrideC = pcPredYuv->getCStride(); 1886 Pel *pRecCb = pcPredYuv->getCbAddr(); 1887 Pel *pRecCr = pcPredYuv->getCrAddr(); 1888 1889 for (Int y=0; y<uiHeight/2; y++) 1890 { 1891 for (Int x=0; x<uiWidth/2; x++) 1892 { 1893 pRecCb[x] = 1<<(g_bitDepthC-1); 1894 pRecCr[x] = 1<<(g_bitDepthC-1); 1895 } 1896 1897 pRecCb += uiStrideC; 1898 pRecCr += uiStrideC; 1899 } 1900 1901 piPred = pcPredYuv->getLumaAddr( uiAbsPartIdx ); 1902 //===== determine distortion ===== 1903 #if H_3D_VSO 1904 if ( m_pcRdCost->getUseVSO() ) 1905 ruiDist = m_pcRdCost->getDistPartVSO ( pcCU, uiAbsPartIdx, piPred, uiStride, piOrg, uiStride, uiWidth, uiHeight, false ); 1906 else 1907 #endif 1908 ruiDist = m_pcRdCost->getDistPart(g_bitDepthY, piPred, uiStride, piOrg, uiStride, uiWidth, uiHeight ); 1909 1910 //===== determine rate and r-d cost ===== 1911 m_pcEntropyCoder->resetBits(); 1912 m_pcEntropyCoder->encodeSingleDepthMode( pcCU, 0, true ); 1913 UInt uiBits = m_pcEntropyCoder->getNumberOfWrittenBits(); 1914 1915 #if H_3D_VSO 1916 if ( m_pcRdCost->getUseLambdaScaleVSO()) 1917 dRDCost = m_pcRdCost->calcRdCostVSO( uiBits, ruiDist ); 1918 else 1919 #endif 1920 dRDCost = m_pcRdCost->calcRdCost( uiBits, ruiDist ); 1921 } 1922 #endif 1840 1923 #if H_3D_DIM_SDC 1841 1924 Void TEncSearch::xIntraCodingSDC( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, Bool bZeroResidual, Int iSDCDeltaResi ) … … 1887 1970 UInt dimType = getDimType ( uiLumaPredMode ); 1888 1971 UInt patternID = pcCU->getDmmWedgeTabIdx(dimType, uiAbsPartIdx); 1972 #if SHARP_DMM1_I0110 1973 UInt uiBaseWidth = pcCU->isDMM1UpscaleMode(uiWidth) ? pcCU->getDMM1BasePatternWidth(uiWidth) : uiWidth; 1974 if ( patternID >= g_dmmWedgeLists[g_aucConvertToBit[uiBaseWidth]].size() && dimType == DMM1_IDX ) 1975 #else 1889 1976 if ( patternID >= g_dmmWedgeLists[g_aucConvertToBit[uiWidth]].size() && dimType == DMM1_IDX ) 1890 { 1977 #endif 1978 { 1979 #if SHARP_DMM1_I0110 1980 if (g_aucConvertToBit[uiBaseWidth] == 2) // Encoder method. Avoid DMM1 pattern list index exceeds the maximum DMM1 pattern number when SDC split is used. 1981 #else 1891 1982 if (g_aucConvertToBit[uiWidth] == 2) // Encoder method. Avoid DMM1 pattern list index exceeds the maximum DMM1 pattern number when SDC split is used. 1983 #endif 1892 1984 { 1893 1985 patternID = 1349; // Split 32x32 to 16x16. 1349: Maximum DMM1 pattern number when block size is 16x16 … … 1951 2043 Int uiTabIdx = pcCU->getDmmWedgeTabIdx(DMM1_IDX, uiAbsPartIdx); 1952 2044 2045 #if SHARP_DMM1_I0110 2046 WedgeList* pacWedgeList = pcCU->isDMM1UpscaleMode( uiWidth ) ? &g_dmmWedgeLists[(g_aucConvertToBit[pcCU->getDMM1BasePatternWidth(uiWidth)])] : &g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])]; 2047 #else 1953 2048 WedgeList* pacWedgeList = &g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])]; 2049 #endif 1954 2050 TComWedgelet* pcWedgelet = &(pacWedgeList->at( uiTabIdx )); 1955 2051 1956 2052 uiNumSegments = 2; 2053 #if SHARP_DMM1_I0110 2054 pbMask = pcCU->isDMM1UpscaleMode( uiWidth ) ? pcWedgelet->getScaledPattern( uiWidth ) : pcWedgelet->getPattern(); 2055 uiMaskStride = pcCU->isDMM1UpscaleMode( uiWidth ) ? uiWidth : pcWedgelet->getStride(); 2056 #else 1957 2057 pbMask = pcWedgelet->getPattern(); 1958 2058 uiMaskStride = pcWedgelet->getStride(); 2059 #endif 1959 2060 } 1960 2061 if( getDimType( uiLumaPredMode ) == DMM4_IDX ) … … 2777 2878 pcCU->setChromIntraDirSubParts( uiBestMode, 0, pcCU->getDepth( 0 ) ); 2778 2879 } 2779 2880 #if MTK_SINGLE_DEPTH_MODE_I0095 2780 2881 Void 2781 TEncSearch::estIntraPred QT( TComDataCU* pcCU,2882 TEncSearch::estIntraPredSingleDepth( TComDataCU* pcCU, 2782 2883 TComYuv* pcOrgYuv, 2783 2884 TComYuv* pcPredYuv, … … 2786 2887 UInt& ruiDistC, 2787 2888 Bool bLumaOnly ) 2889 { 2890 UInt uiDepth = pcCU->getDepth(0); 2891 UInt uiWidth = pcCU->getWidth (0); 2892 UInt uiHeight = pcCU->getHeight(0); 2893 2894 2895 Pel* piOrg = pcOrgYuv ->getLumaAddr( 0, uiWidth ); 2896 UInt uiStride = pcPredYuv->getStride(); 2897 2898 Int index=0; 2899 Pel testDepth; 2900 Pel DepthNeighbours[5]; 2901 //construction of depth candidates 2902 for( Int i = 0; (i < 5) && (index<MTK_SINGLE_DEPTH_MODE_CANDIDATE_LIST_SIZE) ; i++ ) 2903 { 2904 if(!pcCU->getNeighDepth (0, 0, &testDepth, i)) 2905 { 2906 continue; 2907 } 2908 DepthNeighbours[index]=testDepth; 2909 index++; 2910 for(Int j=0;j<index-1;j++) 2911 { 2912 if( (DepthNeighbours[index-1]==DepthNeighbours[j])) 2913 { 2914 index--; 2915 break; 2916 } 2917 } 2918 } 2919 2920 if(index==0) 2921 { 2922 DepthNeighbours[index]=1<<(g_bitDepthY-1); 2923 index++; 2924 } 2925 2926 if(index==1) 2927 { 2928 DepthNeighbours[index]=ClipY(DepthNeighbours[0] + 1 ); 2929 index++; 2930 } 2931 2932 2933 Dist uiDist = 0; 2934 Double dCost = 0.0; 2935 Dist uiBestDist = 0; 2936 Double dBestCost = MAX_DOUBLE; 2937 Pel pBestSingleDepthValue = 0; 2938 2939 for( Int testdepthidx = 0; testdepthidx < index ; testdepthidx++ ) 2940 { 2941 // set context models 2942 m_pcRDGoOnSbacCoder->load( m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST] ); 2943 2944 // determine residual for partition 2945 uiDist = 0; 2946 dCost = 0.0; 2947 #if H_3D_VSO // M36 2948 if( m_pcRdCost->getUseRenModel() ) 2949 { 2950 m_pcRdCost->setRenModelData( pcCU, 0, piOrg, uiStride, uiWidth, uiHeight ); 2951 } 2952 #endif 2953 xIntraCodingSingleDepth(pcCU, 0, pcOrgYuv, pcPredYuv, uiDist, dCost, testdepthidx, DepthNeighbours); 2954 // check r-d cost 2955 if( dCost < dBestCost ) 2956 { 2957 uiBestDist = uiDist; 2958 dBestCost = dCost; 2959 pBestSingleDepthValue = pcCU->getSingleDepthValue(0); 2960 // copy reconstruction 2961 pcPredYuv->copyPartToPartYuv(pcRecoYuv, 0, uiWidth, uiHeight); 2962 } 2963 } // depth index loop 2964 2965 2966 pcCU->setSingleDepthValueSubParts((Pel)pBestSingleDepthValue,0, 0, uiDepth); 2967 assert(pBestSingleDepthValue>=0); 2968 2969 //===== reset context models ===== 2970 m_pcRDGoOnSbacCoder->load(m_pppcRDSbacCoder[uiDepth][CI_CURR_BEST]); 2971 2972 //===== set distortion (rate and r-d costs are determined later) ===== 2973 pcCU->getTotalDistortion() = uiBestDist; 2974 } 2975 2976 #endif 2977 Void 2978 TEncSearch::estIntraPredQT( TComDataCU* pcCU, 2979 TComYuv* pcOrgYuv, 2980 TComYuv* pcPredYuv, 2981 TComYuv* pcResiYuv, 2982 TComYuv* pcRecoYuv, 2983 UInt& ruiDistC, 2984 Bool bLumaOnly 2985 #if HHI_DMM4_ENC_I0066 2986 , Bool bOnlyIVP 2987 #endif 2988 ) 2788 2989 { 2789 2990 UInt uiDepth = pcCU->getDepth(0); … … 2831 3032 Int numModesForFullRD = g_aucIntraModeNumFast[ uiWidthBit ]; 2832 3033 3034 #if HHI_DMM4_ENC_I0066 3035 if( bOnlyIVP ) 3036 { 3037 numModesForFullRD = 0; 3038 } 3039 else 3040 { 3041 #endif 2833 3042 Bool doFastSearch = (numModesForFullRD != numModesAvailable); 2834 3043 if (doFastSearch) … … 2922 3131 } 2923 3132 } 2924 3133 #if HHI_DMM4_ENC_I0066 3134 } 3135 #endif 3136 2925 3137 #if H_3D_DIM 2926 3138 //===== determine set of depth intra modes to be tested ===== 2927 3139 if( m_pcEncCfg->getIsDepth() && uiWidth >= DIM_MIN_SIZE && uiWidth <= DIM_MAX_SIZE && uiWidth == uiHeight ) 2928 3140 { 2929 3141 #if HHI_DMM4_ENC_I0066 3142 #if SEPARATE_FLAG_I0085 3143 if( bOnlyIVP && m_pcEncCfg->getUseIVP() ) 3144 #else 3145 if( bOnlyIVP ) 3146 #endif 3147 { 3148 TComWedgelet* dmm4Segmentation = new TComWedgelet( uiWidth, uiHeight ); 3149 xPredContourFromTex( pcCU, uiPartOffset, uiWidth, uiHeight, dmm4Segmentation ); 3150 3151 Pel deltaDC1 = 0; Pel deltaDC2 = 0; 3152 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, dmm4Segmentation->getPattern(), dmm4Segmentation->getStride(), uiWidth, uiHeight, deltaDC1, deltaDC2 ); 3153 pcCU->setDimDeltaDC( DMM4_IDX, 0, uiPartOffset, deltaDC1 ); 3154 pcCU->setDimDeltaDC( DMM4_IDX, 1, uiPartOffset, deltaDC2 ); 3155 3156 #if HS_DMM_SIGNALLING_I0120 3157 uiRdModeList[ numModesForFullRD++ ] = (DMM4_IDX+DIM_OFFSET); 3158 #else 3159 uiRdModeList[ numModesForFullRD++ ] = (2*DMM4_IDX +DIM_OFFSET); 3160 if( deltaDC1 != 0 || deltaDC2 != 0 ) 3161 uiRdModeList[ numModesForFullRD++ ] = (2*DMM4_IDX+1+DIM_OFFSET); 3162 #endif 3163 dmm4Segmentation->destroy(); delete dmm4Segmentation; 3164 } 3165 else 3166 { 3167 #endif 2930 3168 #if H_3D_FAST_DEPTH_INTRA 2931 3169 Int threshold = max(((pcCU->getQP(0))>>3)-1,3); … … 2935 3173 2936 3174 #if H_3D_DIM_DMM 3175 #if SEPARATE_FLAG_I0085 3176 if( ( m_pcEncCfg->getUseDMM() || m_pcEncCfg->getUseIVP() ) 3177 #else 2937 3178 if( m_pcEncCfg->getUseDMM() 3179 #endif 2938 3180 #if H_3D_FAST_DEPTH_INTRA 2939 3181 && (uiRdModeList[0] != PLANAR_IDX || varCU >= varThreshold) … … 2941 3183 ) 2942 3184 { 3185 #if SEPARATE_FLAG_I0085 3186 UInt uiStart, uiEnd; 3187 if( m_pcEncCfg->getUseDMM() && m_pcEncCfg->getUseIVP() ) 3188 { 3189 uiStart = 0; 3190 uiEnd = 2; 3191 } 3192 else if( m_pcEncCfg->getUseDMM() ) 3193 { 3194 uiStart = 0; 3195 uiEnd = 1; 3196 } 3197 else if( m_pcEncCfg->getUseIVP() ) 3198 { 3199 uiStart = 1; 3200 uiEnd = 2; 3201 } 3202 else 3203 { 3204 uiStart = 0; 3205 uiEnd = 0; 3206 } 3207 for( UInt dmmType = uiStart; dmmType < uiEnd; dmmType++ ) 3208 #else 2943 3209 for( UInt dmmType = 0; dmmType < DMM_NUM_TYPE; dmmType++ ) 3210 #endif 2944 3211 { 2945 3212 #if H_3D_FCO … … 2959 3226 xSearchDmm1Wedge( pcCU, uiPartOffset, piOrg, uiStride, uiWidth, uiHeight, uiTabIdx ); 2960 3227 pcCU->setDmmWedgeTabIdxSubParts( uiTabIdx, dmmType, uiPartOffset, uiDepth + uiInitTrDepth ); 3228 #if SHARP_DMM1_I0110 3229 biSegmentation = pcCU->isDMM1UpscaleMode( uiWidth ) ? 3230 &(g_dmmWedgeLists[(g_aucConvertToBit[pcCU->getDMM1BasePatternWidth(uiWidth)])][uiTabIdx]) : &(g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])][uiTabIdx]); 3231 #else 2961 3232 biSegmentation = &(g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])][uiTabIdx]); 3233 #endif 2962 3234 } break; 2963 3235 … … 2974 3246 if( biSegmentation ) 2975 3247 { 3248 #if SHARP_DMM1_I0110 3249 if( dmmType == DMM1_IDX && pcCU->isDMM1UpscaleMode( uiWidth ) ){ 3250 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegmentation->getScaledPattern(uiWidth), uiWidth, uiWidth, uiHeight, deltaDC1, deltaDC2 ); 3251 } 3252 else 3253 { 3254 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegmentation->getPattern(), biSegmentation->getStride(), uiWidth, uiHeight, deltaDC1, deltaDC2 ); 3255 } 3256 #else 2976 3257 xSearchDmmDeltaDCs( pcCU, uiPartOffset, piOrg, piPred, uiStride, biSegmentation->getPattern(), biSegmentation->getStride(), uiWidth, uiHeight, deltaDC1, deltaDC2 ); 3258 #endif 2977 3259 pcCU->setDimDeltaDC( dmmType, 0, uiPartOffset, deltaDC1 ); 2978 3260 pcCU->setDimDeltaDC( dmmType, 1, uiPartOffset, deltaDC2 ); 2979 3261 3262 #if HS_DMM_SIGNALLING_I0120 3263 uiRdModeList[ numModesForFullRD++ ] = (dmmType +DIM_OFFSET); 3264 #else 2980 3265 uiRdModeList[ numModesForFullRD++ ] = (2*dmmType +DIM_OFFSET); 3266 #if HHI_DMM4_ENC_I0066 3267 if( deltaDC1 != 0 || deltaDC2 != 0 ) 3268 #endif 2981 3269 uiRdModeList[ numModesForFullRD++ ] = (2*dmmType+1+DIM_OFFSET); 3270 #endif 2982 3271 2983 3272 if( DMM4_IDX == dmmType ) { biSegmentation->destroy(); delete biSegmentation; } … … 2985 3274 } 2986 3275 } 3276 #if HHI_DMM4_ENC_I0066 3277 } 3278 #endif 2987 3279 #endif 2988 3280 } … … 2995 3287 2996 3288 UInt uiBestPUMode = 0; 3289 #if SCU_HS_FAST_INTRA_SDC_I0123 3290 UInt uiBestPUModeConv = 0; 3291 UInt uiSecondBestPUModeConv = 0; 3292 UInt uiThirdBestPUModeConv = 0; 3293 #endif 3294 2997 3295 #if H_3D_VSO 2998 3296 Dist uiBestPUDistY = 0; … … 3002 3300 UInt uiBestPUDistC = 0; 3003 3301 Double dBestPUCost = MAX_DOUBLE; 3302 3303 #if SCU_HS_FAST_INTRA_SDC_I0123 3304 Double dBestPUCostConv = MAX_DOUBLE; 3305 UInt varCU = m_pcRdCost->calcVAR(piOrg, uiStride, uiWidth,uiHeight,pcCU->getDepth(0)); 3306 UInt rdSDC = m_pcEncCfg->getIsDepth() ? numModesForFullRD : 0; 3307 #endif 3308 3004 3309 #if H_3D_DIM_SDC 3005 3310 Bool bBestUseSDC = false; 3006 3311 Pel apBestDCOffsets[2] = {0,0}; 3007 3312 #endif 3313 #if SCU_HS_FAST_INTRA_SDC_I0123 3314 for( UInt uiMode = 0; uiMode < numModesForFullRD + rdSDC; uiMode++ ) 3315 #else 3008 3316 for( UInt uiMode = 0; uiMode < numModesForFullRD; uiMode++ ) 3317 #endif 3009 3318 { 3010 3319 // set luma prediction mode 3011 UInt uiOrgMode = uiRdModeList[uiMode]; 3320 #if !SCU_HS_FAST_INTRA_SDC_I0123 3321 UInt uiOrgMode = uiRdModeList[uiMode]; 3322 #endif 3012 3323 3324 #if SCU_HS_FAST_INTRA_SDC_I0123 3325 UInt uiOrgMode; 3326 if (uiMode < numModesForFullRD) 3327 { 3328 uiOrgMode = uiRdModeList[uiMode]; 3329 } 3330 else 3331 { 3332 uiOrgMode = uiRdModeList[uiMode - numModesForFullRD]; 3333 3334 if (uiBestPUModeConv <= 1 ) 3335 { 3336 if (uiOrgMode > 1 && varCU < 1) continue; 3337 } 3338 else 3339 { 3340 if (uiOrgMode != uiBestPUModeConv && uiOrgMode != uiSecondBestPUModeConv && uiOrgMode != uiThirdBestPUModeConv 3341 && uiOrgMode > 1 && uiOrgMode < NUM_INTRA_MODE && varCU < 4) 3342 continue; 3343 } 3344 } 3345 #endif 3346 3013 3347 pcCU->setLumaIntraDirSubParts ( uiOrgMode, uiPartOffset, uiDepth + uiInitTrDepth ); 3014 3348 3015 3349 #if H_3D_DIM_SDC 3350 #if SCU_HS_FAST_INTRA_SDC_I0123 3351 Bool bTestSDC = ( m_pcEncCfg->getUseSDC() && pcCU->getSDCAvailable(uiPartOffset) && uiMode >= numModesForFullRD); 3352 #else 3016 3353 Bool bTestSDC = ( m_pcEncCfg->getUseSDC() && pcCU->getSDCAvailable(uiPartOffset) ); 3354 #endif 3017 3355 3018 3356 for( UInt uiSDC=0; uiSDC<=(bTestSDC?1:0); uiSDC++ ) 3019 3357 { 3358 #if SCU_HS_FAST_INTRA_SDC_I0123 3359 if (!uiSDC && uiMode >= numModesForFullRD) continue; 3360 #endif 3020 3361 pcCU->setSDCFlagSubParts( (uiSDC != 0), uiPartOffset, uiDepth + uiInitTrDepth ); 3362 #if FAST_SDC_OFFSET_DECISION_I0084 3363 Double dOffsetCost[3] = {MAX_DOUBLE,MAX_DOUBLE,MAX_DOUBLE}; 3364 for( Int iOffset = 1; iOffset <= 5; iOffset++ ) 3365 #else 3021 3366 for( Int iSDCDeltaResi = -2; iSDCDeltaResi <= 2; iSDCDeltaResi++ ) 3022 { 3367 #endif 3368 { 3369 #if FAST_SDC_OFFSET_DECISION_I0084 3370 Int iSDCDeltaResi = 0; 3371 if(iOffset % 2 == 0) 3372 { 3373 iSDCDeltaResi = iOffset >> 1; 3374 } 3375 else 3376 { 3377 iSDCDeltaResi = -1 * (iOffset >> 1); 3378 } 3379 #endif 3023 3380 if( ( uiSDC == 0 ) && iSDCDeltaResi != 0 ) 3024 3381 { 3025 3382 continue; 3026 3383 } 3384 #if FAST_SDC_OFFSET_DECISION_I0084 3385 if( iOffset > 3) 3386 { 3387 if ( dOffsetCost[0] < (0.9*dOffsetCost[1]) && dOffsetCost[0] < (0.9*dOffsetCost[2]) ) 3388 { 3389 continue; 3390 } 3391 if ( dOffsetCost[1] < dOffsetCost[0] && dOffsetCost[0] < dOffsetCost[2] && iOffset == 5) 3392 { 3393 continue; 3394 } 3395 if ( dOffsetCost[0] < dOffsetCost[1] && dOffsetCost[2] < dOffsetCost[0] && iOffset == 4) 3396 { 3397 continue; 3398 } 3399 } 3400 #endif 3027 3401 #endif 3028 3402 … … 3070 3444 // start encoding with SDC 3071 3445 xIntraCodingSDC(pcCU, uiPartOffset, pcOrgYuv, pcPredYuv, uiPUDistY, dPUCost, ( testZeroResi != 0 ), iSDCDeltaResi ); 3446 #if FAST_SDC_OFFSET_DECISION_I0084 3447 if ( testZeroResi == 0 && iOffset <= 3 ) 3448 { 3449 dOffsetCost [iOffset -1] = dPUCost; 3450 } 3451 #endif 3072 3452 } 3073 3453 else … … 3077 3457 #if H_3D_DIM_ENC 3078 3458 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, true, dPUCost, (testZeroResi != 0) ); 3459 #if SCU_HS_FAST_INTRA_SDC_I0123 3460 if( dPUCost < dBestPUCostConv ) 3461 { 3462 uiThirdBestPUModeConv = uiSecondBestPUModeConv; 3463 uiSecondBestPUModeConv = uiBestPUModeConv; 3464 uiBestPUModeConv = uiOrgMode; 3465 dBestPUCostConv = dPUCost; 3466 } 3467 #endif 3079 3468 #else 3080 3469 xRecurIntraCodingQT( pcCU, uiInitTrDepth, uiPartOffset, bLumaOnly, pcOrgYuv, pcPredYuv, pcResiYuv, uiPUDistY, uiPUDistC, true, dPUCost ); … … 3620 4009 #if H_3D_VSP 3621 4010 , Int* vspFlag 4011 #if !FIX_TICKET_79 3622 4012 , InheritedVSPDisInfo* inheritedVSPDisInfo 4013 #endif 3623 4014 #endif 3624 4015 #if H_3D_SPIVMP … … 3680 4071 pcCU->getInterMergeCandidates( 0, 0, cMvFieldNeighbours,uhInterDirNeighbours, numValidMergeCand); 3681 4072 pcCU->xGetInterMergeCandidates( 0, 0, cMvFieldNeighbours,uhInterDirNeighbours 3682 #if H_3D_VSP 4073 #if H_3D_VSP && !FIX_TICKET_79 3683 4074 , inheritedVSPDisInfo 3684 4075 #endif … … 3710 4101 pcCU->getInterMergeCandidates( uiAbsPartIdx, iPUIdx, cMvFieldNeighbours,uhInterDirNeighbours, numValidMergeCand); 3711 4102 pcCU->xGetInterMergeCandidates( uiAbsPartIdx, iPUIdx, cMvFieldNeighbours, uhInterDirNeighbours 3712 #if H_3D_VSP 4103 #if H_3D_VSP && !FIX_TICKET_79 3713 4104 , inheritedVSPDisInfo 3714 4105 #endif … … 3733 4124 #endif 3734 4125 } 3735 #if H_3D_VSP 4126 #if H_3D_VSP && !FIX_TICKET_75 3736 4127 xRestrictBipredMergeCand( pcCU, iPUIdx, cMvFieldNeighbours, uhInterDirNeighbours,vspFlag, numValidMergeCand ); 3737 4128 #else … … 3765 4156 #if H_3D_VSP 3766 4157 pcCU->setVSPFlagSubParts( vspFlag[uiMergeCand], uiAbsPartIdx, iPUIdx, pcCU->getDepth( uiAbsPartIdx ) ); 4158 #if !FIX_TICKET_79 3767 4159 pcCU->setDvInfoSubParts(inheritedVSPDisInfo[uiMergeCand].m_acDvInfo, uiAbsPartIdx, iPUIdx, pcCU->getDepth( uiAbsPartIdx ) ); 4160 #endif 3768 4161 #endif 3769 4162 … … 3865 4258 * \returns Void 3866 4259 */ 3867 #if H_3D_VSP 4260 #if H_3D_VSP && !FIX_TICKET_75 3868 4261 Void TEncSearch::xRestrictBipredMergeCand( TComDataCU* pcCU, UInt puIdx, TComMvField* mvFieldNeighbours, UChar* interDirNeighbours, Int* vspFlag, Int numValidMergeCand ) 3869 4262 #else … … 3875 4268 for( UInt mergeCand = 0; mergeCand < numValidMergeCand; ++mergeCand ) 3876 4269 { 3877 #if H_3D_VSP 4270 #if H_3D_VSP && !FIX_TICKET_75 3878 4271 if ( (interDirNeighbours[mergeCand] == 3) && (vspFlag[mergeCand] == false) ) 3879 4272 #else … … 4501 4894 Int vspFlag[MRG_MAX_NUM_CANDS_MEM]; 4502 4895 memset(vspFlag, 0, sizeof(Int)*MRG_MAX_NUM_CANDS_MEM); 4896 #if !FIX_TICKET_79 4503 4897 InheritedVSPDisInfo inheritedVSPDisInfo[MRG_MAX_NUM_CANDS_MEM]; 4898 #endif 4504 4899 UInt uiAbsPartIdx = 0; 4505 4900 Int iWidth = 0; … … 4519 4914 #if H_3D_VSP 4520 4915 , vspFlag 4916 #if !FIX_TICKET_79 4521 4917 , inheritedVSPDisInfo 4918 #endif 4522 4919 #endif 4523 4920 #if H_3D_SPIVMP … … 4533 4930 #if H_3D_VSP 4534 4931 pcCU->setVSPFlagSubParts( vspFlag[uiMRGIndex], uiPartAddr, iPartIdx, pcCU->getDepth( uiPartAddr ) ); 4932 #if !FIX_TICKET_79 4535 4933 pcCU->setDvInfoSubParts(inheritedVSPDisInfo[uiMRGIndex].m_acDvInfo, uiPartAddr, iPartIdx, pcCU->getDepth( uiPartAddr ) ); 4934 #endif 4536 4935 #endif 4537 4936 #if H_3D_DDD … … 6981 7380 } 6982 7381 m_pcEntropyCoder->encodeSkipFlag ( pcCU, 0, true ); 7382 #if MTK_SINGLE_DEPTH_MODE_I0095 7383 m_pcEntropyCoder->encodeSingleDepthMode ( pcCU, 0, true ); 7384 #endif 6983 7385 m_pcEntropyCoder->encodePredMode( pcCU, 0, true ); 6984 7386 m_pcEntropyCoder->encodePartSize( pcCU, 0, pcCU->getDepth(0), true ); … … 7435 7837 7436 7838 Pel refDC1 = 0; Pel refDC2 = 0; 7839 #if SHARP_DMM1_I0110 7840 WedgeList* pacWedgeList = pcCU->isDMM1UpscaleMode( uiWidth ) ? &g_dmmWedgeLists[(g_aucConvertToBit[pcCU->getDMM1BasePatternWidth(uiWidth)])] : &g_dmmWedgeLists[(g_aucConvertToBit[uiWidth])]; 7841 WedgeNodeList* pacWedgeNodeList = pcCU->isDMM1UpscaleMode( uiWidth ) ? &g_dmmWedgeNodeLists[(g_aucConvertToBit[pcCU->getDMM1BasePatternWidth(uiWidth)])] : &g_dmmWedgeNodeLists[(g_aucConvertToBit[uiWidth])]; 7842 #else 7437 7843 WedgeList* pacWedgeList = &g_dmmWedgeLists [(g_aucConvertToBit[uiWidth])]; 7438 7844 WedgeNodeList* pacWedgeNodeList = &g_dmmWedgeNodeLists[(g_aucConvertToBit[uiWidth])]; 7845 #endif 7439 7846 7440 7847 // coarse wedge search … … 7444 7851 { 7445 7852 TComWedgelet* pcWedgelet = &(pacWedgeList->at(pacWedgeNodeList->at(uiNodeId).getPatternIdx())); 7853 #if SHARP_DMM1_I0110 7854 Bool *pbPattern = pcCU->isDMM1UpscaleMode(uiWidth) ? pcWedgelet->getScaledPattern(uiWidth) : pcWedgelet->getPattern(); 7855 UInt uiStride = pcCU->isDMM1UpscaleMode(uiWidth) ? uiWidth : pcWedgelet->getStride(); 7856 xCalcBiSegDCs ( piRef, uiRefStride, pbPattern, uiStride, refDC1, refDC2 ); 7857 xAssignBiSegDCs( piPred, uiPredStride, pbPattern, uiStride, refDC1, refDC2 ); 7858 #else 7446 7859 xCalcBiSegDCs ( piRef, uiRefStride, pcWedgelet->getPattern(), pcWedgelet->getStride(), refDC1, refDC2 ); 7447 7860 xAssignBiSegDCs( piPred, uiPredStride, pcWedgelet->getPattern(), pcWedgelet->getStride(), refDC1, refDC2 ); 7861 #endif 7448 7862 7449 7863 Dist uiActDist = RDO_DIST_MAX; … … 7481 7895 { 7482 7896 TComWedgelet* pcWedgelet = &(pacWedgeList->at(pacWedgeNodeList->at(uiBestNodeId).getRefineIdx( uiRefId ))); 7897 #if SHARP_DMM1_I0110 7898 Bool *pbPattern = pcCU->isDMM1UpscaleMode(uiWidth) ? pcWedgelet->getScaledPattern(uiWidth) : pcWedgelet->getPattern(); 7899 UInt uiStride = pcCU->isDMM1UpscaleMode(uiWidth) ? uiWidth : pcWedgelet->getStride(); 7900 xCalcBiSegDCs ( piRef, uiRefStride, pbPattern, uiStride, refDC1, refDC2 ); 7901 xAssignBiSegDCs( piPred, uiPredStride, pbPattern, uiStride, refDC1, refDC2 ); 7902 #else 7483 7903 xCalcBiSegDCs ( piRef, uiRefStride, pcWedgelet->getPattern(), pcWedgelet->getStride(), refDC1, refDC2 ); 7484 7904 xAssignBiSegDCs( piPred, uiPredStride, pcWedgelet->getPattern(), pcWedgelet->getStride(), refDC1, refDC2 ); 7485 7905 #endif 7486 7906 Dist uiActDist = RDO_DIST_MAX; 7487 7907 #if H_3D_VSO -
trunk/source/Lib/TLibEncoder/TEncSearch.h
r884 r1039 180 180 TComYuv* pcRecoYuv, 181 181 UInt& ruiDistC, 182 Bool bLumaOnly ); 182 Bool bLumaOnly 183 #if HHI_DMM4_ENC_I0066 184 , Bool bOnlyIVP 185 #endif 186 ); 183 187 Void estIntraPredChromaQT ( TComDataCU* pcCU, 184 188 TComYuv* pcOrgYuv, … … 187 191 TComYuv* pcRecoYuv, 188 192 UInt uiPreCalcDistC ); 189 193 #if MTK_SINGLE_DEPTH_MODE_I0095 194 Void estIntraPredSingleDepth ( TComDataCU* pcCU, 195 TComYuv* pcOrgYuv, 196 TComYuv* pcPredYuv, 197 TComYuv* pcResiYuv, 198 TComYuv* pcRecoYuv, 199 UInt& ruiDistC, 200 Bool bLumaOnly ); 201 #endif 190 202 191 203 /// encoder estimation - inter prediction (non-skip) … … 342 354 UInt uiAbsPartIdx, 343 355 UInt stateU0V1Both2 ); 344 356 #if MTK_SINGLE_DEPTH_MODE_I0095 357 Void xIntraCodingSingleDepth( TComDataCU* pcCU, UInt uiAbsPartIdx, TComYuv* pcOrgYuv, TComYuv* pcPredYuv, Dist& ruiDist, Double& dRDCost, Int iTestDepthIdx, Pel * DepthNeighbor ); 358 #endif 345 359 #if H_3D_DIM 346 360 // ------------------------------------------------------------------------------------------------------------------- … … 415 429 #if H_3D_VSP 416 430 , Int* vspFlag 431 #if !FIX_TICKET_79 417 432 , InheritedVSPDisInfo* inheritedVSPDisInfo 433 #endif 418 434 #endif 419 435 #if H_3D_SPIVMP … … 427 443 TComMvField* mvFieldNeighbours, 428 444 UChar* interDirNeighbours, 429 #if H_3D_VSP 445 #if H_3D_VSP && !FIX_TICKET_75 430 446 Int* vspFlag, 431 447 #endif -
trunk/source/Lib/TLibEncoder/TEncTop.cpp
r976 r1039 744 744 m_cSPS.setUseAMP ( m_useAMP ); 745 745 746 #if !MTK_I0099_VPS_EX2 746 747 #if H_3D_QTLPC 747 748 m_cSPS.setUseQTL( m_bUseQTL ); 748 749 m_cSPS.setUsePC ( m_bUsePC ); 750 #endif 749 751 #endif 750 752
Note: See TracChangeset for help on using the changeset viewer.