/* The copyright in this software is being made available under the BSD * License, included below. This software may be subject to other third party * and contributor rights, including patent rights, and no such rights are * granted under this license. * * Copyright (c) 2010-2012, ITU/ISO/IEC * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * * Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * Neither the name of the ITU/ISO/IEC nor the names of its contributors may * be used to endorse or promote products derived from this software without * specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. */ /** \file TEncAdaptiveLoopFilter.h \brief estimation part of sample adaptive offset class (header) */ #ifndef __TENCSAMPLEADAPTIVEOFFSET__ #define __TENCSAMPLEADAPTIVEOFFSET__ #include "TLibCommon/TComSampleAdaptiveOffset.h" #include "TLibCommon/TComPic.h" #include "TEncEntropy.h" #include "TEncSbac.h" #include "TLibCommon/TComBitCounter.h" //! \ingroup TLibEncoder //! \{ // ==================================================================================================================== // Class definition // ==================================================================================================================== class TEncSampleAdaptiveOffset : public TComSampleAdaptiveOffset { private: Double m_dLambdaLuma; Double m_dLambdaChroma; TEncEntropy* m_pcEntropyCoder; TEncSbac*** m_pppcRDSbacCoder; ///< for CABAC TEncSbac* m_pcRDGoOnSbacCoder; #if FAST_BIT_EST TEncBinCABACCounter*** m_pppcBinCoderCABAC; ///< temporal CABAC state storage for RD computation #else TEncBinCABAC*** m_pppcBinCoderCABAC; ///< temporal CABAC state storage for RD computation #endif Int64 ***m_iCount; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE][MAX_NUM_SAO_CLASS]; Int64 ***m_iOffset; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE][MAX_NUM_SAO_CLASS]; Int64 ***m_iOffsetOrg; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE]; #if LGE_SAO_MIGRATION_D0091 Int64 ****m_count_PreDblk; //[LCU][YCbCr][MAX_NUM_SAO_TYPE][MAX_NUM_SAO_CLASS]; Int64 ****m_offsetOrg_PreDblk; //[LCU][YCbCr][MAX_NUM_SAO_TYPE][MAX_NUM_SAO_CLASS]; #endif Int64 **m_iRate; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE]; Int64 **m_iDist; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE]; Double **m_dCost; //[MAX_NUM_SAO_PART][MAX_NUM_SAO_TYPE]; Double *m_dCostPartBest; //[MAX_NUM_SAO_PART]; Int64 *m_iDistOrg; //[MAX_NUM_SAO_PART]; Int *m_iTypePartBest; //[MAX_NUM_SAO_PART]; Int m_iOffsetTh; Bool m_bUseSBACRD; #if SAO_ENCODING_CHOICE #if SAO_ENCODING_CHOICE_CHROMA Double m_depthSaoRate[2][4]; #else Double m_depth0SaoRate; #endif #endif public: TEncSampleAdaptiveOffset (); virtual ~TEncSampleAdaptiveOffset(); Void startSaoEnc( TComPic* pcPic, TEncEntropy* pcEntropyCoder, TEncSbac*** pppcRDSbacCoder, TEncSbac* pcRDGoOnSbacCoder); Void endSaoEnc(); Void resetStats(); #if SAO_CHROMA_LAMBDA #if SAO_ENCODING_CHOICE Void SAOProcess(SAOParam *pcSaoParam, Double dLambda, Double dLambdaChroma, Int depth); #else Void SAOProcess(SAOParam *pcSaoParam, Double dLambda, Double dLambdaChroma); #endif #else Void SAOProcess(SAOParam *pcSaoParam, Double dLambda); #endif #if LGE_SAO_MIGRATION_D0091 Void runQuadTreeDecision(SAOQTPart *psQTPart, Int iPartIdx, Double &dCostFinal, Int iMaxLevel, Double dLambda, Int yCbCr); Void rdoSaoOnePart(SAOQTPart *psQTPart, Int iPartIdx, Double dLambda, Int yCbCr); #else Void runQuadTreeDecision(SAOQTPart *psQTPart, Int iPartIdx, Double &dCostFinal, Int iMaxLevel, Double dLambda); Void rdoSaoOnePart(SAOQTPart *psQTPart, Int iPartIdx, Double dLambda); #endif Void disablePartTree(SAOQTPart *psQTPart, Int iPartIdx); Void getSaoStats(SAOQTPart *psQTPart, Int iYCbCr); Void calcSaoStatsCu(Int iAddr, Int iPartIdx, Int iYCbCr); Void calcSaoStatsBlock( Pel* pRecStart, Pel* pOrgStart, Int stride, Int64** ppStats, Int64** ppCount, UInt width, UInt height, Bool* pbBorderAvail); Void calcSaoStatsCuOrg(Int iAddr, Int iPartIdx, Int iYCbCr); #if LGE_SAO_MIGRATION_D0091 Void calcSaoStatsCu_BeforeDblk( TComPic* pcPic ); #endif Void destroyEncBuffer(); Void createEncBuffer(); Void assignSaoUnitSyntax(SaoLcuParam* saoLcuParam, SAOQTPart* saoPart, Bool &oneUnitFlag, Int yCbCr); Void checkMerge(SaoLcuParam * lcuParamCurr,SaoLcuParam * lcuParamCheck, Int dir); #if SAO_ENCODING_CHOICE Void rdoSaoUnitAll(SAOParam *saoParam, Double lambda, Double lambdaChroma, Int depth); #else Void rdoSaoUnitAll(SAOParam *saoParam, Double lambda, Double lambdaChroma); #endif #if LGE_SAO_MIGRATION_D0091 Void saoComponentParamDist(Int allowMergeLeft, Int allowMergeUp, SAOParam *saoParam, Int addr, Int addrUp, Int addrLeft, Int yCbCr, Double lambda, SaoLcuParam *compSaoParam, Double *distortion); Void sao2ChromaParamDist(Int allowMergeLeft, Int allowMergeUp, SAOParam *saoParam, Int addr, Int addrUp, Int addrLeft, Double lambda, SaoLcuParam *crSaoParam, SaoLcuParam *cbSaoParam, Double *distortion); inline Int64 estSaoDist(Int64 count, Int64 offset, Int64 offsetOrg, Int shift); inline Int64 estIterOffset(Int typeIdx, Int classIdx, double lambda, Int64 offsetInput, Int64 count, Int64 offsetOrg, Int shift, Int bitIncrease, Int *currentDistortionTableBo, Double *currentRdCostTableBo ); inline Int64 estSaoTypeDist(Int compIdx, Int typeIdx, Int shift, Double lambda, Int *currentDistortionTableBo, Double *currentRdCostTableBo); #else Void rdoSaoUnit(SAOParam *saoParam, Int addr, Int addrUp, Int addrLeft, Int yCbCr, Double lambda); #endif Void setMaxNumOffsetsPerPic(Int iVal) {m_maxNumOffsetsPerPic = iVal; } Int getMaxNumOffsetsPerPic() {return m_maxNumOffsetsPerPic; } }; //! \} #endif