Skip to content
Snippets Groups Projects
EncAppCfg.cpp 263 KiB
Newer Older
  • Learn to ignore specific revisions
  •   msg( VERBOSE, "WPP:%d ", (int)m_useWeightedPred);
      msg( VERBOSE, "WPB:%d ", (int)m_useWeightedBiPred);
    
    #if JVET_Q0297_MER
      msg( VERBOSE, "PME:%d ", m_log2ParallelMergeLevel);
    #endif
    
      const int iWaveFrontSubstreams = m_entropyCodingSyncEnabledFlag ? (m_iSourceHeight + m_uiMaxCUHeight - 1) / m_uiMaxCUHeight : 1;
      msg( VERBOSE, " WaveFrontSynchro:%d WaveFrontSubstreams:%d", m_entropyCodingSyncEnabledFlag?1:0, iWaveFrontSubstreams);
      msg( VERBOSE, " ScalingList:%d ", m_useScalingListId );
    
      msg( VERBOSE, "TMVPMode:%d ", m_TMVPModeId );
    
      msg( VERBOSE, " DQ:%d ", m_depQuantEnabledFlag);
      msg( VERBOSE, " SignBitHidingFlag:%d ", m_signDataHidingEnabledFlag);
      msg( VERBOSE, "RecalQP:%d ", m_recalculateQPAccordingToLambda ? 1 : 0 );
    
      {
    
        msg( VERBOSE, "\nTOOL CFG: " );
    
        msg( VERBOSE, "LFNST:%d ", m_LFNST );
    
    Seungsoo Jeong's avatar
    Seungsoo Jeong committed
        msg( VERBOSE, "MMVD:%d ", m_MMVD);
    
        msg( VERBOSE, "Affine:%d ", m_Affine );
        if ( m_Affine )
        {
          msg( VERBOSE, "AffineType:%d ", m_AffineType );
        }
    
        msg(VERBOSE, "SubPuMvp:%d+%d ", m_SubPuMvpMode & 1, (m_SubPuMvpMode & 2) == 2);
    
    Karsten Suehring's avatar
    Karsten Suehring committed
        msg( VERBOSE, "DualITree:%d ", m_dualTree );
    
        msg( VERBOSE, "BIO:%d ", m_BIO );
    
        msg( VERBOSE, "HorCollocatedChroma:%d ", m_horCollocatedChromaFlag );
        msg( VERBOSE, "VerCollocatedChroma:%d ", m_verCollocatedChromaFlag );
    
    Tung Nguyen's avatar
    Tung Nguyen committed
        msg( VERBOSE, "MTS: %1d(intra) %1d(inter) ", m_MTS & 1, ( m_MTS >> 1 ) & 1 );
    
        msg( VERBOSE, "SBT:%d ", m_SBT );
    
        msg( VERBOSE, "ISP:%d ", m_ISP );
    
        msg( VERBOSE, "SMVD:%d ", m_SMVD );
    
    Tung Nguyen's avatar
    Tung Nguyen committed
        msg( VERBOSE, "CompositeLTReference:%d ", m_compositeRefEnabled);
    
        msg( VERBOSE, "Bcw:%d ", m_bcw );
        msg( VERBOSE, "BcwFast:%d ", m_BcwFast );
    
    #if LUMA_ADAPTIVE_DEBLOCKING_FILTER_QP_OFFSET
        msg( VERBOSE, "LADF:%d ", m_LadfEnabed );
    
        msg(VERBOSE, "CIIP:%d ", m_ciip);
    
        msg( VERBOSE, "Triangle:%d ", m_Triangle );
    
    #else
        msg( VERBOSE, "Geo:%d ", m_Geo );
    #endif
    
    Seungsoo Jeong's avatar
    Seungsoo Jeong committed
        m_allowDisFracMMVD = m_MMVD ? m_allowDisFracMMVD : false;
        if ( m_MMVD )
          msg(VERBOSE, "AllowDisFracMMVD:%d ", m_allowDisFracMMVD);
    
        msg( VERBOSE, "AffineAmvr:%d ", m_AffineAmvr );
    
        m_AffineAmvrEncOpt = m_AffineAmvr ? m_AffineAmvrEncOpt : false;
        msg( VERBOSE, "AffineAmvrEncOpt:%d ", m_AffineAmvrEncOpt );
    
        msg(VERBOSE, "DMVR:%d ", m_DMVR);
    
        msg(VERBOSE, "MmvdDisNum:%d ", m_MmvdDisNum);
    
        msg(VERBOSE, "JointCbCr:%d ", m_JointCbCrMode);
    
    #if JVET_Q0820_ACT
      m_useColorTrans = (m_chromaFormatIDC == CHROMA_444) ? m_useColorTrans : 0u;
    #else
    
      m_useColorTrans = (m_chromaFormatIDC == CHROMA_444 && m_costMode != COST_LOSSLESS_CODING) ? m_useColorTrans : 0u;
    
      msg(VERBOSE, "ACT:%d ", m_useColorTrans);
    
    #if !JVET_Q0504_PLT_NON444
    
        m_PLTMode = ( m_chromaFormatIDC == CHROMA_444) ? m_PLTMode : 0u;
    
    Yu Han's avatar
    Yu Han committed
        msg(VERBOSE, "IBC:%d ", m_IBCMode);
    
      msg( VERBOSE, "HashME:%d ", m_HashME );
    
      msg( VERBOSE, "WrapAround:%d ", m_wrapAround);
      if( m_wrapAround )
    
    Philippe Hanhart's avatar
    Philippe Hanhart committed
      {
    
        msg( VERBOSE, "WrapAroundOffset:%d ", m_wrapAroundOffset );
    
    Philippe Hanhart's avatar
    Philippe Hanhart committed
      }
    
      // ADD_NEW_TOOL (add some output indicating the usage of tools)
    
    #if JVET_Q0246_VIRTUAL_BOUNDARY_ENABLE_FLAG 
      msg( VERBOSE, "VirtualBoundariesEnabledFlag:%d ", m_virtualBoundariesEnabledFlag );
      msg( VERBOSE, "VirtualBoundariesPresentInSPSFlag:%d ", m_virtualBoundariesPresentFlag );
      if( m_virtualBoundariesPresentFlag )
      {
    #else
    
      msg(VERBOSE, "LoopFilterAcrossVirtualBoundaries:%d ", m_loopFilterAcrossVirtualBoundariesDisabledFlag);
      if ( m_loopFilterAcrossVirtualBoundariesDisabledFlag )
      {
    
        msg(VERBOSE, "vertical virtual boundaries:[");
        for (unsigned i = 0; i < m_numVerVirtualBoundaries; i++)
        {
          msg(VERBOSE, " %d", m_virtualBoundariesPosX[i]);
        }
        msg(VERBOSE, " ] horizontal virtual boundaries:[");
        for (unsigned i = 0; i < m_numHorVirtualBoundaries; i++)
        {
          msg(VERBOSE, " %d", m_virtualBoundariesPosY[i]);
        }
        msg(VERBOSE, " ] ");
      }
    
        msg(VERBOSE, "Reshape:%d ", m_lmcsEnabled);
        if (m_lmcsEnabled)
    
          msg(VERBOSE, "(Signal:%s ", m_reshapeSignalType == 0 ? "SDR" : (m_reshapeSignalType == 2 ? "HDR-HLG" : "HDR-PQ"));
          msg(VERBOSE, "Opt:%d", m_adpOption);
          if (m_adpOption > 0) { msg(VERBOSE, " CW:%d", m_initialCW); }
    
          msg(VERBOSE, " CSoffset:%d", m_CSoffset);
    
    Taoran Lu's avatar
    Taoran Lu committed
          msg(VERBOSE, ") ");
        }
    
        msg(VERBOSE, "MRL:%d ", m_MRL);
    
        msg(VERBOSE, "MIP:%d ", m_MIP);
    
    Nan Hu's avatar
    Nan Hu committed
        msg(VERBOSE, "EncDbOpt:%d ", m_encDbOpt);
    
      msg( VERBOSE, "LCTUFast:%d ", m_useFastLCTU );
    
      msg( VERBOSE, "FastMrg:%d ", m_useFastMrg );
      msg( VERBOSE, "PBIntraFast:%d ", m_usePbIntraFast );
    
      if( m_ImvMode ) msg( VERBOSE, "IMV4PelFast:%d ", m_Imv4PelFast );
    
    Tung Nguyen's avatar
    Tung Nguyen committed
      if( m_MTS ) msg( VERBOSE, "MTSMaxCand: %1d(intra) %1d(inter) ", m_MTSIntraMaxCand, m_MTSInterMaxCand );
    
      if( m_ISP ) msg( VERBOSE, "ISPFast:%d ", m_useFastISP );
    
      if( m_LFNST ) msg( VERBOSE, "FastLFNST:%d ", m_useFastLFNST );
    
    Karsten Suehring's avatar
    Karsten Suehring committed
      msg( VERBOSE, "AMaxBT:%d ", m_useAMaxBT );
      msg( VERBOSE, "E0023FastEnc:%d ", m_e0023FastEnc );
      msg( VERBOSE, "ContentBasedFastQtbt:%d ", m_contentBasedFastQtbt );
    
      msg( VERBOSE, "UseNonLinearAlfLuma:%d ", m_useNonLinearAlfLuma );
      msg( VERBOSE, "UseNonLinearAlfChroma:%d ", m_useNonLinearAlfChroma );
      msg( VERBOSE, "MaxNumAlfAlternativesChroma:%d ", m_maxNumAlfAlternativesChroma );
    
      if( m_MIP ) msg(VERBOSE, "FastMIP:%d ", m_useFastMIP);
    
      msg( VERBOSE, "FastLocalDualTree:%d ", m_fastLocalDualTreeMode );
    
    
      msg( VERBOSE, "NumSplitThreads:%d ", m_numSplitThreads );
      if( m_numSplitThreads > 1 )
      {
        msg( VERBOSE, "ForceSingleSplitThread:%d ", m_forceSplitSequential );
      }
      msg( VERBOSE, "NumWppThreads:%d+%d ", m_numWppThreads, m_numWppExtraLines );
      msg( VERBOSE, "EnsureWppBitEqual:%d ", m_ensureWppBitEqual );
    
    
        msg( VERBOSE, "RPR:(%1.2lfx, %1.2lfx)|%d ", m_scalingRatioHor, m_scalingRatioVer, m_switchPocPeriod );
    
      msg(VERBOSE, "TemporalFilter:%d ", m_gopBasedTemporalFilterEnabled);
    
    #if EXTENSION_360_VIDEO
      m_ext360.outputConfigurationSummary();
    #endif
    
    
    bool EncAppCfg::xHasNonZeroTemporalID ()
    {
      for (unsigned int i = 0; i < m_iGOPSize; i++)
      {
        if ( m_GOPList[i].m_temporalId != 0 )
        {
          return true;
        }
      }
      return false;
    }
    
    bool EncAppCfg::xHasLeadingPicture ()
    {
      for (unsigned int i = 0; i < m_iGOPSize; i++)
      {
        for ( unsigned int j = 0; j < m_GOPList[i].m_numRefPics0; j++)
        {
          if ( m_GOPList[i].m_deltaRefPics0[j] < 0 )
          {
            return true;
          }
        }
        for ( unsigned int j = 0; j < m_GOPList[i].m_numRefPics1; j++)
        {
          if ( m_GOPList[i].m_deltaRefPics1[j] < 0 )
          {
            return true;
          }
        }
      }
      return false;
    }
    
    
    
    bool confirmPara(bool bflag, const char* message)
    {
      if (!bflag)
      {
        return false;
      }
    
      msg( ERROR, "Error: %s\n",message);
      return true;
    }