【计算机视觉系列实战教程 (实战01)】:图像锐化操作(并手写锐化操作)

文章目录


前言

提示:本文主要通过手写图像锐化算法来理解图像像素的遍历:

我们知道图像的高斯模糊的在实践中是使用高斯卷积核来卷积处理图像的,高斯卷积核"卷"图像的结果是被卷的图像区域变模糊了。而本文要讲解的图像锐化则是将图像更加清晰。


提示:以下是本篇文章正文内容,下面案例可供参考

1、什么是图像锐化

图像锐化是一种图像处理技术,旨在增强图像中边缘和细节的对比度,使其看起来更加清晰和鲜明。

2、使用卷积对图像进行锐化

(1).图像预处理

代码如下(示例):这里对图像先进行了高斯模糊处理,目的是去除噪音,防止锐化后加重噪音的影响

cpp 复制代码
cv::Mat imRead = cv::imread("xxx.jpeg");
cv::GaussianBlur(imRead, imRead, cv::Size(3,3),0);

(2).定义锐化卷积核

代码如下(示例):

cpp 复制代码
cv::Mat kernel_sharpen = (cv::Mat_<int>(3,3)<< 0, -1, 0,
											  -1, 5, -1,
											   0, -1, 0);

(3).对图像进行卷积操作(实现图像锐化)

代码如下(示例):

cpp 复制代码
cv::filter2D(imRead, imRead, imRead.type(), kernel_sharpen);

总代码如下:

cpp 复制代码
cv::Mat imRead = cv::imread(strPth01);
cv::GaussianBlur(imRead, imRead, cv::Size(3,3),0);
//定义锐化卷积核
cv::Mat kernel_sharpen = (cv::Mat_<int>(3, 3) << 0, -1, 0,
												-1, 5, -1,
												 0, -1, 0);
cv::Mat imSharpen;
cv::filter2D(imRead, imSharpen, imRead.type(), kernel_sharpen);

3、手动遍历实现图像锐化

手动遍历像素实现图像的锐化操作

下列函数使用了at访问图像像素,可根据自己的需求使用ptr、iterator等访问像素,代码如下(可直接使用):

cpp 复制代码
/*@author @还下着雨ZG
* @param[in] imSrc, 源图像,即待锐化的图像
* @param[out] imDst, 目标图像,即锐化后的图像
* @return int, 正表示锐化成功,负表示失败
*/
int ImgSharpenBySelf(const cv::Mat& imSrc, cv::Mat& imDst)
{
	if(imSrc.empty()) return -1;
	if(!imDst.empty()) imDst.release();
	if(imSrc.channels()==1)
	{
		cv::Mat imCopy;
		imSrc.convertTo(imCopy,CV_32SC1);
		imDst = imCopy.clone();
		for(int r=1; r<imCopy.rows-1; ++r)
		{
			for(int c=1; c<imCopy.cols-1; ++c)
			{
			    //这里使用int来访问图像像素元素
				imDst.at<int>(r,c) = 5*imCopy.at<int>(r,c)
									 - imCopy.at<int>(r-1,c) 
									 - imCopy.at<int>(r+1,c)
									 - imCopy.at<int>(r,c-1)
									 - imCopy.at<int>(r,c+1);
			}
		}
		//将目标图像(锐化后的图像)转为CV_8UC1
		imDst.convertTo(imDst, CV_8U);
	}
	else if(imSrc.channels()==3)
	{
		//转换图像格式便于计算(防止溢出)
		cv::Mat imCopy;
		imSrc.convertTo(imCopy,CV_32SC3);
		imDst = imCopy.clone();
	    //遍历图像并处理像素 new = 5*current - left - top - right - bottom
		for(int r=1; r<imCopy.rows-1; ++r)
		{
			for(int c=1; c<imCopy.cols-1; ++c)
			{
			    //这里使用int来访问图像像素元素
				imDst.at<cv::Vec3i>(r,c) = 5*imCopy.at<cv::Vec3i>(r,c)
										 - imCopy.at<cv::Vec3i>(r-1,c) 
										 - imCopy.at<cv::Vec3i>(r+1,c)
										 - imCopy.at<cv::Vec3i>(r,c-1)
										 - imCopy.at<cv::Vec3i>(r,c+1);
			}
		}
		//将目标图像(锐化后的图像)转为CV_8UC1
		imDst.convertTo(imDst, CV_8UC3);
	}
	else 
	{
		return -2;
	}
	return 1;
}

总结

1.使用opencv自带的卷积函数filter2D和卷积核kernel来锐化图像

2.手动遍历图像(灰度图像或彩色图像)实现图像的锐化操作

相关推荐
星域智链17 分钟前
宠物智能用品:当毛孩子遇上 AI,是便利还是过度?
人工智能·科技·学习·宠物
taxunjishu34 分钟前
DeviceNet 转 MODBUS TCP罗克韦尔 ControlLogix PLC 与上位机在汽车零部件涂装生产线漆膜厚度精准控制的通讯配置案例
人工智能·区块链·工业物联网·工业自动化·总线协议
说私域43 分钟前
基于多模态AI技术的传统行业智能化升级路径研究——以开源AI大模型、AI智能名片与S2B2C商城小程序为例
人工智能·小程序·开源
囚生CY1 小时前
【速写】优化的深度与广度(Adam & Moun)
人工智能·python·算法
hqyjzsb1 小时前
2025年市场岗位能力重构与跨领域转型路径分析
c语言·人工智能·信息可视化·重构·媒体·改行学it·caie
爱学习的uu1 小时前
CURSOR最新使用指南及使用思路
人工智能·笔记·python·软件工程
叶凡要飞1 小时前
RTX5060Ti安装双系统ubuntu22.04各种踩坑点(黑屏,引导区修复、装驱动、server版本安装)
人工智能·python·yolo·ubuntu·机器学习·操作系统
叶庭云1 小时前
一文掌握 CodeX CLI 安装以及使用!
人工智能·openai·安装·使用教程·codex cli·编码智能体·vibe coding 终端
yuluo_YX2 小时前
VSR 项目解析
人工智能·python
cdming2 小时前
微软Win11双AI功能来袭:“AI管家”+聊天机器人重构桌面交互体验
人工智能·microsoft·机器人