Skip to content
Snippets Groups Projects
SEI.cpp 8.71 KiB
Newer Older
  • Learn to ignore specific revisions
  • /* 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-2019, 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     SEI.cpp
        \brief    helper functions for SEI handling
    */
    
    #include "CommonDef.h"
    #include "SEI.h"
    
    #include "dtrace_next.h"
    
    #if ENABLE_TRACING
    void xTraceSEIHeader()
    {
      DTRACE( g_trace_ctx, D_HEADER, "=========== SEI message ===========\n" );
    }
    
    void xTraceSEIMessageType( SEI::PayloadType payloadType )
    {
      DTRACE( g_trace_ctx, D_HEADER, "=========== %s SEI message ===========\n", SEI::getSEIMessageString( payloadType ) );
    }
    #endif
    
    SEIMessages getSeisByType(SEIMessages &seiList, SEI::PayloadType seiType)
    {
      SEIMessages result;
    
      for (SEIMessages::iterator it=seiList.begin(); it!=seiList.end(); it++)
      {
        if ((*it)->payloadType() == seiType)
        {
          result.push_back(*it);
        }
      }
      return result;
    }
    
    SEIMessages extractSeisByType(SEIMessages &seiList, SEI::PayloadType seiType)
    {
      SEIMessages result;
    
      SEIMessages::iterator it=seiList.begin();
      while ( it!=seiList.end() )
      {
        if ((*it)->payloadType() == seiType)
        {
          result.push_back(*it);
          it = seiList.erase(it);
        }
        else
        {
          it++;
        }
      }
      return result;
    }
    
    
    void deleteSEIs (SEIMessages &seiList)
    {
      for (SEIMessages::iterator it=seiList.begin(); it!=seiList.end(); it++)
      {
        delete (*it);
      }
      seiList.clear();
    }
    
    
    void SEIBufferingPeriod::copyTo (SEIBufferingPeriod& target) const
    
      target.m_bpNalCpbParamsPresentFlag = m_bpNalCpbParamsPresentFlag;
      target.m_bpVclCpbParamsPresentFlag = m_bpVclCpbParamsPresentFlag;
      target.m_initialCpbRemovalDelayLength = m_initialCpbRemovalDelayLength;
      target.m_cpbRemovalDelayLength = m_cpbRemovalDelayLength;
      target.m_dpbOutputDelayLength = m_dpbOutputDelayLength;
    
      target.m_duCpbRemovalDelayIncrementLength = m_duCpbRemovalDelayIncrementLength;
      target.m_dpbOutputDelayDuLength = m_dpbOutputDelayDuLength;
    
      target.m_concatenationFlag = m_concatenationFlag;
      target.m_auCpbRemovalDelayDelta = m_auCpbRemovalDelayDelta;
    
      target.m_cpbRemovalDelayDeltasPresentFlag =  m_cpbRemovalDelayDeltasPresentFlag;
      target.m_numCpbRemovalDelayDeltas = m_numCpbRemovalDelayDeltas;
      target.m_bpMaxSubLayers = m_bpMaxSubLayers;
      ::memcpy(target.m_initialCpbRemovalDelay, m_initialCpbRemovalDelay, sizeof(m_initialCpbRemovalDelay));
      ::memcpy(target.m_initialCpbRemovalOffset, m_initialCpbRemovalOffset, sizeof(m_initialCpbRemovalOffset));
      ::memcpy(target.m_cpbRemovalDelayDelta, m_cpbRemovalDelayDelta, sizeof(m_cpbRemovalDelayDelta));
      ::memcpy(target.m_bpCpbCnt, m_bpCpbCnt, sizeof(m_bpCpbCnt));
    
    void SEIPictureTiming::copyTo (SEIPictureTiming& target) const
    
      ::memcpy(target.m_auCpbRemovalDelay, m_auCpbRemovalDelay, sizeof(m_auCpbRemovalDelay));
      ::memcpy(target.m_subLayerDelaysPresentFlag, m_subLayerDelaysPresentFlag, sizeof(m_subLayerDelaysPresentFlag));
      ::memcpy(target.m_cpbRemovalDelayDeltaEnabledFlag, m_cpbRemovalDelayDeltaEnabledFlag, sizeof(m_cpbRemovalDelayDeltaEnabledFlag));
      ::memcpy(target.m_cpbRemovalDelayDeltaIdx, m_cpbRemovalDelayDeltaIdx, sizeof(m_cpbRemovalDelayDeltaIdx));
      target.m_ptMaxSubLayers = m_ptMaxSubLayers;
    
      target.m_picDpbOutputDelay = m_picDpbOutputDelay;
      target.m_picDpbOutputDuDelay = m_picDpbOutputDuDelay;
      target.m_numDecodingUnitsMinus1 = m_numDecodingUnitsMinus1;
      target.m_duCommonCpbRemovalDelayFlag = m_duCommonCpbRemovalDelayFlag;
      target.m_duCommonCpbRemovalDelayMinus1 = m_duCommonCpbRemovalDelayMinus1;
    
      target.m_numNalusInDuMinus1 = m_numNalusInDuMinus1;
      target.m_duCpbRemovalDelayMinus1 = m_duCpbRemovalDelayMinus1;
    }
    
    // Static member
    const char *SEI::getSEIMessageString(SEI::PayloadType payloadType)
    {
      switch (payloadType)
      {
        case SEI::BUFFERING_PERIOD:                     return "Buffering period";
        case SEI::PICTURE_TIMING:                       return "Picture timing";
    
        case SEI::PAN_SCAN_RECT:                        return "Pan-scan rectangle";                   // not currently decoded
    
        case SEI::FILLER_PAYLOAD:                       return "Filler payload";                       // not currently decoded
    
        case SEI::USER_DATA_REGISTERED_ITU_T_T35:       return "User data registered";                 // not currently decoded
        case SEI::USER_DATA_UNREGISTERED:               return "User data unregistered";
        case SEI::RECOVERY_POINT:                       return "Recovery point";
        case SEI::SCENE_INFO:                           return "Scene information";                    // not currently decoded
        case SEI::FULL_FRAME_SNAPSHOT:                  return "Picture snapshot";                     // not currently decoded
        case SEI::PROGRESSIVE_REFINEMENT_SEGMENT_START: return "Progressive refinement segment start"; // not currently decoded
        case SEI::PROGRESSIVE_REFINEMENT_SEGMENT_END:   return "Progressive refinement segment end";   // not currently decoded
        case SEI::FILM_GRAIN_CHARACTERISTICS:           return "Film grain characteristics";           // not currently decoded
        case SEI::POST_FILTER_HINT:                     return "Post filter hint";                     // not currently decoded
        case SEI::TONE_MAPPING_INFO:                    return "Tone mapping information";
        case SEI::KNEE_FUNCTION_INFO:                   return "Knee function information";
        case SEI::FRAME_PACKING:                        return "Frame packing arrangement";
        case SEI::DISPLAY_ORIENTATION:                  return "Display orientation";
        case SEI::GREEN_METADATA:                       return "Green metadata information";
        case SEI::SOP_DESCRIPTION:                      return "Structure of pictures information";
        case SEI::ACTIVE_PARAMETER_SETS:                return "Active parameter sets";
    
        case SEI::DECODING_UNIT_INFO:                   return "Decoding unit information";
    
        case SEI::TEMPORAL_LEVEL0_INDEX:                return "Temporal sub-layer zero index";
    
        case SEI::DECODED_PICTURE_HASH:                 return "Decoded picture hash";
    
        case SEI::DEPENDENT_RAP_INDICATION:             return "Dependent RAP indication";
    
        case SEI::SCALABLE_NESTING:                     return "Scalable nesting";
        case SEI::REGION_REFRESH_INFO:                  return "Region refresh information";
        case SEI::NO_DISPLAY:                           return "No display";
        case SEI::TIME_CODE:                            return "Time code";
        case SEI::MASTERING_DISPLAY_COLOUR_VOLUME:      return "Mastering display colour volume";
        case SEI::SEGM_RECT_FRAME_PACKING:              return "Segmented rectangular frame packing arrangement";
        case SEI::TEMP_MOTION_CONSTRAINED_TILE_SETS:    return "Temporal motion constrained tile sets";
        case SEI::CHROMA_RESAMPLING_FILTER_HINT:        return "Chroma sampling filter hint";
        case SEI::COLOUR_REMAPPING_INFO:                return "Colour remapping info";
    #if U0033_ALTERNATIVE_TRANSFER_CHARACTERISTICS_SEI
        case SEI::ALTERNATIVE_TRANSFER_CHARACTERISTICS: return "Alternative transfer characteristics";