首页 最新 热门 推荐

  • 首页
  • 最新
  • 热门
  • 推荐

OpenCV-图像锐化

  • 25-03-03 21:21
  • 4524
  • 12877
blog.csdn.net

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

实现原理

       图像锐化(image sharpening)是补偿图像的轮廓,增强图像的边缘及灰度跳变的部分,使图像变得清晰,分为空间域处理和频域处理两类。图像锐化是为了突出图像上地物的边缘、轮廓,或某些线性目标要素的特征。这种滤波方法提高了地物边缘与周围像元之间的反差,因此也被称为边缘增强。

       锐化可通过拉普拉斯算子实现。拉普拉斯算子作为一个常见的二阶微分算子,放在二维图像中可以表示为:

\nabla^{2} f=\frac{\partial^{2} f}{\partial x^{2}}+\frac{\partial^{2} f}{\partial y^{2}}

       其x方向相当于:获取x+1点和x点的差值d1,获取x点和x-1点的差值d2,然后d1-d2。

       \quad \frac{\partial^{2} f}{\partial x^{2}}=f(x+1, y)+f(x-1, y)-2 f(x, y)

       y方向同理。

\frac{\partial^{2} f}{\partial y^{2}}=f(x, y+1)+f(x, y-1)-2 f(x, y)

       不难看出其3*3的模板为:

\begin{array}{|c|c|c|} \hline 0 & 1 & 0 \\ \hline 1 & -4 & 1 \\ \hline 0 & 1 & 0 \\ \hline \end{array}

       若考虑将模板45°旋转并叠加,还可得到:

\begin{array}{|c|c|c|} \hline 1 & 1 & 1 \\ \hline 1 & -8 & 1 \\ \hline 1 & 1 & 1 \\ \hline \end{array}

       基于上述原理,进行C++代码实现。

功能函数代码

  1. // 图像锐化
  2. cv::Mat Sharpen(cv::Mat input, int percent, int type)
  3. {
  4. cv::Mat result;
  5. cv::Mat s = input.clone();
  6. cv::Mat kernel;
  7. switch (type)
  8. {
  9. case 0:
  10. kernel = (Mat_<int>(3, 3) <<
  11. 0, -1, 0,
  12. -1, 4, -1,
  13. 0, -1, 0
  14. );
  15. break;
  16. case 1:
  17. kernel = (Mat_<int>(3, 3) <<
  18. -1, -1, -1,
  19. -1, 8, -1,
  20. -1, -1, -1
  21. );
  22. break;
  23. default:
  24. kernel = (Mat_<int>(3, 3) <<
  25. 0, -1, 0,
  26. -1, 4, -1,
  27. 0, -1, 0
  28. );
  29. break;
  30. }
  31. filter2D(s, s, s.depth(), kernel);
  32. result = input + s * 0.01 * percent;
  33. return result;
  34. }

C++测试代码

  1. #include
  2. #include
  3. using namespace std;
  4. using namespace cv;
  5. cv::Mat Sharpen(cv::Mat input, int percent, int type);
  6. int main()
  7. {
  8. cv::Mat src = imread("test1.jpg");
  9. cv::Mat result1 = Sharpen(src, -50, 0);
  10. cv::Mat result2 = Sharpen(src, 50, 0);
  11. imshow("original", src);
  12. imshow("result1", result1);
  13. imshow("result2", result2);
  14. waitKey(0);
  15. return 0;
  16. }
  17. // 图像锐化
  18. cv::Mat Sharpen(cv::Mat input, int percent, int type)
  19. {
  20. cv::Mat result;
  21. cv::Mat s = input.clone();
  22. cv::Mat kernel;
  23. switch (type)
  24. {
  25. case 0:
  26. kernel = (Mat_<int>(3, 3) <<
  27. 0, -1, 0,
  28. -1, 4, -1,
  29. 0, -1, 0
  30. );
  31. break;
  32. case 1:
  33. kernel = (Mat_<int>(3, 3) <<
  34. -1, -1, -1,
  35. -1, 8, -1,
  36. -1, -1, -1
  37. );
  38. break;
  39. default:
  40. kernel = (Mat_<int>(3, 3) <<
  41. 0, -1, 0,
  42. -1, 4, -1,
  43. 0, -1, 0
  44. );
  45. break;
  46. }
  47. filter2D(s, s, s.depth(), kernel);
  48. result = input + s * 0.01 * percent;
  49. return result;
  50. }

测试效果

图1 原图
图2 锐化-50效果图
图3 锐化100效果图

       通过调整percent可以实现图像锐化程度的调整,type选择模板类型,也可自行填充更多的模板。

       如果函数有什么可以改进完善的地方,非常欢迎大家指出,一同进步何乐而不为呢~

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

注:本文转载自blog.csdn.net的翟天保Steven的文章"https://blog.csdn.net/zhaitianbao/article/details/120347167"。版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。如有侵权,请联系我们删除。
复制链接
复制链接
相关推荐
发表评论
登录后才能发表评论和回复 注册

/ 登录

评论记录:

未查询到任何数据!
回复评论:

分类栏目

后端 (14832) 前端 (14280) 移动开发 (3760) 编程语言 (3851) Java (3904) Python (3298) 人工智能 (10119) AIGC (2810) 大数据 (3499) 数据库 (3945) 数据结构与算法 (3757) 音视频 (2669) 云原生 (3145) 云平台 (2965) 前沿技术 (2993) 开源 (2160) 小程序 (2860) 运维 (2533) 服务器 (2698) 操作系统 (2325) 硬件开发 (2492) 嵌入式 (2955) 微软技术 (2769) 软件工程 (2056) 测试 (2865) 网络空间安全 (2948) 网络与通信 (2797) 用户体验设计 (2592) 学习和成长 (2593) 搜索 (2744) 开发工具 (7108) 游戏 (2829) HarmonyOS (2935) 区块链 (2782) 数学 (3112) 3C硬件 (2759) 资讯 (2909) Android (4709) iOS (1850) 代码人生 (3043) 阅读 (2841)

热门文章

101
推荐
关于我们 隐私政策 免责声明 联系我们
Copyright © 2020-2025 蚁人论坛 (iYenn.com) All Rights Reserved.
Scroll to Top