打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
OpenCV-DFT最优尺寸cv::getOptimalDFTSize

作者:翟天保Steven
版权声明:著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处

函数原型

int getOptimalDFTSize(int vecsize);

参数说明

  1. int类型的vecsize,向量尺寸,一般是图片的宽或高。

测试代码

#include<iostream>
#include<opencv2/opencv.hpp>
#include<ctime>
using namespace std;
using namespace cv;

cv::Mat image_make_border(cv::Mat &src);

int main(void)
{
Mat test = imread("liu.jpg", 0);
cv::Mat result=image_make_border(test);

imshow("original", test);
imshow("result", result/255);
waitKey(0);
system("pause");
return 0;
}

// 图像边界处理
cv::Mat image_make_border(cv::Mat &src)
{
cout << "src row:" << src.rows << endl;
cout << "src col:" << src.cols << endl;
int w = cv::getOptimalDFTSize(src.cols); // 获取DFT变换的最佳宽度
int h = cv::getOptimalDFTSize(src.rows); // 获取DFT变换的最佳高度
cout << "w:" << w << endl;
cout << "h:" << h << endl;
cv::Mat padded;
// 常量法扩充图像边界,常量 = 0
cv::copyMakeBorder(src, padded, 0, h - src.rows, 0, w - src.cols, cv::BORDER_CONSTANT, cv::Scalar::all(0));
padded.convertTo(padded, CV_32FC1);

return padded;
}

测试效果

图1 原图
图2 扩充后图像
图3 尺寸变化

       该函数可以自动计算最适合进行离散傅里叶变换的图像尺寸大小,从而提高计算速度;从图中可以看出,宽的尺寸非常合适,而高需要扩展到4096,从而多了下方的黑线区域,扩展的数值由copyMakeBorder函数决定,后续会介绍该函数~

       如果文章帮助到你了,可以点个赞让我知道,我会很快乐~加油!

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
数字图像处理,相位相关算法解决图像的刚性平移问题
opencv中Mat使用,很好,顶!
基于distanceTransform-距离变换的区域中心提取
opencv之光照补偿和去除光照
OpenCV的基本矩阵操作与示例
cvNormalize函数
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服