加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
eco_unittest.cc 10.05 KB
一键复制 编辑 原始数据 按行查看 历史
dou 提交于 2024-01-10 18:17 . add notes
// Copyright 2005, Google Inc.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
// * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
// * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
// * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// A sample program demonstrating using Google C++ testing framework.
//
// Author: wan@google.com (Zhanyong Wan)
#include "gtest/gtest.h"
#include "ffttools.hpp"
#include "debug.hpp"
#ifdef USE_FFTW
#include <fftw3.h>
#endif
namespace
{
TEST(ffttoolsTest, dft_float)
{
int N = 5;
cv::Mat_<float> mat_float(N, 2*N, CV_32FC1);
for (int j = 0; j < mat_float.rows; j++)
for (int i = 0; i < mat_float.cols; i++)
mat_float.at<float>(j, i) = i + j * mat_float.cols;
//showmat1channels(mat_float, 2);
double timer = (double)cv::getTickCount();
float timedft = 0;
cv::Mat res = eco::dft(mat_float)/(mat_float.rows * mat_float.cols);
//printMat(res);
//showmat2channels(res, 2);
timedft = ((double)cv::getTickCount() - timer) / cv::getTickFrequency();
debug("dft time: %f", timedft);
timer = (double)cv::getTickCount();
res = eco::dft(res, 1);
//showmat2channels(res, 2);
timedft = ((double)cv::getTickCount() - timer) / cv::getTickFrequency();
debug("dft time: %f", timedft);
}
TEST(ffttoolsTest, dft_double)
{
int N = 5;
cv::Mat_<double> mat_double(N, 2*N, CV_64FC1);
for (int j = 0; j < mat_double.rows; j++)
for (int i = 0; i < mat_double.cols; i++)
mat_double.at<double>(j, i) = i + j * mat_double.cols;
//showmat1channels(mat_double, 3);
double timer = (double)cv::getTickCount();
float timedft = 0;
cv::Mat res = eco::dft(mat_double)/(mat_double.rows * mat_double.cols);
//showmat2channels(res, 3);
timedft = ((double)cv::getTickCount() - timer) / cv::getTickFrequency();
debug("dft_d time: %f", timedft);
timer = (double)cv::getTickCount();
res = eco::dft(res, 1);
//showmat2channels(res, 3);
timedft = ((double)cv::getTickCount() - timer) / cv::getTickFrequency();
debug("dft_d time: %f", timedft);
}
/*
TEST(ffttoolsTest, fftshift)
{
cv::Mat_<float> mat_float(10, 10, CV_32FC1);
for (int j = 0; j < mat_float.rows; j++)
for (int i = 0; i < mat_float.cols; i++)
mat_float.at<float>(j, i) = i + j * mat_float.cols;
debug("channels: %d", mat_float.channels());
showmat1channels(mat_float, 2);
cv::Mat res;
res = eco::fftshift(mat_float);
showmat1channels(res, 2);
res = eco::dft(mat_float, 1);
showmat2channels(res, 2);
res = eco::fftshift(res);
showmat2channels(res, 2);
}
TEST(ffttoolsTest, fftshift)
{
cv::Mat_<double> mat_double(10, 10, CV_32FC1);
for (int j = 0; j < mat_double.rows; j++)
for (int i = 0; i < mat_double.cols; i++)
mat_double.at<double>(j, i) = i + j * mat_double.cols;
debug("channels: %d", mat_double.channels());
showmat1channels(mat_double, 3);
cv::Mat res;
res = eco::fftshift(mat_double);
showmat1channels(res, 3);
res = eco::dft_d(mat_double, 1);
showmat2channels(res, 3);
res = eco::fftshift(res);
showmat2channels(res, 3);
}
TEST(ffttoolsTest, complexDotDivision)
{
cv::Mat mat_float(10, 10, CV_32FC2);
for (int j = 0; j < mat_float.rows; j++)
for (int i = 0; i < mat_float.cols; i++)
{
mat_float.at<cv::Vec2f>(j, i)[0] = i + j * mat_float.cols;
mat_float.at<cv::Vec2f>(j, i)[1] = i + j * mat_float.cols;
}
debug("channels: %d", mat_float.channels());
showmat2channels(mat_float, 2);
cv::Mat mat_float1(10, 10, CV_32FC2);
for (int j = 0; j < mat_float1.rows; j++)
for (int i = 0; i < mat_float1.cols; i++)
{
mat_float1.at<cv::Vec2f>(j, i)[0] = i + j * mat_float1.cols;
mat_float1.at<cv::Vec2f>(j, i)[1] = -i;
}
debug("channels: %d", mat_float1.channels());
showmat2channels(mat_float1, 2);
cv::Mat res;
res = eco::complexDotDivision(mat_float, mat_float1);
showmat2channels(res, 2);
}
TEST(ffttoolsTest, complexMatrixMultiplication)
{
cv::Mat mat_float(10, 10, CV_32FC2);
for (int j = 0; j < mat_float.rows; j++)
for (int i = 0; i < mat_float.cols; i++)
{
mat_float.at<cv::Vec2f>(j, i)[0] = i + j * mat_float.cols;
mat_float.at<cv::Vec2f>(j, i)[1] = i + j * mat_float.cols;
}
debug("channels: %d", mat_float.channels());
showmat2channels(mat_float, 2);
cv::Mat mat_float1(10, 10, CV_32FC2);
for (int j = 0; j < mat_float1.rows; j++)
for (int i = 0; i < mat_float1.cols; i++)
{
mat_float1.at<cv::Vec2f>(j, i)[0] = i + j * mat_float1.cols;
mat_float1.at<cv::Vec2f>(j, i)[1] = -i;
}
debug("channels: %d", mat_float1.channels());
showmat2channels(mat_float1, 2);
cv::Mat res;
res = eco::complexMatrixMultiplication(mat_float, mat_float1);
showmat2channels(res, 2);
}
TEST(ffttoolsTest, mat_sum_f)
{
cv::Mat_<float> mat_float(10, 10, CV_32FC1);
for (int j = 0; j < mat_float.rows; j++)
for (int i = 0; i < mat_float.cols; i++)
mat_float.at<float>(j, i) = i + j * mat_float.cols;
EXPECT_EQ(4950, eco::mat_sum_f(mat_float));
}
TEST(ffttoolsTest, mat_sum_d)
{
cv::Mat_<double> mat_double(10, 10, CV_64FC1);
for (int j = 0; j < mat_double.rows; j++)
for (int i = 0; i < mat_double.cols; i++)
mat_double.at<double>(j, i) = i + j * mat_double.cols;
EXPECT_EQ(4950, eco::mat_sum_d(mat_double));
}
TEST(ffttoolsTest, rot90)
{
cv::Mat_<float> mat_float(10, 10, CV_32FC1);
for (int j = 0; j < mat_float.rows; j++)
for (int i = 0; i < mat_float.cols; i++)
mat_float.at<float>(j, i) = i + j * mat_float.cols;
showmat1channels(mat_float, 2);
debug("==============");
eco::rot90(mat_float, 1);
showmat1channels(mat_float, 2);
debug("==============");
eco::rot90(mat_float, 2);
showmat1channels(mat_float, 2);
debug("==============");
eco::rot90(mat_float, 3);
showmat1channels(mat_float, 2);
}
TEST(ffttoolsTest, complexConvolution)
{
cv::Mat mat_float(14, 14, CV_32FC2);
for (int j = 0; j < mat_float.rows; j++)
for (int i = 0; i < mat_float.cols; i++)
{
mat_float.at<cv::Vec2f>(j, i)[0] = i + j * mat_float.cols;
mat_float.at<cv::Vec2f>(j, i)[1] = i + j * mat_float.cols;
}
debug("channels: %d", mat_float.channels());
showmat2channels(mat_float, 2);
cv::Mat mat_float1(9, 9, CV_32FC2);
for (int j = 0; j < mat_float1.rows; j++)
for (int i = 0; i < mat_float1.cols; i++)
{
mat_float1.at<cv::Vec2f>(j, i)[0] = i + j * mat_float1.cols;
mat_float1.at<cv::Vec2f>(j, i)[1] = -i;
}
debug("channels: %d", mat_float1.channels());
showmat2channels(mat_float1, 2);
cv::Mat res;
res = eco::complexConvolution(mat_float, mat_float1, 0);
showmat2channels(res, 2);
res = eco::complexConvolution(mat_float, mat_float1, 1);
showmat2channels(res, 2);
}
TEST(debug, copyTo_clone_Difference)
{
copyTo_clone_Difference();
}
*/
TEST(ffttoolsTest, complexDotMultiplication)
{
int N = 5;
cv::Mat mat_float(N, N*2, CV_32FC2);
for (int j = 0; j < mat_float.rows; j++)
for (int i = 0; i < mat_float.cols; i++)
{
mat_float.at<cv::Vec2f>(j, i)[0] = i + j * mat_float.cols;
mat_float.at<cv::Vec2f>(j, i)[1] = i + j * mat_float.cols;
}
//showmat2channels(mat_float, 2);
cv::Mat mat_float1(N, N*2, CV_32FC2);
for (int j = 0; j < mat_float1.rows; j++)
for (int i = 0; i < mat_float1.cols; i++)
{
mat_float1.at<cv::Vec2f>(j, i)[0] = i + j * mat_float1.cols;
mat_float1.at<cv::Vec2f>(j, i)[1] = -i;
}
//showmat2channels(mat_float1, 2);
// complexDotMultiplicationCPU
cv::Mat res;
res = eco::complexDotMultiplicationCPU(mat_float, mat_float1);
int iter = 70;
double timer = (double)cv::getTickCount();
float timedft = 0;
while (iter > 0)
{
res = eco::complexDotMultiplicationCPU(mat_float, mat_float1);
iter--;
}
timedft = ((double)cv::getTickCount() - timer) / cv::getTickFrequency();
debug("complexDotMultiplicationCPU time: %f", timedft);
//showmat2channels(res, 2);
// complexDotMultiplicationSIMD
#ifdef USE_SIMD
res = eco::complexDotMultiplicationSIMD(mat_float, mat_float1);
iter = 70;
timer = (double)cv::getTickCount();
while (iter > 0)
{
res = eco::complexDotMultiplicationSIMD(mat_float, mat_float1);
iter--;
}
timedft = ((double)cv::getTickCount() - timer) / cv::getTickFrequency();
debug("complexDotMultiplicationSIMD time: %f", timedft);
//showmat2channels(res, 2);
#endif
/*
#ifdef USE_CUDA
cv::cuda::setDevice(0);
debug("%d", cv::cuda::getDevice());
//res = eco::complexDotMultiplicationGPU(mat_float, mat_float1);
iter = 1;
timer = (double)cv::getTickCount();
while (iter > 0)
{
res = eco::complexDotMultiplicationGPU(mat_float, mat_float1);
iter--;
}
timedft = ((double)cv::getTickCount() - timer) / cv::getTickFrequency();
debug("complexDotMultiplicationGPU time: %f", timedft);
//showmat2channels(res, 2);
#endif
*/
}//TEST
TEST(matReferenceTest, matReferenceTest)
{
eco::matReferenceTest();
}
} //namespace
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化