/*! * \copy * Copyright (c) 2013, Cisco Systems * 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. * * 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. * */ #ifndef WELS_VIDEO_CODEC_APPLICATION_DEFINITION_H__ #define WELS_VIDEO_CODEC_APPLICATION_DEFINITION_H__ /** * @file codec_app_def.h * @brief Data and /or structures introduced in Cisco OpenH264 application */ #include "codec_def.h" /* Constants */ #define MAX_TEMPORAL_LAYER_NUM 4 #define MAX_SPATIAL_LAYER_NUM 4 #define MAX_QUALITY_LAYER_NUM 4 #define MAX_LAYER_NUM_OF_FRAME 128 #define MAX_NAL_UNITS_IN_LAYER 128 ///< predetermined here, adjust it later if need #define MAX_RTP_PAYLOAD_LEN 1000 #define AVERAGE_RTP_PAYLOAD_LEN 800 #define SAVED_NALUNIT_NUM_TMP ( (MAX_SPATIAL_LAYER_NUM*MAX_QUALITY_LAYER_NUM) + 1 + MAX_SPATIAL_LAYER_NUM ) ///< SPS/PPS + SEI/SSEI + PADDING_NAL #define MAX_SLICES_NUM_TMP ( ( MAX_NAL_UNITS_IN_LAYER - SAVED_NALUNIT_NUM_TMP ) / 3 ) #define AUTO_REF_PIC_COUNT -1 ///< encoder selects the number of reference frame automatically #define UNSPECIFIED_BIT_RATE 0 ///< to do: add detail comment /** * @brief Struct of OpenH264 version */ /// /// E.g. SDK version is 1.2.0.0, major version number is 1, minor version number is 2, and revision number is 0. typedef struct _tagVersion { unsigned int uMajor; ///< The major version number unsigned int uMinor; ///< The minor version number unsigned int uRevision; ///< The revision number unsigned int uReserved; ///< The reserved number, it should be 0. } OpenH264Version; /** * @brief Decoding status */ typedef enum { /** * Errors derived from bitstream parsing */ dsErrorFree = 0x00, ///< bit stream error-free dsFramePending = 0x01, ///< need more throughput to generate a frame output, dsRefLost = 0x02, ///< layer lost at reference frame with temporal id 0 dsBitstreamError = 0x04, ///< error bitstreams(maybe broken internal frame) the decoder cared dsDepLayerLost = 0x08, ///< dependented layer is ever lost dsNoParamSets = 0x10, ///< no parameter set NALs involved dsDataErrorConcealed = 0x20, ///< current data error concealed specified /** * Errors derived from logic level */ dsInvalidArgument = 0x1000, ///< invalid argument specified dsInitialOptExpected = 0x2000, ///< initializing operation is expected dsOutOfMemory = 0x4000, ///< out of memory due to new request /** * ANY OTHERS? */ dsDstBufNeedExpan = 0x8000 ///< actual picture size exceeds size of dst pBuffer feed in decoder, so need expand its size } DECODING_STATE; /** * @brief Option types introduced in SVC encoder application */ typedef enum { ENCODER_OPTION_DATAFORMAT = 0, ENCODER_OPTION_IDR_INTERVAL, ///< IDR period,0/-1 means no Intra period (only the first frame); lager than 0 means the desired IDR period, must be multiple of (2^temporal_layer) ENCODER_OPTION_SVC_ENCODE_PARAM_BASE, ///< structure of Base Param ENCODER_OPTION_SVC_ENCODE_PARAM_EXT, ///< structure of Extension Param ENCODER_OPTION_FRAME_RATE, ///< maximal input frame rate, current supported range: MAX_FRAME_RATE = 30,MIN_FRAME_RATE = 1 ENCODER_OPTION_BITRATE, ENCODER_OPTION_MAX_BITRATE, ENCODER_OPTION_INTER_SPATIAL_PRED, ENCODER_OPTION_RC_MODE, ENCODER_OPTION_RC_FRAME_SKIP, ENCODER_PADDING_PADDING, ///< 0:disable padding;1:padding ENCODER_OPTION_PROFILE, ///< assgin the profile for each layer ENCODER_OPTION_LEVEL, ///< assgin the level for each layer ENCODER_OPTION_NUMBER_REF, ///< the number of refererence frame ENCODER_OPTION_DELIVERY_STATUS, ///< the delivery info which is a feedback from app level ENCODER_LTR_RECOVERY_REQUEST, ENCODER_LTR_MARKING_FEEDBACK, ENCODER_LTR_MARKING_PERIOD, ENCODER_OPTION_LTR, ///< 0:disable LTR;larger than 0 enable LTR; LTR number is fixed to be 2 in current encoder ENCODER_OPTION_COMPLEXITY, ENCODER_OPTION_ENABLE_SSEI, ///< enable SSEI: true--enable ssei; false--disable ssei ENCODER_OPTION_ENABLE_PREFIX_NAL_ADDING, ///< enable prefix: true--enable prefix; false--disable prefix ENCODER_OPTION_ENABLE_SPS_PPS_ID_ADDITION, ///< enable pSps/pPps id addition: true--enable pSps/pPps id; false--disable pSps/pPps id addistion ENCODER_OPTION_CURRENT_PATH, ENCODER_OPTION_DUMP_FILE, ///< dump layer reconstruct frame to a specified file ENCODER_OPTION_TRACE_LEVEL, ///< trace info based on the trace level ENCODER_OPTION_TRACE_CALLBACK, ///< a void (*)(void* context, int level, const char* message) function which receives log messages ENCODER_OPTION_TRACE_CALLBACK_CONTEXT, ///< context info of trace callback ENCODER_OPTION_GET_STATISTICS, ///< read only ENCODER_OPTION_STATISTICS_LOG_INTERVAL, ///< log interval in millisecond ENCODER_OPTION_IS_LOSSLESS_LINK, ///< advanced algorithmetic settings ENCODER_OPTION_BITS_VARY_PERCENTAGE ///< bit vary percentage } ENCODER_OPTION; /** * @brief Option types introduced in decoder application */ typedef enum { DECODER_OPTION_DATAFORMAT = 0, ///< color format, now supports 23 only (I420) DECODER_OPTION_END_OF_STREAM, ///< end of stream flag DECODER_OPTION_VCL_NAL, ///< feedback whether or not have VCL NAL in current AU for application layer DECODER_OPTION_TEMPORAL_ID, ///< feedback temporal id for application layer DECODER_OPTION_FRAME_NUM, ///< feedback current decoded frame number DECODER_OPTION_IDR_PIC_ID, ///< feedback current frame belong to which IDR period DECODER_OPTION_LTR_MARKING_FLAG, ///< feedback wether current frame mark a LTR DECODER_OPTION_LTR_MARKED_FRAME_NUM, ///< feedback frame num marked by current Frame DECODER_OPTION_ERROR_CON_IDC, ///< not finished yet, indicate decoder error concealment status, in progress DECODER_OPTION_TRACE_LEVEL, DECODER_OPTION_TRACE_CALLBACK, ///< a void (*)(void* context, int level, const char* message) function which receives log messages DECODER_OPTION_TRACE_CALLBACK_CONTEXT,///< context info of trace callbac DECODER_OPTION_GET_STATISTICS } DECODER_OPTION; /** * @brief Enumerate the type of error concealment methods */ typedef enum { ERROR_CON_DISABLE = 0, ERROR_CON_FRAME_COPY, ERROR_CON_SLICE_COPY, ERROR_CON_FRAME_COPY_CROSS_IDR, ERROR_CON_SLICE_COPY_CROSS_IDR, ERROR_CON_SLICE_COPY_CROSS_IDR_FREEZE_RES_CHANGE, ERROR_CON_SLICE_MV_COPY_CROSS_IDR, ERROR_CON_SLICE_MV_COPY_CROSS_IDR_FREEZE_RES_CHANGE } ERROR_CON_IDC; /** * @brief Feedback that whether or not have VCL NAL in current AU */ typedef enum { FEEDBACK_NON_VCL_NAL = 0, FEEDBACK_VCL_NAL, FEEDBACK_UNKNOWN_NAL } FEEDBACK_VCL_NAL_IN_AU; /** * @brief Type of layer being encoded */ typedef enum { NON_VIDEO_CODING_LAYER = 0, VIDEO_CODING_LAYER = 1 } LAYER_TYPE; /** * @brief Spatial layer num */ typedef enum { SPATIAL_LAYER_0 = 0, SPATIAL_LAYER_1 = 1, SPATIAL_LAYER_2 = 2, SPATIAL_LAYER_3 = 3, SPATIAL_LAYER_ALL = 4 } LAYER_NUM; /** * @brief Enumerate the type of video bitstream which is provided to decoder */ typedef enum { VIDEO_BITSTREAM_AVC = 0, VIDEO_BITSTREAM_SVC = 1, VIDEO_BITSTREAM_DEFAULT = VIDEO_BITSTREAM_SVC } VIDEO_BITSTREAM_TYPE; /** * @brief Enumerate the type of key frame request */ typedef enum { NO_RECOVERY_REQUSET = 0, LTR_RECOVERY_REQUEST = 1, IDR_RECOVERY_REQUEST = 2, NO_LTR_MARKING_FEEDBACK = 3, LTR_MARKING_SUCCESS = 4, LTR_MARKING_FAILED = 5 } KEY_FRAME_REQUEST_TYPE; /** * @brief Structure for LTR recover request */ typedef struct { unsigned int uiFeedbackType; ///< IDR request or LTR recovery request unsigned int uiIDRPicId; ///< distinguish request from different IDR int iLastCorrectFrameNum; int iCurrentFrameNum; ///< specify current decoder frame_num. } SLTRRecoverRequest; /** * @brief Structure for LTR marking feedback */ typedef struct { unsigned int uiFeedbackType; ///< mark failed or successful unsigned int uiIDRPicId; ///< distinguish request from different IDR int iLTRFrameNum; ///< specify current decoder frame_num } SLTRMarkingFeedback; /** * @brief Structure for LTR configuration */ typedef struct { bool bEnableLongTermReference; ///< 1: on, 0: off int iLTRRefNum; ///< TODO: not supported to set it arbitrary yet } SLTRConfig; /** * @brief Structure for slice argument */ typedef struct { unsigned int uiSliceMbNum[MAX_SLICES_NUM_TMP]; ///< only used when uiSliceMode=2;here we use a tmp fixed value since MAX_SLICES_NUM is not defined here and its definition may be changed; unsigned int uiSliceNum; ///< only used when uiSliceMode=1 unsigned int uiSliceSizeConstraint; ///< only used when uiSliceMode=4 } SSliceArgument; ///< not all the elements in this argument will be used, how it will be used depends on uiSliceMode; please refer to SliceModeEnum /** * @brief Enumerate the type of slice mode */ typedef enum { SM_SINGLE_SLICE = 0, ///< | SliceNum==1 SM_FIXEDSLCNUM_SLICE = 1, ///< | according to SliceNum | enabled dynamic slicing for multi-thread SM_RASTER_SLICE = 2, ///< | according to SlicesAssign | need input of MB numbers each slice. In addition, if other constraint in SSliceArgument is presented, need to follow the constraints. Typically if MB num and slice size are both constrained, re-encoding may be involved. SM_ROWMB_SLICE = 3, ///< | according to PictureMBHeight | typical of single row of mbs each slice + slice size constraint which including re-encoding SM_DYN_SLICE = 4, ///< | according to SliceSize | dynamic slicing (have no idea about slice_nums until encoding current frame) SM_AUTO_SLICE = 5, ///< | according to thread number SM_RESERVED = 6 } SliceModeEnum; /** * @brief Enumerate the type of rate control mode */ typedef enum { RC_QUALITY_MODE = 0, ///< quality mode RC_BITRATE_MODE = 1, ///< bitrate mode RC_BUFFERBASED_MODE = 2, ///< no bitrate control,only using buffer status,adjust the video quality RC_TIMESTAMP_MODE = 3, //rate control based timestamp RC_BITRATE_MODE_POST_SKIP = 4, ///< this is in-building RC MODE, WILL BE DELETED after algorithm tuning! RC_OFF_MODE = -1, ///< rate control off mode } RC_MODES; /** * @brief Enumerate the type of profile id */ typedef enum { PRO_UNKNOWN = 0, PRO_BASELINE = 66, PRO_MAIN = 77, PRO_EXTENDED = 88, PRO_HIGH = 100, PRO_HIGH10 = 110, PRO_HIGH422 = 122, PRO_HIGH444 = 144, PRO_CAVLC444 = 244, PRO_SCALABLE_BASELINE = 83, PRO_SCALABLE_HIGH = 86 } EProfileIdc; /** * @brief Enumerate the type of level id */ typedef enum { LEVEL_UNKNOWN, LEVEL_1_0, LEVEL_1_B, LEVEL_1_1, LEVEL_1_2, LEVEL_1_3, LEVEL_2_0, LEVEL_2_1, LEVEL_2_2, LEVEL_3_0, LEVEL_3_1, LEVEL_3_2, LEVEL_4_0, LEVEL_4_1, LEVEL_4_2, LEVEL_5_0, LEVEL_5_1, LEVEL_5_2 } ELevelIdc; /** * @brief Enumerate the type of wels log */ enum { WELS_LOG_QUIET = 0x00, ///< quiet mode WELS_LOG_ERROR = 1 << 0, ///< error log iLevel WELS_LOG_WARNING = 1 << 1, ///< Warning log iLevel WELS_LOG_INFO = 1 << 2, ///< information log iLevel WELS_LOG_DEBUG = 1 << 3, ///< debug log, critical algo log WELS_LOG_DETAIL = 1 << 4, ///< per packet/frame log WELS_LOG_RESV = 1 << 5, ///< resversed log iLevel WELS_LOG_LEVEL_COUNT = 6, WELS_LOG_DEFAULT = WELS_LOG_WARNING ///< default log iLevel in Wels codec }; /** * @brief Structure for slice configuration */ typedef struct { SliceModeEnum uiSliceMode; ///< by default, uiSliceMode will be SM_SINGLE_SLICE SSliceArgument sSliceArgument; } SSliceConfig; /** * @brief Structure for spatial layer configuration */ typedef struct { int iVideoWidth; ///< width of picture in luminance samples of a layer int iVideoHeight; ///< height of picture in luminance samples of a layer float fFrameRate; ///< frame rate specified for a layer int iSpatialBitrate; ///< target bitrate for a spatial layer, in unit of bps int iMaxSpatialBitrate; ///< maximum bitrate for a spatial layer, in unit of bps EProfileIdc uiProfileIdc; ///< value of profile IDC (PRO_UNKNOWN for auto-detection) ELevelIdc uiLevelIdc; ///< value of profile IDC (0 for auto-detection) int iDLayerQp; ///< value of level IDC (0 for auto-detection) SSliceConfig sSliceCfg; ///< slice configuration for a layer } SSpatialLayerConfig; /** * @brief Encoder usage type */ typedef enum { CAMERA_VIDEO_REAL_TIME, ///< camera video for real-time communication SCREEN_CONTENT_REAL_TIME, ///< screen content signal CAMERA_VIDEO_NON_REAL_TIME } EUsageType; /** * @brief Enumulate the complexity mode */ typedef enum { LOW_COMPLEXITY, ///< the lowest compleixty,the fastest speed, MEDIUM_COMPLEXITY, ///< medium complexity, medium speed,medium quality HIGH_COMPLEXITY ///< high complexity, lowest speed, high quality } ECOMPLEXITY_MODE; /** * @brief Enumulate for the stategy of SPS/PPS strategy */ typedef enum { CONSTANT_ID = 0, ///< constant id in SPS/PPS INCREASING_ID = 0x01, ///< SPS/PPS id increases at each IDR SPS_LISTING = 0x02, ///< using SPS in the existing list if possible SPS_LISTING_AND_PPS_INCREASING = 0x03, SPS_PPS_LISTING = 0x06, } EParameterSetStrategy; // TODO: Refine the parameters definition. /** * @brief SVC Encoding Parameters */ typedef struct TagEncParamBase { EUsageType iUsageType; ///< application type;1.CAMERA_VIDEO_REAL_TIME:camera video signal; 2.SCREEN_CONTENT_REAL_TIME:screen content signal; int iPicWidth; ///< width of picture in luminance samples (the maximum of all layers if multiple spatial layers presents) int iPicHeight; ///< height of picture in luminance samples((the maximum of all layers if multiple spatial layers presents) int iTargetBitrate; ///< target bitrate desired, in unit of bps RC_MODES iRCMode; ///< rate control mode float fMaxFrameRate; ///< maximal input frame rate } SEncParamBase, *PEncParamBase; /** * @brief SVC Encoding Parameters extention */ typedef struct TagEncParamExt { EUsageType iUsageType; ///< application type;1.CAMERA_VIDEO_REAL_TIME:camera video signal;2.SCREEN_CONTENT_REAL_TIME:screen content signal; int iPicWidth; ///< width of picture in luminance samples (the maximum of all layers if multiple spatial layers presents) int iPicHeight; ///< height of picture in luminance samples((the maximum of all layers if multiple spatial layers presents) int iTargetBitrate; ///< target bitrate desired, in unit of bps RC_MODES iRCMode; ///< rate control mode float fMaxFrameRate; ///< maximal input frame rate int iTemporalLayerNum; ///< temporal layer number, max temporal layer = 4 int iSpatialLayerNum; ///< spatial layer number,1<= iSpatialLayerNum <= MAX_SPATIAL_LAYER_NUM, MAX_SPATIAL_LAYER_NUM = 4 SSpatialLayerConfig sSpatialLayers[MAX_SPATIAL_LAYER_NUM]; ECOMPLEXITY_MODE iComplexityMode; unsigned int uiIntraPeriod; ///< period of Intra frame int iNumRefFrame; ///< number of reference frame used EParameterSetStrategy eSpsPpsIdStrategy; ///< different stategy in adjust ID in SPS/PPS: 0- constant ID, 1-additional ID, 6-mapping and additional bool bPrefixNalAddingCtrl; ///< false:not use Prefix NAL; true: use Prefix NAL bool bEnableSSEI; ///< false:not use SSEI; true: use SSEI -- TODO: planning to remove the interface of SSEI bool bSimulcastAVC; ///< (when encoding more than 1 spatial layer) false: use SVC syntax for higher layers; true: use Simulcast AVC -- coming soon int iPaddingFlag; ///< 0:disable padding;1:padding int iEntropyCodingModeFlag; ///< 0:CAVLC 1:CABAC. /* rc control */ bool bEnableFrameSkip; ///< False: don't skip frame even if VBV buffer overflow.True: allow skipping frames to keep the bitrate within limits int iMaxBitrate; ///< the maximum bitrate, in unit of bps, set it to UNSPECIFIED_BIT_RATE if not needed int iMaxQp; ///< the maximum QP encoder supports int iMinQp; ///< the minmum QP encoder supports unsigned int uiMaxNalSize; ///< the maximum NAL size. This value should be not 0 for dynamic slice mode /*LTR settings*/ bool bEnableLongTermReference; ///< 1: on, 0: off int iLTRRefNum; ///< the number of LTR(long term reference),TODO: not supported to set it arbitrary yet unsigned int iLtrMarkPeriod; ///< the LTR marked period that is used in feedback. /* multi-thread settings*/ unsigned short iMultipleThreadIdc; ///< 1 # 0: auto(dynamic imp. internal encoder); 1: multiple threads imp. disabled; lager than 1: count number of threads; /* Deblocking loop filter */ int iLoopFilterDisableIdc; ///< 0: on, 1: off, 2: on except for slice boundaries int iLoopFilterAlphaC0Offset; ///< AlphaOffset: valid range [-6, 6], default 0 int iLoopFilterBetaOffset; ///< BetaOffset: valid range [-6, 6], default 0 /*pre-processing feature*/ bool bEnableDenoise; ///< denoise control bool bEnableBackgroundDetection; ///< background detection control //VAA_BACKGROUND_DETECTION //BGD cmd bool bEnableAdaptiveQuant; ///< adaptive quantization control bool bEnableFrameCroppingFlag; ///< enable frame cropping flag: TRUE always in application bool bEnableSceneChangeDetect; bool bIsLosslessLink; ///< LTR advanced setting } SEncParamExt; /** * @brief Define a new struct to show the property of video bitstream. */ typedef struct { unsigned int size; ///< size of the struct VIDEO_BITSTREAM_TYPE eVideoBsType; ///< video stream type (AVC/SVC) } SVideoProperty; /** * @brief SVC Decoding Parameters, reserved here and potential applicable in the future */ typedef struct TagSVCDecodingParam { char* pFileNameRestructed; ///< file name of reconstructed frame used for PSNR calculation based debug EVideoFormatType eOutputColorFormat; ///< color space format to be outputed, EVideoFormatType specified in codec_def.h unsigned int uiCpuLoad; ///< CPU load unsigned char uiTargetDqLayer; ///< setting target dq layer id ERROR_CON_IDC eEcActiveIdc; ///< whether active error concealment feature in decoder bool bParseOnly; ///< decoder for parse only, no reconstruction. When it is true, SPS/PPS size should not exceed SPS_PPS_BS_SIZE (128). Otherwise, it will return error info SVideoProperty sVideoProperty; ///< video stream property } SDecodingParam, *PDecodingParam; /** * @brief Bitstream inforamtion of a layer being encoded */ typedef struct { unsigned char uiTemporalId; unsigned char uiSpatialId; unsigned char uiQualityId; unsigned char uiLayerType; int iNalCount; ///< count number of NAL coded already int* pNalLengthInByte; ///< length of NAL size in byte from 0 to iNalCount-1 unsigned char* pBsBuf; ///< buffer of bitstream contained } SLayerBSInfo, *PLayerBSInfo; /** * @brief Frame bit stream info */ typedef struct { int iTemporalId; ///< temporal ID /** * The sub sequence layers are ordered hierarchically based on their dependency on each other so that any picture in a layer shall not be * predicted from any picture on any higher layer. */ int iSubSeqId; ///< refer to D.2.11 Sub-sequence information SEI message semantics int iLayerNum; SLayerBSInfo sLayerInfo[MAX_LAYER_NUM_OF_FRAME]; EVideoFrameType eFrameType; int iFrameSizeInBytes; long long uiTimeStamp; } SFrameBSInfo, *PFrameBSInfo; /** * @brief Structure for source picture */ typedef struct Source_Picture_s { int iColorFormat; ///< color space type int iStride[4]; ///< stride for each plane pData unsigned char* pData[4]; ///< plane pData int iPicWidth; ///< luma picture width in x coordinate int iPicHeight; ///< luma picture height in y coordinate long long uiTimeStamp; ///< timestamp of the source picture, unit: millisecond } SSourcePicture; /** * @brief Structure for bit rate info */ typedef struct TagBitrateInfo { LAYER_NUM iLayer; int iBitrate; ///< the maximum bitrate } SBitrateInfo; /** * @brief Structure for dump layer info */ typedef struct TagDumpLayer { int iLayer; char* pFileName; } SDumpLayer; /** * @brief Structure for profile info in layer * */ typedef struct TagProfileInfo { int iLayer; EProfileIdc uiProfileIdc; ///< the profile info } SProfileInfo; /** * @brief Structure for level info in layer * */ typedef struct TagLevelInfo { int iLayer; ELevelIdc uiLevelIdc; ///< the level info } SLevelInfo; /** * @brief Structure for dilivery status * */ typedef struct TagDeliveryStatus { bool bDeliveryFlag; ///< 0: the previous frame isn't delivered,1: the previous frame is delivered int iDropFrameType; ///< the frame type that is dropped; reserved int iDropFrameSize; ///< the frame size that is dropped; reserved } SDeliveryStatus; /** * @brief The capability of decoder, for SDP negotiation */ typedef struct TagDecoderCapability { int iProfileIdc; ///< profile_idc int iProfileIop; ///< profile-iop int iLevelIdc; ///< level_idc int iMaxMbps; ///< max-mbps int iMaxFs; ///< max-fs int iMaxCpb; ///< max-cpb int iMaxDpb; ///< max-dpb int iMaxBr; ///< max-br bool bRedPicCap; ///< redundant-pic-cap } SDecoderCapability; /** * @brief to do */ typedef struct TagParserBsInfo { int iNalNum; ///< total NAL number in current AU int iNalLenInByte [MAX_NAL_UNITS_IN_LAYER]; ///< each nal length unsigned char* pDstBuff; ///< outputted dst buffer for parsed bitstream int iSpsWidthInPixel; ///< required SPS width info int iSpsHeightInPixel; ///< required SPS height info unsigned long long uiInBsTimeStamp; ///< input BS timestamp unsigned long long uiOutBsTimeStamp; ///< output BS timestamp } SParserBsInfo, *PParserBsInfo; /** * @brief Structure for encoder statistics */ typedef struct TagVideoEncoderStatistics { unsigned int uiWidth; ///< the width of encoded frame unsigned int uiHeight; ///< the height of encoded frame //following standard, will be 16x aligned, if there are multiple spatial, this is of the highest float fAverageFrameSpeedInMs; ///< average_Encoding_Time // rate control related float fAverageFrameRate; ///< the average frame rate in, calculate since encoding starts, supposed that the input timestamp is in unit of ms float fLatestFrameRate; ///< the frame rate in, in the last second, supposed that the input timestamp is in unit of ms (? useful for checking BR, but is it easy to calculate? unsigned int uiBitRate; ///< sendrate in Bits per second, calculated within the set time-window unsigned int uiAverageFrameQP; ///< the average QP of last encoded frame unsigned int uiInputFrameCount; ///< number of frames unsigned int uiSkippedFrameCount; ///< number of frames unsigned int uiResolutionChangeTimes; ///< uiResolutionChangeTimes unsigned int uiIDRReqNum; ///< number of IDR requests unsigned int uiIDRSentNum; ///< number of actual IDRs sent unsigned int uiLTRSentNum; ///< number of LTR sent/marked long long iStatisticsTs; ///< Timestamp of updating the statistics } SEncoderStatistics; // in building, coming soon /** * @brief Structure for decoder statistics */ typedef struct TagVideoDecoderStatistics { unsigned int uiWidth; ///< the width of encode/decode frame unsigned int uiHeight; ///< the height of encode/decode frame float fAverageFrameSpeedInMs; ///< average_Decoding_Time float fActualAverageFrameSpeedInMs; ///< actual average_Decoding_Time, including freezing pictures unsigned int uiDecodedFrameCount; ///< number of frames unsigned int uiResolutionChangeTimes; ///< uiResolutionChangeTimes unsigned int uiIDRCorrectNum; ///< number of correct IDR received //EC on related unsigned int uiAvgEcRatio; ///< when EC is on, the average ratio of total EC areas, can be an indicator of reconstruction quality unsigned int uiAvgEcPropRatio; ///< when EC is on, the rough average ratio of propogate EC areas, can be an indicator of reconstruction quality unsigned int uiEcIDRNum; ///< number of actual unintegrity IDR or not received but eced unsigned int uiEcFrameNum; ///< unsigned int uiIDRLostNum; ///< number of whole lost IDR unsigned int uiFreezingIDRNum; ///< number of freezing IDR with error (partly received), under resolution change unsigned int uiFreezingNonIDRNum; ///< number of freezing non-IDR with error int iAvgLumaQp; ///< average luma QP. default: -1, no correct frame outputted int iSpsReportErrorNum; ///< number of Sps Invalid report int iSubSpsReportErrorNum; ///< number of SubSps Invalid report int iPpsReportErrorNum; ///< number of Pps Invalid report int iSpsNoExistNalNum; ///< number of Sps NoExist Nal int iSubSpsNoExistNalNum; ///< number of SubSps NoExist Nal int iPpsNoExistNalNum; ///< number of Pps NoExist Nal } SDecoderStatistics; // in building, coming soon #endif//WELS_VIDEO_CODEC_APPLICATION_DEFINITION_H__