This source file includes following definitions.
- PARAM_TEST_CASE
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- SetUp
 
- mosaic
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- CUDA_TEST_P
 
- PARAM_TEST_CASE
 
- CUDA_TEST_P
 
#include "test_precomp.hpp"
#ifdef HAVE_CUDA
using namespace cvtest;
PARAM_TEST_CASE(CvtColor, cv::cuda::DeviceInfo, cv::Size, MatDepth, UseRoi)
{
    cv::cuda::DeviceInfo devInfo;
    cv::Size size;
    int depth;
    bool useRoi;
    cv::Mat img;
    virtual void SetUp()
    {
        devInfo = GET_PARAM(0);
        size = GET_PARAM(1);
        depth = GET_PARAM(2);
        useRoi = GET_PARAM(3);
        cv::cuda::setDevice(devInfo.deviceID());
        img = randomMat(size, CV_MAKE_TYPE(depth, 3), 0.0, depth == CV_32F ? 1.0 : 255.0);
    }
};
CUDA_TEST_P(CvtColor, BGR2RGB)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR2RGBA)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2RGBA);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2RGBA);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR2BGRA)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2BGRA);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2BGRA);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGRA2RGB)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGRA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGRA2RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGRA2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGRA2BGR)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGRA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGRA2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGRA2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGRA2RGBA)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGRA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGRA2RGBA);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGRA2RGBA);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR2GRAY)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2GRAY);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, RGB2GRAY)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2GRAY);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, GRAY2BGR)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2GRAY);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_GRAY2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_GRAY2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, GRAY2BGRA)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2GRAY);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_GRAY2BGRA, 4);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_GRAY2BGRA, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGRA2GRAY)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGRA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGRA2GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGRA2GRAY);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, RGBA2GRAY)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGBA2GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGBA2GRAY);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, BGR2BGR565)
{
    if (depth != CV_8U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2BGR565);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2BGR565);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, RGB2BGR565)
{
    if (depth != CV_8U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2BGR565);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2BGR565);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5652BGR)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR565);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5652BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5652BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5652RGB)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR565);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5652RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5652RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGRA2BGR565)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGRA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGRA2BGR565);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGRA2BGR565);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, RGBA2BGR565)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGBA2BGR565);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGBA2BGR565);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5652BGRA)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR565);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5652BGRA, 4);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5652BGRA, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5652RGBA)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR565);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5652RGBA, 4);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5652RGBA, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, GRAY2BGR565)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2GRAY);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_GRAY2BGR565);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_GRAY2BGR565);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5652GRAY)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR565);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5652GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5652GRAY);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR2BGR555)
{
    if (depth != CV_8U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2BGR555);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2BGR555);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, RGB2BGR555)
{
    if (depth != CV_8U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2BGR555);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2BGR555);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5552BGR)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR555);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5552BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5552BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5552RGB)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR555);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5552RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5552RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGRA2BGR555)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGRA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGRA2BGR555);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGRA2BGR555);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, RGBA2BGR555)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGBA2BGR555);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGBA2BGR555);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5552BGRA)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR555);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5552BGRA, 4);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5552BGRA, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5552RGBA)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR555);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5552RGBA, 4);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5552RGBA, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, GRAY2BGR555)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2GRAY);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_GRAY2BGR555);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_GRAY2BGR555);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR5552GRAY)
{
    if (depth != CV_8U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGR555);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR5552GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR5552GRAY);
    EXPECT_MAT_NEAR(dst_gold, dst, 0.0);
}
CUDA_TEST_P(CvtColor, BGR2XYZ)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2XYZ);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2XYZ);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, RGB2XYZ)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2XYZ);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2XYZ);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, BGR2XYZ4)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2XYZ, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2XYZ);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, 1e-5);
}
CUDA_TEST_P(CvtColor, BGRA2XYZ4)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2BGRA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2XYZ, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2XYZ);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, 1e-5);
}
CUDA_TEST_P(CvtColor, XYZ2BGR)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2XYZ);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_XYZ2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_XYZ2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, XYZ2RGB)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2XYZ);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_XYZ2RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_XYZ2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, XYZ42BGR)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2XYZ);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_XYZ2BGR);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_XYZ2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, XYZ42BGRA)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2XYZ);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_XYZ2BGR, 4);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_XYZ2BGR, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, BGR2YCrCb)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2YCrCb);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2YCrCb);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGB2YCrCb)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2YCrCb);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2YCrCb);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, BGR2YCrCb4)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2YCrCb, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2YCrCb);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGBA2YCrCb4)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2YCrCb, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2YCrCb);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, YCrCb2BGR)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2YCrCb);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_YCrCb2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_YCrCb2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, YCrCb2RGB)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2YCrCb);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_YCrCb2RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_YCrCb2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, YCrCb42RGB)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2YCrCb);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_YCrCb2RGB);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_YCrCb2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, YCrCb42RGBA)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2YCrCb);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_YCrCb2RGB, 4);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_YCrCb2RGB, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, BGR2HSV)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2HSV);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2HSV);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGB2HSV)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HSV);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HSV);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGB2HSV4)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HSV, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HSV);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGBA2HSV4)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HSV, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HSV);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, BGR2HLS)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2HLS);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2HLS);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGB2HLS)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HLS);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HLS);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGB2HLS4)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HLS, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HLS);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGBA2HLS4)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HLS, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HLS);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HSV2BGR)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HSV);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HSV2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HSV2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HSV2RGB)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HSV);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HSV2RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HSV2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HSV42BGR)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HSV);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HSV2BGR);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HSV2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HSV42BGRA)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HSV);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HSV2BGR, 4);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HSV2BGR, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HLS2BGR)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HLS);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HLS2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HLS2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HLS2RGB)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HLS);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HLS2RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HLS2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HLS42RGB)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HLS);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HLS2RGB);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HLS2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HLS42RGBA)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HLS);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HLS2RGB, 4);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HLS2RGB, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, BGR2HSV_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2HSV_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2HSV_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGB2HSV_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HSV_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HSV_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGB2HSV4_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HSV_FULL, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HSV_FULL);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGBA2HSV4_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HSV_FULL, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HSV_FULL);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, BGR2HLS_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2HLS_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2HLS_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGB2HLS_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HLS_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HLS_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGB2HLS4_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HLS_FULL, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HLS_FULL);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, RGBA2HLS4_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2HLS_FULL, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2HLS_FULL);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HSV2BGR_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HSV_FULL);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HSV2BGR_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HSV2BGR_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HSV2RGB_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HSV_FULL);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HSV2RGB_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HSV2RGB_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HSV42RGB_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HSV_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HSV2RGB_FULL);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HSV2RGB_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HSV42RGBA_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HSV_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HSV2RGB_FULL, 4);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HSV2RGB_FULL, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HLS2BGR_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HLS_FULL);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HLS2BGR_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HLS2BGR_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HLS2RGB_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HLS_FULL);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HLS2RGB_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HLS2RGB_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HLS42RGB_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HLS_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HLS2RGB_FULL);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HLS2RGB_FULL);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, HLS42RGBA_FULL)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2HLS_FULL);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_HLS2RGB_FULL, 4);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_HLS2RGB_FULL, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_32F ? 1e-2 : 1);
}
CUDA_TEST_P(CvtColor, BGR2YUV)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2YUV);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2YUV);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, RGB2YUV)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2YUV);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2YUV);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, YUV2BGR)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2YUV);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_YUV2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_YUV2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, YUV42BGR)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2YUV);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_YUV2BGR);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_YUV2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, YUV42BGRA)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2YUV);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_YUV2BGR, 4);
    cv::Mat channels[4];
    cv::split(src, channels);
    channels[3] = cv::Mat(src.size(), depth, cv::Scalar::all(0));
    cv::merge(channels, 4, src);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_YUV2BGR, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, YUV2RGB)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_RGB2YUV);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_YUV2RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_YUV2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, 1e-5);
}
CUDA_TEST_P(CvtColor, BGR2YUV4)
{
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2YUV, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2YUV);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, 1e-5);
}
CUDA_TEST_P(CvtColor, RGBA2YUV4)
{
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2YUV, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2YUV);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, 1e-5);
}
CUDA_TEST_P(CvtColor, BGR2Lab)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2Lab);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2Lab);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, RGB2Lab)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2Lab);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2Lab);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, BGRA2Lab4)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2Lab, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2Lab);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, LBGR2Lab)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_LBGR2Lab);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_LBGR2Lab);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, LRGB2Lab)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_LRGB2Lab);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_LRGB2Lab);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, LBGRA2Lab4)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_LBGR2Lab, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_LBGR2Lab);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, Lab2BGR)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Lab);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Lab2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Lab2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-5);
}
CUDA_TEST_P(CvtColor, Lab2RGB)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Lab);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Lab2RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Lab2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-5);
}
CUDA_TEST_P(CvtColor, Lab2BGRA)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Lab);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Lab2BGR, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Lab2BGR, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-5);
}
CUDA_TEST_P(CvtColor, Lab2LBGR)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Lab);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Lab2LBGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Lab2LBGR);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-5);
}
CUDA_TEST_P(CvtColor, Lab2LRGB)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Lab);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Lab2LRGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Lab2LRGB);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-5);
}
CUDA_TEST_P(CvtColor, Lab2LRGBA)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Lab);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Lab2LRGB, 4);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Lab2LRGB, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-5);
}
CUDA_TEST_P(CvtColor, BGR2Luv)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2Luv);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2Luv);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, RGB2Luv)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGB2Luv);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGB2Luv);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, BGRA2Luv4)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BGR2Luv, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGR2Luv);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, LBGR2Luv)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_LBGR2Luv);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_LBGR2Luv);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, LRGB2Luv)
{
    if (depth == CV_16U)
        return;
    cv::Mat src = img;
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_LRGB2Luv);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_LRGB2Luv);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, LBGRA2Luv4)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2RGBA);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_LBGR2Luv, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_LBGR2Luv);
    cv::Mat h_dst(dst);
    cv::Mat channels[4];
    cv::split(h_dst, channels);
    cv::merge(channels, 3, h_dst);
    EXPECT_MAT_NEAR(dst_gold, h_dst, depth == CV_8U ? 1 : 1e-3);
}
CUDA_TEST_P(CvtColor, Luv2BGR)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Luv);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Luv2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Luv2BGR);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-4);
}
CUDA_TEST_P(CvtColor, Luv2RGB)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Luv);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Luv2RGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Luv2RGB);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-4);
}
CUDA_TEST_P(CvtColor, Luv2BGRA)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Luv);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Luv2BGR, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Luv2BGR, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-4);
}
CUDA_TEST_P(CvtColor, Luv2LBGR)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Luv);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Luv2LBGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Luv2LBGR);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-4);
}
CUDA_TEST_P(CvtColor, Luv2LRGB)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Luv);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Luv2LRGB);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Luv2LRGB);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-4);
}
CUDA_TEST_P(CvtColor, Luv2LRGBA)
{
    if (depth == CV_16U)
        return;
    cv::Mat src;
    cv::cvtColor(img, src, cv::COLOR_BGR2Luv);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_Luv2LRGB, 4);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_Luv2LRGB, 4);
    EXPECT_MAT_NEAR(dst_gold, dst, depth == CV_8U ? 1 : 1e-4);
}
#if defined (CUDA_VERSION) && (CUDA_VERSION >= 5000)
CUDA_TEST_P(CvtColor, RGBA2mRGBA)
{
    if (depth != CV_8U)
        return;
    cv::Mat src = randomMat(size, CV_MAKE_TYPE(depth, 4));
    cv::cuda::GpuMat dst = createMat(src.size(), src.type(), useRoi);
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_RGBA2mRGBA);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_RGBA2mRGBA);
    EXPECT_MAT_NEAR(dst_gold, dst, 1);
}
#endif 
CUDA_TEST_P(CvtColor, BayerBG2BGR)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerBG2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerBG2BGR);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 0);
}
CUDA_TEST_P(CvtColor, BayerBG2BGR4)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerBG2BGR, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerBG2BGR);
    cv::Mat dst4(dst);
    cv::Mat dst3;
    cv::cvtColor(dst4, dst3, cv::COLOR_BGRA2BGR);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst3(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 0);
}
CUDA_TEST_P(CvtColor, BayerGB2BGR)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerGB2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerGB2BGR);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 0);
}
CUDA_TEST_P(CvtColor, BayerGB2BGR4)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerGB2BGR, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerGB2BGR);
    cv::Mat dst4(dst);
    cv::Mat dst3;
    cv::cvtColor(dst4, dst3, cv::COLOR_BGRA2BGR);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst3(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 0);
}
CUDA_TEST_P(CvtColor, BayerRG2BGR)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerRG2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerRG2BGR);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 0);
}
CUDA_TEST_P(CvtColor, BayerRG2BGR4)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerRG2BGR, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerRG2BGR);
    cv::Mat dst4(dst);
    cv::Mat dst3;
    cv::cvtColor(dst4, dst3, cv::COLOR_BGRA2BGR);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst3(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 0);
}
CUDA_TEST_P(CvtColor, BayerGR2BGR)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerGR2BGR);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerGR2BGR);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 0);
}
CUDA_TEST_P(CvtColor, BayerGR2BGR4)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerGR2BGR, 4);
    ASSERT_EQ(4, dst.channels());
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerGR2BGR);
    cv::Mat dst4(dst);
    cv::Mat dst3;
    cv::cvtColor(dst4, dst3, cv::COLOR_BGRA2BGR);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst3(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 0);
}
CUDA_TEST_P(CvtColor, BayerBG2Gray)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerBG2GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerBG2GRAY);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 2);
}
CUDA_TEST_P(CvtColor, BayerGB2Gray)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerGB2GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerGB2GRAY);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 2);
}
CUDA_TEST_P(CvtColor, BayerRG2Gray)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerRG2GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerRG2GRAY);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 2);
}
CUDA_TEST_P(CvtColor, BayerGR2Gray)
{
    if ((depth != CV_8U && depth != CV_16U) || useRoi)
        return;
    cv::Mat src = randomMat(size, depth);
    cv::cuda::GpuMat dst;
    cv::cuda::cvtColor(loadMat(src, useRoi), dst, cv::COLOR_BayerGR2GRAY);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BayerGR2GRAY);
    EXPECT_MAT_NEAR(dst_gold(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), dst(cv::Rect(1, 1, dst.cols - 2, dst.rows - 2)), 2);
}
INSTANTIATE_TEST_CASE_P(CUDA_ImgProc, CvtColor, testing::Combine(
    ALL_DEVICES,
    DIFFERENT_SIZES,
    testing::Values(MatDepth(CV_8U), MatDepth(CV_16U), MatDepth(CV_32F)),
    WHOLE_SUBMAT));
struct Demosaicing : testing::TestWithParam<cv::cuda::DeviceInfo>
{
    cv::cuda::DeviceInfo devInfo;
    virtual void SetUp()
    {
        devInfo = GetParam();
        cv::cuda::setDevice(devInfo.deviceID());
    }
    static void mosaic(const cv::Mat_<cv::Vec3b>& src, cv::Mat_<uchar>& dst, cv::Point firstRed)
    {
        dst.create(src.size());
        for (int y = 0; y < src.rows; ++y)
        {
            for (int x = 0; x < src.cols; ++x)
            {
                cv::Vec3b pix = src(y, x);
                cv::Point alternate;
                alternate.x = (x + firstRed.x) % 2;
                alternate.y = (y + firstRed.y) % 2;
                if (alternate.y == 0)
                {
                    if (alternate.x == 0)
                    {
                        
                        
                        dst(y, x) = pix[2];
                    }
                    else
                    {
                        
                        
                        dst(y, x) = pix[1];
                    }
                }
                else
                {
                    if (alternate.x == 0)
                    {
                        
                        
                        dst(y, x) = pix[1];
                    }
                    else
                    {
                        
                        
                        dst(y, x) = pix[0];
                    }
                }
            }
        }
    }
};
CUDA_TEST_P(Demosaicing, BayerBG2BGR)
{
    cv::Mat img = readImage("stereobm/aloe-L.png");
    ASSERT_FALSE(img.empty()) << "Can't load input image";
    cv::Mat_<uchar> src;
    mosaic(img, src, cv::Point(1, 1));
    cv::cuda::GpuMat dst;
    cv::cuda::demosaicing(loadMat(src), dst, cv::COLOR_BayerBG2BGR);
    EXPECT_MAT_SIMILAR(img, dst, 2e-2);
}
CUDA_TEST_P(Demosaicing, BayerGB2BGR)
{
    cv::Mat img = readImage("stereobm/aloe-L.png");
    ASSERT_FALSE(img.empty()) << "Can't load input image";
    cv::Mat_<uchar> src;
    mosaic(img, src, cv::Point(0, 1));
    cv::cuda::GpuMat dst;
    cv::cuda::demosaicing(loadMat(src), dst, cv::COLOR_BayerGB2BGR);
    EXPECT_MAT_SIMILAR(img, dst, 2e-2);
}
CUDA_TEST_P(Demosaicing, BayerRG2BGR)
{
    cv::Mat img = readImage("stereobm/aloe-L.png");
    ASSERT_FALSE(img.empty()) << "Can't load input image";
    cv::Mat_<uchar> src;
    mosaic(img, src, cv::Point(0, 0));
    cv::cuda::GpuMat dst;
    cv::cuda::demosaicing(loadMat(src), dst, cv::COLOR_BayerRG2BGR);
    EXPECT_MAT_SIMILAR(img, dst, 2e-2);
}
CUDA_TEST_P(Demosaicing, BayerGR2BGR)
{
    cv::Mat img = readImage("stereobm/aloe-L.png");
    ASSERT_FALSE(img.empty()) << "Can't load input image";
    cv::Mat_<uchar> src;
    mosaic(img, src, cv::Point(1, 0));
    cv::cuda::GpuMat dst;
    cv::cuda::demosaicing(loadMat(src), dst, cv::COLOR_BayerGR2BGR);
    EXPECT_MAT_SIMILAR(img, dst, 2e-2);
}
CUDA_TEST_P(Demosaicing, BayerBG2BGR_MHT)
{
    cv::Mat img = readImage("stereobm/aloe-L.png");
    ASSERT_FALSE(img.empty()) << "Can't load input image";
    cv::Mat_<uchar> src;
    mosaic(img, src, cv::Point(1, 1));
    cv::cuda::GpuMat dst;
    cv::cuda::demosaicing(loadMat(src), dst, cv::cuda::COLOR_BayerBG2BGR_MHT);
    EXPECT_MAT_SIMILAR(img, dst, 5e-3);
}
CUDA_TEST_P(Demosaicing, BayerGB2BGR_MHT)
{
    cv::Mat img = readImage("stereobm/aloe-L.png");
    ASSERT_FALSE(img.empty()) << "Can't load input image";
    cv::Mat_<uchar> src;
    mosaic(img, src, cv::Point(0, 1));
    cv::cuda::GpuMat dst;
    cv::cuda::demosaicing(loadMat(src), dst, cv::cuda::COLOR_BayerGB2BGR_MHT);
    EXPECT_MAT_SIMILAR(img, dst, 5e-3);
}
CUDA_TEST_P(Demosaicing, BayerRG2BGR_MHT)
{
    cv::Mat img = readImage("stereobm/aloe-L.png");
    ASSERT_FALSE(img.empty()) << "Can't load input image";
    cv::Mat_<uchar> src;
    mosaic(img, src, cv::Point(0, 0));
    cv::cuda::GpuMat dst;
    cv::cuda::demosaicing(loadMat(src), dst, cv::cuda::COLOR_BayerRG2BGR_MHT);
    EXPECT_MAT_SIMILAR(img, dst, 5e-3);
}
CUDA_TEST_P(Demosaicing, BayerGR2BGR_MHT)
{
    cv::Mat img = readImage("stereobm/aloe-L.png");
    ASSERT_FALSE(img.empty()) << "Can't load input image";
    cv::Mat_<uchar> src;
    mosaic(img, src, cv::Point(1, 0));
    cv::cuda::GpuMat dst;
    cv::cuda::demosaicing(loadMat(src), dst, cv::cuda::COLOR_BayerGR2BGR_MHT);
    EXPECT_MAT_SIMILAR(img, dst, 5e-3);
}
INSTANTIATE_TEST_CASE_P(CUDA_ImgProc, Demosaicing, ALL_DEVICES);
PARAM_TEST_CASE(SwapChannels, cv::cuda::DeviceInfo, cv::Size, UseRoi)
{
    cv::cuda::DeviceInfo devInfo;
    cv::Size size;
    bool useRoi;
    virtual void SetUp()
    {
        devInfo = GET_PARAM(0);
        size = GET_PARAM(1);
        useRoi = GET_PARAM(2);
        cv::cuda::setDevice(devInfo.deviceID());
    }
};
CUDA_TEST_P(SwapChannels, Accuracy)
{
    cv::Mat src = readImageType("stereobm/aloe-L.png", CV_8UC4);
    ASSERT_FALSE(src.empty());
    cv::cuda::GpuMat d_src = loadMat(src, useRoi);
    const int dstOrder[] = {2, 1, 0, 3};
    cv::cuda::swapChannels(d_src, dstOrder);
    cv::Mat dst_gold;
    cv::cvtColor(src, dst_gold, cv::COLOR_BGRA2RGBA);
    EXPECT_MAT_NEAR(dst_gold, d_src, 0.0);
}
INSTANTIATE_TEST_CASE_P(CUDA_ImgProc, SwapChannels, testing::Combine(
    ALL_DEVICES,
    DIFFERENT_SIZES,
    WHOLE_SUBMAT));
#endif