2014-04-24 15:12:49 +08:00
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <math.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "cpu_core.h"
|
|
|
|
#include "IWelsVP.h"
|
|
|
|
#include "ScrollDetection.h"
|
|
|
|
#include "ScrollDetectionFuncs.h"
|
|
|
|
#include "utils/DataGenerator.h"
|
|
|
|
|
2014-09-17 15:50:59 +08:00
|
|
|
using namespace WelsVP;
|
2014-04-24 15:12:49 +08:00
|
|
|
|
|
|
|
#define ASSERT_MEMORY_FAIL2X(A, B) \
|
|
|
|
if (NULL == B) { \
|
|
|
|
delete []A;\
|
|
|
|
ASSERT_TRUE(0); \
|
|
|
|
}
|
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
TEST (ScrollDetectionTest, TestScroll) {
|
2014-04-30 16:46:58 +08:00
|
|
|
unsigned char* pSrc, *pRef;
|
2014-06-25 18:50:41 -07:00
|
|
|
int iWidthSets[4] = {640, 1024, 1280, 1980};
|
|
|
|
int iHeightSets[4] = {360, 768, 720, 1080};
|
2014-04-30 16:46:58 +08:00
|
|
|
int iStride = 0;
|
2014-04-24 15:12:49 +08:00
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
for (int i = 0; i < 4; i++) {
|
2014-04-30 16:46:58 +08:00
|
|
|
int iWidth = iWidthSets[i];
|
|
|
|
int iHeight = iHeightSets[i];
|
2014-04-24 15:12:49 +08:00
|
|
|
iStride = iWidth + 16;
|
2014-06-25 18:50:41 -07:00
|
|
|
pSrc = new unsigned char[iHeight * iStride];
|
|
|
|
ASSERT_TRUE (NULL != pSrc);
|
|
|
|
pRef = new unsigned char[iHeight * iStride];
|
|
|
|
ASSERT_MEMORY_FAIL2X (pSrc, pRef)
|
2014-06-28 21:57:42 +03:00
|
|
|
RandomPixelDataGenerator (pRef, iWidth, iHeight, iStride);
|
2014-04-24 15:12:49 +08:00
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
int iMvRange = iHeight / 3;
|
|
|
|
int iScrollMv = rand() % (iMvRange << 1) - iMvRange;
|
2014-04-30 16:46:58 +08:00
|
|
|
unsigned char* pSrcTmp = pSrc;
|
|
|
|
unsigned char* pRefTmp = pRef;
|
2014-04-24 15:12:49 +08:00
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
for (int j = 0; j < iHeight; j++) {
|
|
|
|
if ((j + iScrollMv) >= 0 && (j + iScrollMv) < iHeight)
|
|
|
|
for (int i = 0; i < iWidth; i++) {
|
|
|
|
memcpy (pSrcTmp , &pRefTmp[ (j + iScrollMv)*iStride], iWidth * sizeof (unsigned char));
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
for (int i = 0; i < iWidth; i++)
|
|
|
|
pSrcTmp[i] = rand() % 256;
|
2014-04-24 15:12:49 +08:00
|
|
|
}
|
|
|
|
pSrcTmp += iStride;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
SPixMap sSrcMap = { { 0 } };
|
|
|
|
SPixMap sRefMap = { { 0 } };
|
|
|
|
|
|
|
|
sSrcMap.pPixel[0] = pSrc;
|
|
|
|
sRefMap.pPixel[0] = pRef;
|
|
|
|
sSrcMap.iStride[0] = sRefMap.iStride[0] = iStride;
|
|
|
|
sSrcMap.sRect.iRectWidth = sRefMap.sRect.iRectWidth = iWidth;
|
|
|
|
sSrcMap.sRect.iRectHeight = sRefMap.sRect.iRectHeight = iHeight;
|
|
|
|
|
|
|
|
SScrollDetectionParam sScrollDetectionResult;
|
|
|
|
WelsMemset (&sScrollDetectionResult, 0, sizeof (sScrollDetectionResult));
|
2014-04-30 16:46:58 +08:00
|
|
|
int iCoreNum = 1;
|
|
|
|
unsigned int uiCPUFlag = WelsCPUFeatureDetect (&iCoreNum);
|
2014-04-24 15:12:49 +08:00
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
CScrollDetection* pTest = new CScrollDetection (uiCPUFlag);
|
2014-04-30 16:46:58 +08:00
|
|
|
int iMethodIdx = METHOD_SCROLL_DETECTION;
|
2014-04-24 15:12:49 +08:00
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
pTest->Set (iMethodIdx, (&sScrollDetectionResult));
|
|
|
|
int ret = pTest->Process (iMethodIdx, &sSrcMap, &sRefMap);
|
|
|
|
EXPECT_EQ (ret, 0);
|
|
|
|
pTest->Get (iMethodIdx, (&sScrollDetectionResult));
|
2014-04-24 15:12:49 +08:00
|
|
|
|
2014-06-25 18:50:41 -07:00
|
|
|
EXPECT_EQ (sScrollDetectionResult.bScrollDetectFlag, true);
|
|
|
|
EXPECT_EQ (sScrollDetectionResult.iScrollMvY, iScrollMv);
|
2014-04-24 15:12:49 +08:00
|
|
|
|
|
|
|
delete pTest;
|
|
|
|
delete []pSrc;
|
|
|
|
delete []pRef;
|
|
|
|
}
|
|
|
|
}
|