2014-01-14 15:48:20 +08:00
|
|
|
#include <fstream>
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include "codec_def.h"
|
|
|
|
#include "utils/BufferedData.h"
|
2014-01-18 19:31:54 +08:00
|
|
|
#include "utils/FileInputStream.h"
|
2014-01-14 15:48:20 +08:00
|
|
|
#include "BaseEncoderTest.h"
|
|
|
|
|
2014-10-29 13:50:18 +08:00
|
|
|
static int InitWithParam (ISVCEncoder* encoder, SEncParamExt* pEncParamExt) {
|
|
|
|
|
2015-11-10 09:50:06 -08:00
|
|
|
SliceModeEnum eSliceMode = pEncParamExt->sSpatialLayers[0].sSliceArgument.uiSliceMode;
|
2014-10-29 13:50:18 +08:00
|
|
|
bool bBaseParamFlag = (SM_SINGLE_SLICE == eSliceMode && !pEncParamExt->bEnableDenoise
|
|
|
|
&& pEncParamExt->iSpatialLayerNum == 1 && !pEncParamExt->bIsLosslessLink
|
|
|
|
&& !pEncParamExt->bEnableLongTermReference && !pEncParamExt->iEntropyCodingModeFlag) ? true : false;
|
|
|
|
if (bBaseParamFlag) {
|
2014-03-03 10:59:16 +02:00
|
|
|
SEncParamBase param;
|
2014-06-25 18:50:41 -07:00
|
|
|
memset (¶m, 0, sizeof (SEncParamBase));
|
|
|
|
|
2014-10-29 13:50:18 +08:00
|
|
|
param.iUsageType = pEncParamExt->iUsageType;
|
|
|
|
param.fMaxFrameRate = pEncParamExt->fMaxFrameRate;
|
|
|
|
param.iPicWidth = pEncParamExt->iPicWidth;
|
|
|
|
param.iPicHeight = pEncParamExt->iPicHeight;
|
2014-03-03 10:59:16 +02:00
|
|
|
param.iTargetBitrate = 5000000;
|
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
return encoder->Initialize (¶m);
|
2014-03-03 10:59:16 +02:00
|
|
|
} else {
|
|
|
|
SEncParamExt param;
|
2014-06-25 18:50:41 -07:00
|
|
|
encoder->GetDefaultParams (¶m);
|
2014-03-03 10:59:16 +02:00
|
|
|
|
2014-10-29 13:50:18 +08:00
|
|
|
param.iUsageType = pEncParamExt->iUsageType;
|
|
|
|
param.fMaxFrameRate = pEncParamExt->fMaxFrameRate;
|
|
|
|
param.iPicWidth = pEncParamExt->iPicWidth;
|
|
|
|
param.iPicHeight = pEncParamExt->iPicHeight;
|
|
|
|
param.iTargetBitrate = 5000000;
|
|
|
|
param.bEnableDenoise = pEncParamExt->bEnableDenoise;
|
|
|
|
param.iSpatialLayerNum = pEncParamExt->iSpatialLayerNum;
|
|
|
|
param.bIsLosslessLink = pEncParamExt->bIsLosslessLink;
|
|
|
|
param.bEnableLongTermReference = pEncParamExt->bEnableLongTermReference;
|
|
|
|
param.iEntropyCodingModeFlag = pEncParamExt->iEntropyCodingModeFlag ? 1 : 0;
|
2015-11-10 09:50:06 -08:00
|
|
|
if (eSliceMode != SM_SINGLE_SLICE && eSliceMode != SM_SIZELIMITED_SLICE) //SM_SIZELIMITED_SLICE don't support multi-thread now
|
2014-04-01 11:39:04 +03:00
|
|
|
param.iMultipleThreadIdc = 2;
|
|
|
|
|
2014-03-14 19:01:37 +02:00
|
|
|
for (int i = 0; i < param.iSpatialLayerNum; i++) {
|
2014-10-29 13:50:18 +08:00
|
|
|
param.sSpatialLayers[i].iVideoWidth = pEncParamExt->iPicWidth >> (param.iSpatialLayerNum - 1 - i);
|
|
|
|
param.sSpatialLayers[i].iVideoHeight = pEncParamExt->iPicHeight >> (param.iSpatialLayerNum - 1 - i);
|
|
|
|
param.sSpatialLayers[i].fFrameRate = pEncParamExt->fMaxFrameRate;
|
2014-03-14 19:01:37 +02:00
|
|
|
param.sSpatialLayers[i].iSpatialBitrate = param.iTargetBitrate;
|
2014-03-03 10:59:16 +02:00
|
|
|
|
2015-11-10 09:50:06 -08:00
|
|
|
param.sSpatialLayers[i].sSliceArgument.uiSliceMode = eSliceMode;
|
|
|
|
if (eSliceMode == SM_SIZELIMITED_SLICE) {
|
|
|
|
param.sSpatialLayers[i].sSliceArgument.uiSliceSizeConstraint = 600;
|
2014-05-22 19:39:43 +08:00
|
|
|
param.uiMaxNalSize = 1500;
|
|
|
|
}
|
2015-11-23 11:54:43 -08:00
|
|
|
if (eSliceMode == SM_FIXEDSLCNUM_SLICE) {
|
|
|
|
param.sSpatialLayers[i].sSliceArgument.uiSliceNum = 4;
|
|
|
|
param.iMultipleThreadIdc = 4;
|
|
|
|
param.bUseLoadBalancing = false;
|
|
|
|
}
|
2014-03-14 19:01:37 +02:00
|
|
|
}
|
2014-06-10 10:57:11 +03:00
|
|
|
param.iTargetBitrate *= param.iSpatialLayerNum;
|
2014-03-03 10:59:16 +02:00
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
return encoder->InitializeExt (¶m);
|
2014-03-03 10:59:16 +02:00
|
|
|
}
|
2014-01-14 15:48:20 +08:00
|
|
|
}
|
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
BaseEncoderTest::BaseEncoderTest() : encoder_ (NULL) {}
|
2014-01-14 15:48:20 +08:00
|
|
|
|
|
|
|
void BaseEncoderTest::SetUp() {
|
2014-06-25 18:50:41 -07:00
|
|
|
int rv = WelsCreateSVCEncoder (&encoder_);
|
|
|
|
ASSERT_EQ (0, rv);
|
|
|
|
ASSERT_TRUE (encoder_ != NULL);
|
2014-12-11 14:31:32 +08:00
|
|
|
|
|
|
|
unsigned int uiTraceLevel = WELS_LOG_ERROR;
|
|
|
|
encoder_->SetOption (ENCODER_OPTION_TRACE_LEVEL, &uiTraceLevel);
|
2014-01-14 15:48:20 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void BaseEncoderTest::TearDown() {
|
|
|
|
if (encoder_) {
|
|
|
|
encoder_->Uninitialize();
|
2014-06-25 18:50:41 -07:00
|
|
|
WelsDestroySVCEncoder (encoder_);
|
2014-01-14 15:48:20 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-10-29 13:50:18 +08:00
|
|
|
void BaseEncoderTest::EncodeStream (InputStream* in, SEncParamExt* pEncParamExt, Callback* cbk) {
|
|
|
|
|
|
|
|
ASSERT_TRUE (NULL != pEncParamExt);
|
|
|
|
|
|
|
|
int rv = InitWithParam (encoder_, pEncParamExt);
|
2014-06-25 18:50:41 -07:00
|
|
|
ASSERT_TRUE (rv == cmResultSuccess);
|
2014-01-14 15:48:20 +08:00
|
|
|
|
|
|
|
// I420: 1(Y) + 1/4(U) + 1/4(V)
|
2014-10-29 13:50:18 +08:00
|
|
|
int frameSize = pEncParamExt->iPicWidth * pEncParamExt->iPicHeight * 3 / 2;
|
2014-01-14 15:48:20 +08:00
|
|
|
|
|
|
|
BufferedData buf;
|
2014-06-25 18:50:41 -07:00
|
|
|
buf.SetLength (frameSize);
|
|
|
|
ASSERT_TRUE (buf.Length() == (size_t)frameSize);
|
2014-01-14 15:48:20 +08:00
|
|
|
|
|
|
|
SFrameBSInfo info;
|
2014-06-25 18:50:41 -07:00
|
|
|
memset (&info, 0, sizeof (SFrameBSInfo));
|
2014-01-14 15:48:20 +08:00
|
|
|
|
2014-02-20 10:33:07 +08:00
|
|
|
SSourcePicture pic;
|
2014-06-25 18:50:41 -07:00
|
|
|
memset (&pic, 0, sizeof (SSourcePicture));
|
2014-10-29 13:50:18 +08:00
|
|
|
pic.iPicWidth = pEncParamExt->iPicWidth;
|
|
|
|
pic.iPicHeight = pEncParamExt->iPicHeight;
|
2014-02-20 10:33:07 +08:00
|
|
|
pic.iColorFormat = videoFormatI420;
|
2014-10-29 13:50:18 +08:00
|
|
|
pic.iStride[0] = pic.iPicWidth;
|
|
|
|
pic.iStride[1] = pic.iStride[2] = pic.iPicWidth >> 1;
|
|
|
|
pic.pData[0] = buf.data();
|
|
|
|
pic.pData[1] = pic.pData[0] + pEncParamExt->iPicWidth * pEncParamExt->iPicHeight;
|
|
|
|
pic.pData[2] = pic.pData[1] + (pEncParamExt->iPicWidth * pEncParamExt->iPicHeight >> 2);
|
2014-06-25 18:50:41 -07:00
|
|
|
while (in->read (buf.data(), frameSize) == frameSize) {
|
|
|
|
rv = encoder_->EncodeFrame (&pic, &info);
|
|
|
|
ASSERT_TRUE (rv == cmResultSuccess);
|
2014-06-23 16:38:45 +08:00
|
|
|
if (info.eFrameType != videoFrameTypeSkip && cbk != NULL) {
|
2014-06-25 18:50:41 -07:00
|
|
|
cbk->onEncodeFrame (info);
|
2014-01-14 15:48:20 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-01-18 19:31:54 +08:00
|
|
|
|
2014-10-29 13:50:18 +08:00
|
|
|
void BaseEncoderTest::EncodeFile (const char* fileName, SEncParamExt* pEncParamExt, Callback* cbk) {
|
2014-01-18 19:31:54 +08:00
|
|
|
FileInputStream fileStream;
|
2014-06-25 18:50:41 -07:00
|
|
|
ASSERT_TRUE (fileStream.Open (fileName));
|
2014-10-29 13:50:18 +08:00
|
|
|
ASSERT_TRUE (NULL != pEncParamExt);
|
|
|
|
EncodeStream (&fileStream, pEncParamExt, cbk);
|
2014-01-18 19:31:54 +08:00
|
|
|
}
|