Changeset 608 in 3DVCSoftware for trunk/source/Lib/TLibEncoder/TEncSampleAdaptiveOffset.h
- Timestamp:
- 1 Sep 2013, 22:47:26 (12 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/source/Lib/TLibEncoder/TEncSampleAdaptiveOffset.h
r443 r608 4 4 * granted under this license. 5 5 * 6 * Copyright (c) 2010-201 2, ITU/ISO/IEC6 * Copyright (c) 2010-2013, ITU/ISO/IEC 7 7 * All rights reserved. 8 8 * … … 32 32 */ 33 33 34 /** \file TEncAdaptiveLoopFilter.h 34 /** 35 \file TEncSampleAdaptiveOffset.h 35 36 \brief estimation part of sample adaptive offset class (header) 36 37 */ … … 56 57 { 57 58 private: 58 Double m_dLambdaLuma;59 Double m_dLambdaChroma;60 61 59 TEncEntropy* m_pcEntropyCoder; 62 60 TEncSbac*** m_pppcRDSbacCoder; ///< for CABAC … … 71 69 Int64 ***m_iOffset; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE][MAX_NUM_SAO_CLASS]; 72 70 Int64 ***m_iOffsetOrg; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE]; 73 #if LGE_SAO_MIGRATION_D009174 71 Int64 ****m_count_PreDblk; //[LCU][YCbCr][MAX_NUM_SAO_TYPE][MAX_NUM_SAO_CLASS]; 75 72 Int64 ****m_offsetOrg_PreDblk; //[LCU][YCbCr][MAX_NUM_SAO_TYPE][MAX_NUM_SAO_CLASS]; 76 #endif77 73 Int64 **m_iRate; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE]; 78 74 Int64 **m_iDist; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE]; … … 81 77 Int64 *m_iDistOrg; //[MAX_NUM_SAO_PART]; 82 78 Int *m_iTypePartBest; //[MAX_NUM_SAO_PART]; 83 Int m_iOffsetTh; 79 Int m_iOffsetThY; 80 Int m_iOffsetThC; 84 81 Bool m_bUseSBACRD; 85 82 #if SAO_ENCODING_CHOICE … … 108 105 #endif 109 106 110 #if LGE_SAO_MIGRATION_D0091111 107 Void runQuadTreeDecision(SAOQTPart *psQTPart, Int iPartIdx, Double &dCostFinal, Int iMaxLevel, Double dLambda, Int yCbCr); 112 108 Void rdoSaoOnePart(SAOQTPart *psQTPart, Int iPartIdx, Double dLambda, Int yCbCr); 113 #else114 Void runQuadTreeDecision(SAOQTPart *psQTPart, Int iPartIdx, Double &dCostFinal, Int iMaxLevel, Double dLambda);115 Void rdoSaoOnePart(SAOQTPart *psQTPart, Int iPartIdx, Double dLambda);116 #endif117 109 118 110 Void disablePartTree(SAOQTPart *psQTPart, Int iPartIdx); 119 111 Void getSaoStats(SAOQTPart *psQTPart, Int iYCbCr); 120 112 Void calcSaoStatsCu(Int iAddr, Int iPartIdx, Int iYCbCr); 121 Void calcSaoStatsBlock( Pel* pRecStart, Pel* pOrgStart, Int stride, Int64** ppStats, Int64** ppCount, UInt width, UInt height, Bool* pbBorderAvail );113 Void calcSaoStatsBlock( Pel* pRecStart, Pel* pOrgStart, Int stride, Int64** ppStats, Int64** ppCount, UInt width, UInt height, Bool* pbBorderAvail, Int iYCbCr); 122 114 Void calcSaoStatsCuOrg(Int iAddr, Int iPartIdx, Int iYCbCr); 123 #if LGE_SAO_MIGRATION_D0091124 115 Void calcSaoStatsCu_BeforeDblk( TComPic* pcPic ); 125 #endif126 116 Void destroyEncBuffer(); 127 117 Void createEncBuffer(); … … 133 123 Void rdoSaoUnitAll(SAOParam *saoParam, Double lambda, Double lambdaChroma); 134 124 #endif 135 #if LGE_SAO_MIGRATION_D0091136 125 Void saoComponentParamDist(Int allowMergeLeft, Int allowMergeUp, SAOParam *saoParam, Int addr, Int addrUp, Int addrLeft, Int yCbCr, Double lambda, SaoLcuParam *compSaoParam, Double *distortion); 137 126 Void sao2ChromaParamDist(Int allowMergeLeft, Int allowMergeUp, SAOParam *saoParam, Int addr, Int addrUp, Int addrLeft, Double lambda, SaoLcuParam *crSaoParam, SaoLcuParam *cbSaoParam, Double *distortion); 138 127 inline Int64 estSaoDist(Int64 count, Int64 offset, Int64 offsetOrg, Int shift); 139 inline Int64 estIterOffset(Int typeIdx, Int classIdx, double lambda, Int64 offsetInput, Int64 count, Int64 offsetOrg, Int shift, Int bitIncrease, Int *currentDistortionTableBo, Double *currentRdCostTableBo);128 inline Int64 estIterOffset(Int typeIdx, Int classIdx, Double lambda, Int64 offsetInput, Int64 count, Int64 offsetOrg, Int shift, Int bitIncrease, Int *currentDistortionTableBo, Double *currentRdCostTableBo, Int offsetTh ); 140 129 inline Int64 estSaoTypeDist(Int compIdx, Int typeIdx, Int shift, Double lambda, Int *currentDistortionTableBo, Double *currentRdCostTableBo); 141 #else142 Void rdoSaoUnit(SAOParam *saoParam, Int addr, Int addrUp, Int addrLeft, Int yCbCr, Double lambda);143 #endif144 130 Void setMaxNumOffsetsPerPic(Int iVal) {m_maxNumOffsetsPerPic = iVal; } 145 131 Int getMaxNumOffsetsPerPic() {return m_maxNumOffsetsPerPic; }
Note: See TracChangeset for help on using the changeset viewer.