Changeset 390 in 3DVCSoftware for branches/HTM-6.2-dev2-Mediatek/source/Lib/TLibCommon/TComDataCU.cpp
- Timestamp:
- 10 May 2013, 10:17:06 (11 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
branches/HTM-6.2-dev2-Mediatek/source/Lib/TLibCommon/TComDataCU.cpp
r373 r390 69 69 if (vspIdx < 4) 70 70 { 71 #if MTK_VSP_USING_NBDV_D0105 72 pcMvFieldNeighbours[ iCount<<1].setMvField ( pDInfo->m_acMvCandNoRef[0], NOT_VALID ); 73 #else 71 74 pcMvFieldNeighbours[ iCount<<1].setMvField ( pDInfo->m_acMvCand[0], NOT_VALID ); 75 #endif 72 76 if ( pcCURef->getSlice()->isInterB() ) 73 77 { 78 #if MTK_VSP_USING_NBDV_D0105 79 pcMvFieldNeighbours[(iCount<<1)+1 ].setMvField ( pDInfo->m_acMvCandNoRef[0], NOT_VALID ); 80 #else 74 81 pcMvFieldNeighbours[(iCount<<1)+1 ].setMvField ( pDInfo->m_acMvCand[0], NOT_VALID ); 82 #endif 75 83 } 76 84 } … … 81 89 UChar* puhInterDirNeighbours, TComMvField* pcMvFieldNeighbours, Int* iVSPIndexTrue, Int mrgCandIdx, DisInfo* pDInfo ) 82 90 { 91 #if MTK_LGE_VSP_DEPTH_OFF_D0105_D0139 92 if (getSlice()->getSPS()->isDepth()) 93 { 94 return true; 95 } 96 #endif 97 83 98 #if MERL_VSP_C0152_BugFix_ForNoDepthCase 84 99 TComPic* pRefPicBaseDepth = NULL; … … 105 120 if (vspIdx < 4) // spatial 106 121 { 122 #if MTK_VSP_USING_NBDV_D0105 123 pcMvFieldNeighbours[iCount<<1].setMvField(pDInfo->m_acMvCandNoRef[0], NOT_VALID ); 124 #else 107 125 pcMvFieldNeighbours[iCount<<1].setMvField(pDInfo->m_acMvCand[0], NOT_VALID ); 126 #endif 108 127 if ( getSlice()->isInterB() ) 109 128 { 129 #if MTK_VSP_USING_NBDV_D0105 130 pcMvFieldNeighbours[(iCount<<1)+1].setMvField( pDInfo->m_acMvCandNoRef[0], NOT_VALID ); 131 #else 110 132 pcMvFieldNeighbours[(iCount<<1)+1].setMvField( pDInfo->m_acMvCand[0], NOT_VALID ); 133 #endif 111 134 } 112 135 } … … 3715 3738 cDisInfo.m_acMvCand[0] = getDvInfo(uiAbsPartIdx).m_acMvCand[0]; 3716 3739 cDisInfo.m_aVIdxCan[0] = getDvInfo(uiAbsPartIdx).m_aVIdxCan[0]; 3740 #if MTK_VSP_USING_NBDV_D0105 3741 cDisInfo.m_acMvCandNoRef[0] = getDvInfo(uiAbsPartIdx).m_acMvCandNoRef[0]; 3742 #endif 3717 3743 } 3718 3744 #else … … 3780 3806 clipMv(cMvPred); 3781 3807 pcMvFieldNeighbours[iCount<<1].setMvField(cMvPred,pcMvFieldNeighbours[iCount<<1].getRefIdx()); 3808 #if MTK_LGE_VSP_DEPTH_OFF_D0105_D0139 3809 if (pcMvFieldNeighbours[iCount<<1].getRefIdx()<0) 3810 { 3811 assert(pcTextureCU->getVSPIndex(uiPartIdxCenter)!=0); 3812 for (Int i=0; i<getSlice()->getNumRefIdx(REF_PIC_LIST_0); i++) 3813 { 3814 if (getSlice()->getRefPOC(REF_PIC_LIST_0, i) == getSlice()->getPOC()) 3815 { 3816 pcMvFieldNeighbours[iCount<<1].setMvField(cMvPred,i); 3817 break; 3818 } 3819 } 3820 } 3821 #endif 3782 3822 } 3783 3823 if ( getSlice()->isInterB() ) … … 3792 3832 clipMv(cMvPred); 3793 3833 pcMvFieldNeighbours[(iCount<<1)+1].setMvField(cMvPred,pcMvFieldNeighbours[(iCount<<1)+1].getRefIdx()); 3834 #if MTK_LGE_VSP_DEPTH_OFF_D0105_D0139 3835 if (pcMvFieldNeighbours[(iCount<<1)+1].getRefIdx()<0) 3836 { 3837 assert(pcTextureCU->getVSPIndex(uiPartIdxCenter)!=0); 3838 for (Int i=0; i<getSlice()->getNumRefIdx(REF_PIC_LIST_1); i++) 3839 { 3840 if (getSlice()->getRefPOC(REF_PIC_LIST_1, i) == getSlice()->getPOC()) 3841 { 3842 pcMvFieldNeighbours[(iCount<<1)+1].setMvField(cMvPred,i); 3843 break; 3844 } 3845 } 3846 } 3847 #endif 3794 3848 } 3795 3849 } 3796 3850 #if MERL_VSP_C0152 3851 #if !MTK_LGE_VSP_DEPTH_OFF_D0105_D0139 3797 3852 xInheritVspMode( pcTextureCU, uiPartIdxCenter, bVspMvZeroDone, iCount, iVSPIndexTrue, pcMvFieldNeighbours, &cDisInfo ) ; 3798 3853 #endif 3799 if ( mrgCandIdx == iCount ) 3800 { 3801 return; 3802 } 3803 iCount ++; 3854 #endif 3855 #if MTK_LGE_VSP_DEPTH_OFF_D0105_D0139 3856 if (!((pcMvFieldNeighbours[iCount<<1].getRefIdx()<0 && !getSlice()->isInterB()) 3857 || (pcMvFieldNeighbours[iCount<<1].getRefIdx()<0 && pcMvFieldNeighbours[(iCount<<1)+1].getRefIdx()<0 && getSlice()->isInterB()))) 3858 { 3859 #endif 3860 if ( mrgCandIdx == iCount ) 3861 { 3862 return; 3863 } 3864 iCount ++; 3865 #if MTK_LGE_VSP_DEPTH_OFF_D0105_D0139 3866 } 3867 else 3868 { 3869 assert(0); 3870 } 3871 #endif 3804 3872 } 3805 3873 } … … 5043 5111 Int depthEndPosX = Clip3(0, iPictureWidth - 1, iBlkX + iBlkWidth - 1 + (mv->getHor()>>2)); 5044 5112 Int depthEndPosY = Clip3(0, iPictureHeight - 1, iBlkY + iBlkHeight - 1 + (mv->getVer()>>2)); 5113 #if !MTK_DEPTH_TO_DISP_D0138 5045 5114 Int iCenterX = (depthStartPosX + depthEndPosX) >> 1; 5046 5115 Int iCenterY = (depthStartPosY + depthEndPosY) >> 1; 5116 #endif 5047 5117 5048 5118 Pel *depthTL = pcBaseViewDepthPicYuv->getLumaAddr(); … … 5052 5122 aiDepth[2] = depthTL[ (depthStartPosY) * depStride + depthEndPosX ]; // Right Top 5053 5123 aiDepth[3] = depthTL[ (depthEndPosY) * depStride + depthEndPosX ]; // Right Bottom 5124 #if MTK_DEPTH_TO_DISP_D0138 5125 for (Int i = 0; i < 4; i++) 5126 #else 5054 5127 aiDepth[4] = depthTL[ (iCenterY) * depStride + iCenterX ]; // Center 5055 5128 for (Int i = 0; i < 5; i++) 5129 #endif 5056 5130 { 5057 5131 if (maxDepthVal < aiDepth[i])
Note: See TracChangeset for help on using the changeset viewer.