Newer
Older
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
sei->m_maiSignR[i].resize(3);
sei->m_maiExponentR[i].resize(3);
sei->m_maiMantissaR[i].resize(3);
sei->m_maiSignT[i].resize(3);
sei->m_maiExponentT[i].resize(3);
sei->m_maiMantissaT[i].resize(3);
for (int j = 0; j < 3; j++)
{
sei->m_maiSignR[i][j].resize(3);
sei->m_maiExponentR[i][j].resize(3);
sei->m_maiMantissaR[i][j].resize(3);
for (int k = 0; k < 3; k++)
{
sei->m_maiSignR[i][j][k] = 0;
sei->m_maiExponentR[i][j][k] = 0;
sei->m_maiMantissaR[i][j][k] = 0;
}
sei->m_maiSignT[i][j] = 0;
sei->m_maiExponentT[i][j] = 0;
sei->m_maiMantissaT[i][j] = 0;
}
}
}
}
void SEIEncoder::initSEIMultiviewViewPosition(SEIMultiviewViewPosition *sei)
{
CHECK(!(m_isInitialized), "Multiview view position SEI already initialized");
CHECK(!(sei != nullptr), "Need a seiMultiviewViewPosition for initialization (got nullptr)");
sei->m_mvpNumViewsMinus1 = m_pcCfg->getMvpSEINumViewsMinus1();
int numViews = sei->m_mvpNumViewsMinus1 + 1;
sei->m_mvpViewPosition.resize(numViews);
for (int i = 0; i <= sei->m_mvpNumViewsMinus1; i++)
{
sei->m_mvpViewPosition[i] = m_pcCfg->getMvpSEIViewPosition(i);
}
}
void SEIEncoder::initSEIAlphaChannelInfo(SEIAlphaChannelInfo *sei)
{
CHECK(!(m_isInitialized), "Alpha channel information SEI already initialized");
CHECK(!(sei != nullptr), "Need a seiAlphaChannelInfo for initialization (got nullptr)");
sei->m_aciCancelFlag = m_pcCfg->getAciSEICancelFlag();
sei->m_aciUseIdc = m_pcCfg->getAciSEIUseIdc();
sei->m_aciBitDepthMinus8 = m_pcCfg->getAciSEIBitDepthMinus8();
sei->m_aciTransparentValue = m_pcCfg->getAciSEITransparentValue();
sei->m_aciOpaqueValue = m_pcCfg->getAciSEIOpaqueValue();
sei->m_aciIncrFlag = m_pcCfg->getAciSEIIncrFlag();
sei->m_aciClipFlag = m_pcCfg->getAciSEIClipFlag();
sei->m_aciClipTypeFlag = m_pcCfg->getAciSEIClipTypeFlag();
}
void SEIEncoder::initSEIDepthRepresentationInfo(SEIDepthRepresentationInfo *sei)
{
CHECK(!(m_isInitialized), "Depth representation information SEI already initialized");
CHECK(!(sei != nullptr), "Need a seiDepthRepresentationInfo for initialization (got nullptr)");
sei->m_driZNearFlag = m_pcCfg->getDriSEIZNearFlag();
sei->m_driZFarFlag = m_pcCfg->getDriSEIZFarFlag();
sei->m_driDMinFlag = m_pcCfg->getDriSEIDMinFlag();
sei->m_driDMaxFlag = m_pcCfg->getDriSEIDMaxFlag();
sei->m_driZNear = m_pcCfg->getDriSEIZNear();
sei->m_driZFar = m_pcCfg->getDriSEIZFar();
sei->m_driDMin = m_pcCfg->getDriSEIDMin();
sei->m_driDMax = m_pcCfg->getDriSEIDMax();
sei->m_driDisparityRefViewId = m_pcCfg->getDriSEIDisparityRefViewId();
sei->m_driDepthRepresentationType = m_pcCfg->getDriSEIDepthRepresentationType();
sei->m_driDepthNonlinearRepresentationNumMinus1 = m_pcCfg->getDriSEINonlinearNumMinus1();
sei->m_driDepthNonlinearRepresentationModel.resize(sei->m_driDepthNonlinearRepresentationNumMinus1 + 1);
for(int i = 0; i < (sei->m_driDepthNonlinearRepresentationNumMinus1 + 1); i++)
{
sei->m_driDepthNonlinearRepresentationModel[i] = m_pcCfg->getDriSEINonlinearModel(i);
}
}
void SEIEncoder::initSEIColourTransformInfo(SEIColourTransformInfo* seiCTI)
{
CHECK(!(m_isInitialized), "Unspecified error");
CHECK(!(seiCTI != nullptr), "Unspecified error");
1080
1081
1082
1083
1084
1085
1086
1087
1088
1089
1090
1091
1092
1093
1094
1095
1096
1097
1098
1099
1100
// Set SEI message parameters read from command line options
seiCTI->m_id = m_pcCfg->getCtiSEIId();
seiCTI->m_signalInfoFlag = m_pcCfg->getCtiSEISignalInfoFlag();
seiCTI->m_fullRangeFlag = m_pcCfg->getCtiSEIFullRangeFlag();
seiCTI->m_primaries = m_pcCfg->getCtiSEIPrimaries();
seiCTI->m_transferFunction = m_pcCfg->getCtiSEITransferFunction();
seiCTI->m_matrixCoefs = m_pcCfg->getCtiSEIMatrixCoefs();
seiCTI->m_crossComponentFlag = m_pcCfg->getCtiSEICrossComponentFlag();
seiCTI->m_crossComponentInferred = m_pcCfg->getCtiSEICrossComponentInferred();
seiCTI->m_numberChromaLutMinus1 = m_pcCfg->getCtiSEINbChromaLut() - 1;
seiCTI->m_chromaOffset = m_pcCfg->getCtiSEIChromaOffset();
seiCTI->m_bitdepth = m_pcCfg->getBitDepth(CHANNEL_TYPE_LUMA);
for (int i = 0; i < MAX_NUM_COMPONENT; i++) {
seiCTI->m_lut[i] = m_pcCfg->getCtiSEILut(i);
}
seiCTI->m_log2NumberOfPointsPerLut = floorLog2(seiCTI->m_lut[0].numLutValues - 1);
}
void SEIEncoder::initSEISubpictureLevelInfo(SEISubpicureLevelInfo *sei, const SPS *sps)
{
const EncCfgParam::CfgSEISubpictureLevel &cfgSubPicLevel = m_pcCfg->getSubpicureLevelInfoSEICfg();
sei->m_sliSublayerInfoPresentFlag = cfgSubPicLevel.m_sliSublayerInfoPresentFlag;
sei->m_sliMaxSublayers = cfgSubPicLevel.m_sliMaxSublayers;
sei->m_numRefLevels = cfgSubPicLevel.m_sliSublayerInfoPresentFlag ? (int)cfgSubPicLevel.m_refLevels.size() / cfgSubPicLevel.m_sliMaxSublayers : (int)cfgSubPicLevel.m_refLevels.size();
sei->m_numSubpics = cfgSubPicLevel.m_numSubpictures;
sei->m_explicitFractionPresentFlag = cfgSubPicLevel.m_explicitFraction;
sei->m_nonSubpicLayersFraction.resize(sei->m_numRefLevels);
sei->m_refLevelIdc.resize(sei->m_numRefLevels);
for (int level = 0; level < sei->m_numRefLevels; level++)
{
sei->m_nonSubpicLayersFraction[level].resize(sei->m_sliMaxSublayers);
sei->m_refLevelIdc[level].resize(sei->m_sliMaxSublayers);
for (int sublayer = 0; sublayer < sei->m_sliMaxSublayers; sublayer++)
{
sei->m_refLevelFraction.resize(sei->m_numRefLevels);
for (int level = 0; level < sei->m_numRefLevels; level++)
{
sei->m_refLevelFraction[level].resize(sei->m_numSubpics);
for (int subpic = 0; subpic < sei->m_numSubpics; subpic++)
{
sei->m_refLevelFraction[level][subpic].resize(sei->m_sliMaxSublayers);
for (int sublayer = 0; sublayer < sei->m_sliMaxSublayers; sublayer++)
{
sei->m_refLevelFraction[level][subpic][sublayer] = 0;
}
}
}
}
// set sei parameters according to the configured values
for (int sublayer = sei->m_sliSublayerInfoPresentFlag ? 0 : sei->m_sliMaxSublayers - 1, cnta = 0, cntb = 0; sublayer < sei->m_sliMaxSublayers; sublayer++)
{
for (int level = 0; level < sei->m_numRefLevels; level++)
{
sei->m_nonSubpicLayersFraction[level][sublayer] = cfgSubPicLevel.m_nonSubpicLayersFraction[cnta];
sei->m_refLevelIdc[level][sublayer] = cfgSubPicLevel.m_refLevels[cnta++];
if (sei->m_explicitFractionPresentFlag)
{
for (int subpic = 0; subpic < sei->m_numSubpics; subpic++)
{
sei->m_refLevelFraction[level][subpic][sublayer] = cfgSubPicLevel.m_fractions[cntb++];
}
// update the inference of m_refLevelIdc[][] and m_refLevelFraction[][][]
if (!sei->m_sliSublayerInfoPresentFlag)
{
for (int sublayer = sei->m_sliMaxSublayers - 2; sublayer >= 0; sublayer--)
{
for (int level = 0; level < sei->m_numRefLevels; level++)
{
sei->m_nonSubpicLayersFraction[level][sublayer] = sei->m_nonSubpicLayersFraction[level][sei->m_sliMaxSublayers - 1];
sei->m_refLevelIdc[level][sublayer] = sei->m_refLevelIdc[level][sei->m_sliMaxSublayers - 1];
if (sei->m_explicitFractionPresentFlag)
for (int subpic = 0; subpic < sei->m_numSubpics; subpic++)
{
sei->m_refLevelFraction[level][subpic][sublayer] = sei->m_refLevelFraction[level][subpic][sei->m_sliMaxSublayers - 1];
}
}
}
}
void SEIEncoder::initSEINeuralNetworkPostFilterCharacteristics(SEINeuralNetworkPostFilterCharacteristics *sei, int filterIdx)
{
CHECK(!(m_isInitialized), "Unspecified error");
sei->m_id = m_pcCfg->getNNPostFilterSEICharacteristicsId(filterIdx);
sei->m_modeIdc = m_pcCfg->getNNPostFilterSEICharacteristicsModeIdc(filterIdx);
Maria Santamaria
committed
#if JVET_AA0056_GATING_FILTER_CHARACTERISTICS
sei->m_purposeAndFormattingFlag = m_pcCfg->getNNPostFilterSEICharacteristicsPurposeAndFormattingFlag(filterIdx);
if (sei->m_purposeAndFormattingFlag)
#else
Maria Santamaria
committed
#endif
1190
1191
1192
1193
1194
1195
1196
1197
1198
1199
1200
1201
1202
1203
1204
1205
1206
1207
1208
1209
1210
1211
1212
1213
1214
1215
1216
1217
1218
{
sei->m_purpose = m_pcCfg->getNNPostFilterSEICharacteristicsPurpose(filterIdx);
if(sei->m_purpose == 2 || sei->m_purpose == 4)
{
sei->m_outSubWidthCFlag = m_pcCfg->getNNPostFilterSEICharacteristicsOutSubWidthCFlag(filterIdx);
sei->m_outSubHeightCFlag = m_pcCfg->getNNPostFilterSEICharacteristicsOutSubHeightCFlag(filterIdx);
}
if(sei->m_purpose == 3 || sei->m_purpose == 4)
{
sei->m_picWidthInLumaSamples = m_pcCfg->getNNPostFilterSEICharacteristicsPicWidthInLumaSamples(filterIdx);
sei->m_picHeightInLumaSamples = m_pcCfg->getNNPostFilterSEICharacteristicsPicHeightInLumaSamples(filterIdx);
}
sei->m_componentLastFlag = m_pcCfg->getNNPostFilterSEICharacteristicsComponentLastFlag(filterIdx);
sei->m_inpSampleIdc = m_pcCfg->getNNPostFilterSEICharacteristicsInpSampleIdc(filterIdx);
if(sei->m_inpSampleIdc == 4)
{
sei->m_inpTensorBitDepthMinus8 = m_pcCfg->getNNPostFilterSEICharacteristicsInpTensorBitDepthMinus8(filterIdx);
}
sei->m_inpOrderIdc = m_pcCfg->getNNPostFilterSEICharacteristicsInpOrderIdc(filterIdx);
sei->m_outSampleIdc = m_pcCfg->getNNPostFilterSEICharacteristicsOutSampleIdc(filterIdx);
if(sei->m_outSampleIdc == 4)
{
sei->m_outTensorBitDepthMinus8 = m_pcCfg->getNNPostFilterSEICharacteristicsOutTensorBitDepthMinus8(filterIdx);
}
#if JVET_AA0100_SEPERATE_COLOR_CHARACTERISTICS
sei->m_AuxInpIdc = m_pcCfg->getNNPostFilterSEICharacteristicsAuxInpIdc(filterIdx);
sei->m_SepColDescriptionFlag = m_pcCfg->getNNPostFilterSEICharacteristicsSepColDescriptionFlag(filterIdx);
if(sei->m_SepColDescriptionFlag){
sei->m_ColPrimaries = m_pcCfg->getNNPostFilterSEICharacteristicsColPrimaries(filterIdx);
sei->m_TransCharacteristics = m_pcCfg->getNNPostFilterSEICharacteristicsTransCharacteristics(filterIdx);
sei->m_MatrixCoeffs = m_pcCfg->getNNPostFilterSEICharacteristicsMatrixCoeffs(filterIdx);
}
#endif
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249
1250
1251
1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
sei->m_outOrderIdc = m_pcCfg->getNNPostFilterSEICharacteristicsOutOrderIdc(filterIdx);
sei->m_constantPatchSizeFlag = m_pcCfg->getNNPostFilterSEICharacteristicsConstantPatchSizeFlag(filterIdx);
sei->m_patchWidthMinus1 = m_pcCfg->getNNPostFilterSEICharacteristicsPatchWidthMinus1(filterIdx);
sei->m_patchHeightMinus1 = m_pcCfg->getNNPostFilterSEICharacteristicsPatchHeightMinus1(filterIdx);
sei->m_overlap = m_pcCfg->getNNPostFilterSEICharacteristicsOverlap(filterIdx);
sei->m_paddingType = m_pcCfg->getNNPostFilterSEICharacteristicsPaddingType(filterIdx);
sei->m_complexityIdc = m_pcCfg->getNNPostFilterSEICharacteristicsComplexityIdc(filterIdx);
if(sei->m_complexityIdc > 0)
{
if(sei->m_complexityIdc == 1)
{
sei->m_parameterTypeFlag = m_pcCfg->getNNPostFilterSEICharacteristicsParameterTypeFlag(filterIdx);
sei->m_log2ParameterBitLengthMinus3 = m_pcCfg->getNNPostFilterSEICharacteristicsLog2ParameterBitLengthMinus3(filterIdx);
sei->m_numParametersIdc = m_pcCfg->getNNPostFilterSEICharacteristicsNumParametersIdc(filterIdx);
sei->m_numKmacOperationsIdc = m_pcCfg->getNNPostFilterSEICharacteristicsNumKmacOperationsIdc(filterIdx);
}
}
}
if (sei->m_modeIdc == 1)
{
const string payloadFilename = m_pcCfg->getNNPostFilterSEICharacteristicsPayloadFilename(filterIdx);
ifstream bitstreamFile(payloadFilename.c_str(), ifstream::in | ifstream::binary);
if (!bitstreamFile)
{
EXIT( "Failed to open bitstream file " << payloadFilename.c_str() << " for reading" ) ;
}
bitstreamFile.seekg(0, std::ifstream::end);
sei->m_payloadLength = bitstreamFile.tellg();
bitstreamFile.seekg(0, std::ifstream::beg);
sei->m_payloadByte = new char[sei->m_payloadLength];
bitstreamFile.read(sei->m_payloadByte, sei->m_payloadLength);
bitstreamFile.close();
}
}
void SEIEncoder::initSEINeuralNetworkPostFilterActivation(SEINeuralNetworkPostFilterActivation *sei)
{
CHECK(!(m_isInitialized), "Unspecified error");
sei->m_id = m_pcCfg->getNnPostFilterSEIActivationId();
}