static void toRGB_caller(const oclMat &src, oclMat &dst, int bidx, const std::string & kernelName,
const oclMat & data = oclMat())
{
- std::string build_options = format("-D DEPTH_%d -D channels=%d", src.depth(), dst.channels());
+ std::string build_options = format("-D DEPTH_%d -D dcn=%d", src.depth(), dst.channels());
int src_offset = src.offset / src.elemSize1(), src_step = src.step1();
int dst_offset = dst.offset / dst.elemSize1(), dst_step = dst.step1();
openCLExecuteKernel(src.clCxt, &cvt_color, kernelName.c_str(), gt, lt, args, -1, -1, build_options.c_str());
}
+static void RGB_caller(const oclMat &src, oclMat &dst, bool reverse)
+{
+ std::string build_options = format("-D DEPTH_%d -D dcn=%d -D scn=%d -D %s", src.depth(),
+ dst.channels(), src.channels(), reverse ? "REVERSE" : "ORDER");
+ int src_offset = src.offset / src.elemSize1(), src_step = src.step1();
+ int dst_offset = dst.offset / dst.elemSize1(), dst_step = dst.step1();
+
+ vector<pair<size_t , const void *> > args;
+ args.push_back( make_pair( sizeof(cl_int) , (void *)&dst.cols));
+ args.push_back( make_pair( sizeof(cl_int) , (void *)&dst.rows));
+ args.push_back( make_pair( sizeof(cl_int) , (void *)&src_step));
+ args.push_back( make_pair( sizeof(cl_int) , (void *)&dst_step));
+ args.push_back( make_pair( sizeof(cl_mem) , (void *)&src.data));
+ args.push_back( make_pair( sizeof(cl_mem) , (void *)&dst.data));
+ args.push_back( make_pair( sizeof(cl_int) , (void *)&src_offset ));
+ args.push_back( make_pair( sizeof(cl_int) , (void *)&dst_offset ));
+
+ size_t gt[3] = { dst.cols, dst.rows, 1 }, lt[3] = { 16, 16, 1 };
+ openCLExecuteKernel(src.clCxt, &cvt_color, "RGB", gt, lt, args, -1, -1, build_options.c_str());
+}
+
static void cvtColor_caller(const oclMat &src, oclMat &dst, int code, int dcn)
{
Size sz = src.size();
switch (code)
{
- /*
- case CV_BGR2BGRA: case CV_RGB2BGRA: case CV_BGRA2BGR:
- case CV_RGBA2BGR: case CV_RGB2BGR: case CV_BGRA2RGBA:
- case CV_BGR2BGR565: case CV_BGR2BGR555: case CV_RGB2BGR565: case CV_RGB2BGR555:
- case CV_BGRA2BGR565: case CV_BGRA2BGR555: case CV_RGBA2BGR565: case CV_RGBA2BGR555:
- case CV_BGR5652BGR: case CV_BGR5552BGR: case CV_BGR5652RGB: case CV_BGR5552RGB:
- case CV_BGR5652BGRA: case CV_BGR5552BGRA: case CV_BGR5652RGBA: case CV_BGR5552RGBA:
- */
- case CV_RGB2GRAY:
- case CV_BGR2GRAY:
- case CV_RGBA2GRAY:
- case CV_BGRA2GRAY:
+ case CV_BGR2BGRA: case CV_RGB2BGRA: case CV_BGRA2BGR:
+ case CV_RGBA2BGR: case CV_RGB2BGR: case CV_BGRA2RGBA:
+ {
+ CV_Assert(scn == 3 || scn == 4);
+ dcn = code == CV_BGR2BGRA || code == CV_RGB2BGRA || code == CV_BGRA2RGBA ? 4 : 3;
+ bool reverse = !(code == CV_BGR2BGRA || code == CV_BGRA2BGR);
+ dst.create(sz, CV_MAKE_TYPE(depth, dcn));
+ RGB_caller(src, dst, reverse);
+ break;
+ }
+ /*
+ case CV_BGR2BGR565: case CV_BGR2BGR555: case CV_RGB2BGR565: case CV_RGB2BGR555:
+ case CV_BGRA2BGR565: case CV_BGRA2BGR555: case CV_RGBA2BGR565: case CV_RGBA2BGR555:
+ case CV_BGR5652BGR: case CV_BGR5552BGR: case CV_BGR5652RGB: case CV_BGR5552RGB:
+ case CV_BGR5652BGRA: case CV_BGR5552BGRA: case CV_BGR5652RGBA: case CV_BGR5552RGBA:
+ */
+ case CV_RGB2GRAY: case CV_BGR2GRAY:
+ case CV_RGBA2GRAY: case CV_BGRA2GRAY:
{
CV_Assert(scn == 3 || scn == 4);
bidx = code == CV_BGR2GRAY || code == CV_BGRA2GRAY ? 0 : 2;
toRGB_caller(src, dst, bidx, "YUV2RGB");
break;
}
- case CV_YUV2RGB_NV12:
- case CV_YUV2BGR_NV12:
- case CV_YUV2RGBA_NV12:
- case CV_YUV2BGRA_NV12:
+ case CV_YUV2RGB_NV12: case CV_YUV2BGR_NV12:
+ case CV_YUV2RGBA_NV12: case CV_YUV2BGRA_NV12:
{
CV_Assert(scn == 1);
CV_Assert( sz.width % 2 == 0 && sz.height % 3 == 0 && depth == CV_8U );
#define CVTCODE(name) COLOR_ ## name
-// RGB <-> Gray
-
-OCL_TEST_P(CvtColor, RGB2GRAY)
-{
- doTest(3, 1, CVTCODE(RGB2GRAY));
-}
-OCL_TEST_P(CvtColor, GRAY2RGB)
-{
- doTest(1, 3, CVTCODE(GRAY2RGB));
-}
+// RGB[A] <-> BGR[A]
+
+OCL_TEST_P(CvtColor, BGR2BGRA) { doTest(3, 4, CVTCODE(BGR2BGRA)); }
+OCL_TEST_P(CvtColor, RGB2RGBA) { doTest(3, 4, CVTCODE(BGR2BGRA)); }
+OCL_TEST_P(CvtColor, BGRA2BGR) { doTest(4, 3, CVTCODE(BGRA2BGR)); }
+OCL_TEST_P(CvtColor, RGBA2RGB) { doTest(4, 3, CVTCODE(BGRA2BGR)); }
+OCL_TEST_P(CvtColor, BGR2RGBA) { doTest(3, 4, CVTCODE(BGR2RGBA)); }
+OCL_TEST_P(CvtColor, RGB2BGRA) { doTest(3, 4, CVTCODE(BGR2RGBA)); }
+OCL_TEST_P(CvtColor, RGBA2BGR) { doTest(4, 3, CVTCODE(RGBA2BGR)); }
+OCL_TEST_P(CvtColor, BGRA2RGB) { doTest(4, 3, CVTCODE(RGBA2BGR)); }
+OCL_TEST_P(CvtColor, BGR2RGB) { doTest(3, 3, CVTCODE(BGR2RGB)); }
+OCL_TEST_P(CvtColor, RGB2BGR) { doTest(3, 3, CVTCODE(BGR2RGB)); }
+OCL_TEST_P(CvtColor, BGRA2RGBA) { doTest(4, 4, CVTCODE(BGRA2RGBA)); }
+OCL_TEST_P(CvtColor, RGBA2BGRA) { doTest(4, 4, CVTCODE(BGRA2RGBA)); }
-OCL_TEST_P(CvtColor, BGR2GRAY)
-{
- doTest(3, 1, CVTCODE(BGR2GRAY));
-}
-OCL_TEST_P(CvtColor, GRAY2BGR)
-{
- doTest(1, 3, CVTCODE(GRAY2BGR));
-}
-
-OCL_TEST_P(CvtColor, RGBA2GRAY)
-{
- doTest(4, 1, CVTCODE(RGBA2GRAY));
-}
-OCL_TEST_P(CvtColor, GRAY2RGBA)
-{
- doTest(1, 4, CVTCODE(GRAY2RGBA));
-}
+// RGB <-> Gray
-OCL_TEST_P(CvtColor, BGRA2GRAY)
-{
- doTest(4, 1, CVTCODE(BGRA2GRAY));
-}
-OCL_TEST_P(CvtColor, GRAY2BGRA)
-{
- doTest(1, 4, CVTCODE(GRAY2BGRA));
-}
+OCL_TEST_P(CvtColor, RGB2GRAY) { doTest(3, 1, CVTCODE(RGB2GRAY)); }
+OCL_TEST_P(CvtColor, GRAY2RGB) { doTest(1, 3, CVTCODE(GRAY2RGB)); }
+OCL_TEST_P(CvtColor, BGR2GRAY) { doTest(3, 1, CVTCODE(BGR2GRAY)); }
+OCL_TEST_P(CvtColor, GRAY2BGR) { doTest(1, 3, CVTCODE(GRAY2BGR)); }
+OCL_TEST_P(CvtColor, RGBA2GRAY) { doTest(4, 1, CVTCODE(RGBA2GRAY)); }
+OCL_TEST_P(CvtColor, GRAY2RGBA) { doTest(1, 4, CVTCODE(GRAY2RGBA)); }
+OCL_TEST_P(CvtColor, BGRA2GRAY) { doTest(4, 1, CVTCODE(BGRA2GRAY)); }
+OCL_TEST_P(CvtColor, GRAY2BGRA) { doTest(1, 4, CVTCODE(GRAY2BGRA)); }
// RGB <-> YUV
-OCL_TEST_P(CvtColor, RGB2YUV)
-{
- doTest(3, 3, CVTCODE(RGB2YUV));
-}
-OCL_TEST_P(CvtColor, BGR2YUV)
-{
- doTest(3, 3, CVTCODE(BGR2YUV));
-}
-OCL_TEST_P(CvtColor, RGBA2YUV)
-{
- doTest(4, 3, CVTCODE(RGB2YUV));
-}
-OCL_TEST_P(CvtColor, BGRA2YUV)
-{
- doTest(4, 3, CVTCODE(BGR2YUV));
-}
-OCL_TEST_P(CvtColor, YUV2RGB)
-{
- doTest(3, 3, CVTCODE(YUV2RGB));
-}
-OCL_TEST_P(CvtColor, YUV2BGR)
-{
- doTest(3, 3, CVTCODE(YUV2BGR));
-}
-OCL_TEST_P(CvtColor, YUV2RGBA)
-{
- doTest(3, 4, CVTCODE(YUV2RGB));
-}
-OCL_TEST_P(CvtColor, YUV2BGRA)
-{
- doTest(3, 4, CVTCODE(YUV2BGR));
-}
+OCL_TEST_P(CvtColor, RGB2YUV) { doTest(3, 3, CVTCODE(RGB2YUV)); }
+OCL_TEST_P(CvtColor, BGR2YUV) { doTest(3, 3, CVTCODE(BGR2YUV)); }
+OCL_TEST_P(CvtColor, RGBA2YUV) { doTest(4, 3, CVTCODE(RGB2YUV)); }
+OCL_TEST_P(CvtColor, BGRA2YUV) { doTest(4, 3, CVTCODE(BGR2YUV)); }
+OCL_TEST_P(CvtColor, YUV2RGB) { doTest(3, 3, CVTCODE(YUV2RGB)); }
+OCL_TEST_P(CvtColor, YUV2BGR) { doTest(3, 3, CVTCODE(YUV2BGR)); }
+OCL_TEST_P(CvtColor, YUV2RGBA) { doTest(3, 4, CVTCODE(YUV2RGB)); }
+OCL_TEST_P(CvtColor, YUV2BGRA) { doTest(3, 4, CVTCODE(YUV2BGR)); }
// RGB <-> YCrCb
-OCL_TEST_P(CvtColor, RGB2YCrCb)
-{
- doTest(3, 3, CVTCODE(RGB2YCrCb));
-}
-OCL_TEST_P(CvtColor, BGR2YCrCb)
-{
- doTest(3, 3, CVTCODE(BGR2YCrCb));
-}
-OCL_TEST_P(CvtColor, RGBA2YCrCb)
-{
- doTest(4, 3, CVTCODE(RGB2YCrCb));
-}
-OCL_TEST_P(CvtColor, BGRA2YCrCb)
-{
- doTest(4, 3, CVTCODE(BGR2YCrCb));
-}
-OCL_TEST_P(CvtColor, YCrCb2RGB)
-{
- doTest(3, 3, CVTCODE(YCrCb2RGB));
-}
-OCL_TEST_P(CvtColor, YCrCb2BGR)
-{
- doTest(3, 3, CVTCODE(YCrCb2BGR));
-}
-OCL_TEST_P(CvtColor, YCrCb2RGBA)
-{
- doTest(3, 4, CVTCODE(YCrCb2RGB));
-}
-OCL_TEST_P(CvtColor, YCrCb2BGRA)
-{
- doTest(3, 4, CVTCODE(YCrCb2BGR));
-}
+OCL_TEST_P(CvtColor, RGB2YCrCb) { doTest(3, 3, CVTCODE(RGB2YCrCb)); }
+OCL_TEST_P(CvtColor, BGR2YCrCb) { doTest(3, 3, CVTCODE(BGR2YCrCb)); }
+OCL_TEST_P(CvtColor, RGBA2YCrCb) { doTest(4, 3, CVTCODE(RGB2YCrCb)); }
+OCL_TEST_P(CvtColor, BGRA2YCrCb) { doTest(4, 3, CVTCODE(BGR2YCrCb)); }
+OCL_TEST_P(CvtColor, YCrCb2RGB) { doTest(3, 3, CVTCODE(YCrCb2RGB)); }
+OCL_TEST_P(CvtColor, YCrCb2BGR) { doTest(3, 3, CVTCODE(YCrCb2BGR)); }
+OCL_TEST_P(CvtColor, YCrCb2RGBA) { doTest(3, 4, CVTCODE(YCrCb2RGB)); }
+OCL_TEST_P(CvtColor, YCrCb2BGRA) { doTest(3, 4, CVTCODE(YCrCb2BGR)); }
// RGB <-> XYZ
-OCL_TEST_P(CvtColor, RGB2XYZ)
-{
- doTest(3, 3, CVTCODE(RGB2XYZ));
-}
-OCL_TEST_P(CvtColor, BGR2XYZ)
-{
- doTest(3, 3, CVTCODE(BGR2XYZ));
-}
-OCL_TEST_P(CvtColor, RGBA2XYZ)
-{
- doTest(4, 3, CVTCODE(RGB2XYZ));
-}
-OCL_TEST_P(CvtColor, BGRA2XYZ)
-{
- doTest(4, 3, CVTCODE(BGR2XYZ));
-}
+OCL_TEST_P(CvtColor, RGB2XYZ) { doTest(3, 3, CVTCODE(RGB2XYZ)); }
+OCL_TEST_P(CvtColor, BGR2XYZ) { doTest(3, 3, CVTCODE(BGR2XYZ)); }
+OCL_TEST_P(CvtColor, RGBA2XYZ) { doTest(4, 3, CVTCODE(RGB2XYZ)); }
+OCL_TEST_P(CvtColor, BGRA2XYZ) { doTest(4, 3, CVTCODE(BGR2XYZ)); }
-OCL_TEST_P(CvtColor, XYZ2RGB)
-{
- doTest(3, 3, CVTCODE(XYZ2RGB));
-}
-OCL_TEST_P(CvtColor, XYZ2BGR)
-{
- doTest(3, 3, CVTCODE(XYZ2BGR));
-}
-OCL_TEST_P(CvtColor, XYZ2RGBA)
-{
- doTest(3, 4, CVTCODE(XYZ2RGB));
-}
-OCL_TEST_P(CvtColor, XYZ2BGRA)
-{
- doTest(3, 4, CVTCODE(XYZ2BGR));
-}
+OCL_TEST_P(CvtColor, XYZ2RGB) { doTest(3, 3, CVTCODE(XYZ2RGB)); }
+OCL_TEST_P(CvtColor, XYZ2BGR) { doTest(3, 3, CVTCODE(XYZ2BGR)); }
+OCL_TEST_P(CvtColor, XYZ2RGBA) { doTest(3, 4, CVTCODE(XYZ2RGB)); }
+OCL_TEST_P(CvtColor, XYZ2BGRA) { doTest(3, 4, CVTCODE(XYZ2BGR)); }
// YUV -> RGBA_NV12
}
};
-OCL_TEST_P(CvtColor_YUV420, YUV2RGBA_NV12)
-{
- doTest(1, 4, CV_YUV2RGBA_NV12);
-}
-
-OCL_TEST_P(CvtColor_YUV420, YUV2BGRA_NV12)
-{
- doTest(1, 4, CV_YUV2BGRA_NV12);
-}
-
-OCL_TEST_P(CvtColor_YUV420, YUV2RGB_NV12)
-{
- doTest(1, 3, CV_YUV2RGB_NV12);
-}
-
-OCL_TEST_P(CvtColor_YUV420, YUV2BGR_NV12)
-{
- doTest(1, 3, CV_YUV2BGR_NV12);
-}
+OCL_TEST_P(CvtColor_YUV420, YUV2RGBA_NV12) { doTest(1, 4, CV_YUV2RGBA_NV12); }
+OCL_TEST_P(CvtColor_YUV420, YUV2BGRA_NV12) { doTest(1, 4, CV_YUV2BGRA_NV12); }
+OCL_TEST_P(CvtColor_YUV420, YUV2RGB_NV12) { doTest(1, 3, CV_YUV2RGB_NV12); }
+OCL_TEST_P(CvtColor_YUV420, YUV2BGR_NV12) { doTest(1, 3, CV_YUV2BGR_NV12); }
INSTANTIATE_TEST_CASE_P(OCL_ImgProc, CvtColor,
testing::Combine(