c++opencv实现频率域图像增强


好的,下面是一个使用 C++ 和 OpenCV 实现频率域图像增强的示例代码。这个例子展示了如何使用傅里叶变换对图像进行频域滤波,具体来说是高通滤波器。 ```cpp #include <opencv2/opencv.hpp> #include <iostream> // 高通滤波器函数 void highPassFilter(cv::Mat &input, cv::Mat &output, int cutoff) { // 计算中心位置 int cx = input.cols / 2; int cy = input.rows / 2; // 创建与输入相同大小的掩码 cv::Mat mask = cv::Mat::zeros(input.size(), CV_32F); // 设置高通滤波器 for (int i = 0; i < input.rows; ++i) { for (int j = 0; j < input.cols; ++j) { double distance = std::sqrt(std::pow(i - cy, 2) + std::pow(j - cx, 2)); if (distance > cutoff) { mask.at<float>(i, j) = 1.0; } } } // 应用掩码 cv::multiply(input, mask, output); } int main() { // 读取图像 cv::Mat image = cv::imread("input.jpg", cv::IMREAD_GRAYSCALE); if (image.empty()) { std::cerr << "无法读取图像" << std::endl; return -1; } // 将图像转换为浮点类型 cv::Mat floatImage; image.convertTo(floatImage, CV_32F); // 进行傅里叶变换 cv::Mat complexImage; cv::dft(floatImage, complexImage, cv::DFT_COMPLEX_OUTPUT); // 将频谱移到图像中心 cv::Mat shiftedSpectrum; cv::dft(complexImage, shiftedSpectrum, cv::DFT_SCALE | cv::DFT_CENTER_ZERO); // 应用高通滤波器 cv::Mat filteredSpectrum; highPassFilter(shiftedSpectrum, filteredSpectrum, 30); // 将频谱移回原位 cv::Mat unshiftedSpectrum; cv::dft(filteredSpectrum, unshiftedSpectrum, cv::DFT_INVERSE | cv::DFT_REAL_OUTPUT); // 将结果转换回8位图像 cv::Mat result; unshiftedSpectrum.convertTo(result, CV_8U); // 显示结果 cv::imshow("原始图像", image); cv::imshow("增强后的图像", result); cv::waitKey(0); // 保存结果 cv::imwrite("enhanced_image.jpg", result); return 0; } ``` 额外需要注意的逻辑点 1. 边界处理:在创建掩码时,确保边界条件处理得当,避免越界访问。 2. 参数选择:`cutoff` 参数的选择会影响滤波效果,需要根据实际需求进行调整。 3. 性能优化:对于大图像,可以考虑使用多线程或 GPU 加速来提高处理速度。 希望这段代码对你有帮助!如果有任何问题,欢迎随时提问。 [2024-12-07 12:24:59 | AI写代码神器 | 724点数解答]
- import math class ball: """ 实现 def __init__(self, radius) 函数, 他有一个参数radius, 并为对象初始化一个变量self.radius """ """ 实现 def surface_area(self) 函数, 通过self.radius计算球的表面积, 并将这个表面积返回 """ """ 实现 def volume(self) 函数, 通过self.radius计算球的体积, 并将这个体积返回 """ """ 在评测文件中将这样调用这个类 ball = ball(eval(input())) print("球的半径:{:.2f}".format(ball.radius)) print("球的表面积:{:.2f}".format(ball.surface_area())) print("球的体积:{:(261点数解答 | 2024-11-28 21:19:39)175
- opencv.js 识别图片(824点数解答 | 2024-03-22 16:22:16)156
- opencv.js 识别图片中的电梯轮廓(1193点数解答 | 2024-03-22 16:23:32)175
- #include <random> #include <ctime> using namespace std; #include <opencv2\\opencv.hpp> #include <opencv2\\features2d.hpp> using namespace cv; vector<point2f> pts; // 代码生成的点 const point2f center(200, 200); // 圆心 const float std_r = 100; // 标准半径 // 从 [0, 360) 生成圆周上的点, 都是利用 pt_start 旋转, 再加上一点随机偏移 for (int i = 0; i < 360; i += 8) { default_random_engine e(time(nullptr) + rand()); // 随机 engine uniform_real_distribution<float> u(-8.0f, 8.0f); const float r = std_r + u(e); // 半径 + 误差(29点数解答 | 2024-11-06 23:40:42)148
- 帮我写一段PS脚本,用于图片的美颜,增强 PS版本为Mac版 2019CC(309点数解答 | 2025-02-22 20:49:53)99
- 帮我写一段PS脚本,用于图片的美颜,增强 PS版本为Adobe Photoshop 版本: 20.0.6 20190724.r.80 2019/07/24: 1207344 x64(192点数解答 | 2025-02-28 11:01:21)134
- 帮我写一段PS脚本,用于图片的美颜,增强 PS版本为Adobe Photoshop 版本: 20.0.6 20190724.r.80 2019/07/24: 1207344 x64(680点数解答 | 2025-02-28 14:43:51)123
- 循环点亮 led 灯: (1) 使用定时器to 的方式 1,实现 8个 led 由上至下间隔 1s 流动,其中每个 led 亮 0.5s,灭0.5s,一直重复。。 (2) 使用定时器 to 的方式 1,实现 8个 led 逐个点亮,间隔 1s,一直重复。。(1193点数解答 | 2024-12-27 15:10:29)173
- 在ios开发中,写一个完整的代理,包括声明、实现(268点数解答 | 2023-11-08 00:39:55)184
- 作为javascript开发,简述如何使用animation 实现⾃定义动画 ?(333点数解答 | 2023-11-09 01:50:07)173
- 编写 js 代码,使用 for 循环,实现 1 到 100 相加,将结果输出到页面。(240点数解答 | 2024-05-20 22:11:29)238
- 编写 js 代码,使用 while 循环,实现 1 到 100 相加,将结果输出到页面。(47点数解答 | 2024-05-20 22:16:48)222