范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文
国学影视

图像增强及运算篇之图像点运算和图像灰度化处理

  一.图像点运算概念
  图像点运算(Point Operation)指对于一幅输入图像,将产生一幅输出图像,输出图像的每个像素点的灰度值由输入像素点决定。点运算实际上是灰度到灰度的映射过程,通过映射变换来达到增强或者减弱图像的灰度。还可以对图像进行求灰度直方图、线性变换、非线性变换以及图像骨架的提取。它与相邻的像素之间没有运算关系,是一种简单和有效的图像处理方法[1]。
  图像的灰度变换可以通过有选择的突出图像感兴趣的特征或者抑制图像中不需要的特征,从而改善图像的质量,凸显图像的细节,提高图像的对比度。它也能有效地改变图像的直方图分布,使图像的像素值分布更为均匀[2-3]。它在实际中有很多的应用: 光度学标定 对比度增强 对比度扩展 显示标定 轮廓线确定
  设输入图像为A(x,y),输出图像为B(x,y),则点运算可以表示为:
  图像点运算与几何运算存在差别,不会改变图像内像素点之间的空间位置关系。同时与局部(领域)运算也存在差别,输入像素和输出像素一一对应。 二.图像灰度化处理
  图像灰度化是将一幅彩色图像转换为灰度化图像的过程。彩色图像通常包括R、G、B三个分量,分别显示出红绿蓝等各种颜色,灰度化就是使彩色图像的R、G、B三个分量相等的过程。灰度图像中每个像素仅具有一种样本颜色,其灰度是位于黑色与白色之间的多级色彩深度,灰度值大的像素点比较亮,反之比较暗,像素值最大为255(表示白色),像素值最小为0(表示黑色)。
  假设某点的颜色由RGB(R,G,B)组成,常见灰度处理算法如表11-1所示:
  表11-1中Gray表示灰度处理之后的颜色,然后将原始RGB(R,G,B)颜色均匀地替换成新颜色RGB(Gray,Gray,Gray),从而将彩色图片转化为灰度图像。一种常见的方法是将RGB三个分量求和再取平均值,但更为准确的方法是设置不同的权重,将RGB分量按不同的比例进行灰度划分。比如人类的眼睛感官蓝色的敏感度最低,敏感最高的是绿色,因此将RGB按照0.299、0.587、0.144比例加权平均能得到较合理的灰度图像,如公式11-2所示[4-6]。
  在日常生活中,我们看到的大多数彩色图像都是RGB类型,但是在图像处理过程中,常常需要用到灰度图像、二值图像、HSV、HSI等颜色,OpenCV提供了cvtColor()函数实现这些功能。其函数原型如下所示: dst = cv2.cvtColor(src, code[, dst[, dstCn]])
  – src表示输入图像,需要进行颜色空间变换的原图像
  – dst表示输出图像,其大小和深度与src一致
  – code表示转换的代码或标识
  – dstCn表示目标图像通道数,其值为0时,则有src和code决定
  该函数的作用是将一个图像从一个颜色空间转换到另一个颜色空间,其中,RGB是指Red、Green和Blue,一副图像由这三个通道(channel)构成;Gray表示只有灰度值一个通道;HSV包含Hue(色调)、Saturation(饱和度)和Value(亮度)三个通道。
  在OpenCV中,常见的颜色空间转换标识包括CV_BGR2BGRA、CV_RGB2GRAY、CV_GRAY2RGB、CV_BGR2HSV、CV_BGR2XYZ、CV_BGR2HLS等。下面是调用cvtColor()函数将图像进行灰度化处理的代码。 # -*- coding: utf-8 -*- # By:Eastmount import cv2   import numpy as np    #读取原始图片 src = cv2.imread("luo.png")  #图像灰度化处理 grayImage = cv2.cvtColor(src,cv2.COLOR_BGR2GRAY)  #显示图像 cv2.imshow("src", src) cv2.imshow("result", grayImage)  #等待显示 cv2.waitKey(0) cv2.destroyAllWindows()
  输出结果如图11-1所示,左边是彩色的"小珞珞"原图,右边是将彩色图像进行灰度化处理之后的灰度图。其中,灰度图将一个像素点的三个颜色变量设置为相等(R=G=B),此时该值称为灰度值。
  同样,可以调用如下核心代码将彩色图像转换为HSV颜色空间,其输出结果如图11-2所示。 grayImage = cv2.cvtColor(src, cv2.COLOR_BGR2HSV)
  下面代码对比了九种常见的颜色空间,包括BGR、RGB、GRAY、HSV、YCrCb、HLS、XYZ、LAB和YUV,并循环显示处理后的图像。 # -*- coding: utf-8 -*- # By:Eastmount import cv2   import numpy as np   import matplotlib.pyplot as plt  #读取原始图像 img_BGR = cv2.imread("luo.png")  img_RGB = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2RGB)     #BGR转换为RGB img_GRAY = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2GRAY)   #灰度化处理 img_HSV = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2HSV)     #BGR转HSV img_YCrCb = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2YCrCb) #BGR转YCrCb img_HLS = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2HLS)     #BGR转HLS img_XYZ = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2XYZ)     #BGR转XYZ img_LAB = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2LAB)     #BGR转LAB img_YUV = cv2.cvtColor(img_BGR, cv2.COLOR_BGR2YUV)     #BGR转YUV  #调用matplotlib显示处理结果 titles = ["BGR", "RGB", "GRAY", "HSV", "YCrCb", "HLS", "XYZ", "LAB", "YUV"]   images = [img_BGR, img_RGB, img_GRAY, img_HSV, img_YCrCb,           img_HLS, img_XYZ, img_LAB, img_YUV]   for i in range(9):      plt.subplot(3, 3, i+1), plt.imshow(images[i], "gray")      plt.title(titles[i])      plt.xticks([]),plt.yticks([])   plt.show()
  其运行结果如图11-3所示:
  三.基于像素操作的图像灰度化处理
  前面讲述了调用OpenCV中cvtColor()函数实现图像灰度化的处理,接下来讲解基于像素操作的图像灰度化处理方法,主要是最大值灰度处理、平均灰度处理和加权平均灰度处理方法。 1.最大值灰度处理方法
  该方法的灰度值等于彩色图像R、G、B三个分量中的最大值,公式如下:
  其方法灰度化处理后的灰度图亮度很高,实现代码如下。 # -*- coding: utf-8 -*- # By:Eastmount import cv2   import numpy as np   import matplotlib.pyplot as plt  #读取原始图像 img = cv2.imread("luo.png")  #获取图像高度和宽度 height = img.shape[0] width = img.shape[1]  #创建一幅图像 grayimg = np.zeros((height, width, 3), np.uint8)  #图像最大值灰度处理 for i in range(height):     for j in range(width):         #获取图像R G B最大值         gray = max(img[i,j][0], img[i,j][1], img[i,j][2])         #灰度图像素赋值 gray=max(R,G,B)         grayimg[i,j] = np.uint8(gray)  #显示图像 cv2.imshow("src", img) cv2.imshow("gray", grayimg) #等待显示 cv2.waitKey(0) cv2.destroyAllWindows()
  其输出结果如图11-4所示,其处理效果的灰度偏亮。
  2.平均灰度处理方法
  该方法的灰度值等于彩色图像R、G、B三个分量灰度值的求和平均值,其计算公式如公式(11-4)所示:
  平均灰度处理方法实现代码如下。 # -*- coding: utf-8 -*- # By:Eastmount import cv2   import numpy as np   import matplotlib.pyplot as plt  #读取原始图像 img = cv2.imread("luo.png")  #获取图像高度和宽度 height = img.shape[0] width = img.shape[1]  #创建一幅图像 grayimg = np.zeros((height, width, 3), np.uint8)  #图像平均灰度处理方法 for i in range(height):     for j in range(width):         #灰度值为RGB三个分量的平均值         gray = (int(img[i,j][0]) + int(img[i,j][1]) + int(img[i,j][2]))  /  3         grayimg[i,j] = np.uint8(gray)  #显示图像 cv2.imshow("src", img) cv2.imshow("gray", grayimg)  #等待显示 cv2.waitKey(0) cv2.destroyAllWindows()
  其输出结果如图11-5所示:
  3.加权平均灰度处理方法
  该方法根据色彩重要性,将三个分量以不同的权值进行加权平均。由于人眼对绿色的敏感最高,对蓝色敏感最低,因此,按下式对RGB三分量进行加权平均能得到较合理的灰度图像。
  加权平均灰度处理方法实现代码如下所示: # -*- coding: utf-8 -*- # By:Eastmount import cv2   import numpy as np   import matplotlib.pyplot as plt  #读取原始图像 img = cv2.imread("luo.png")  #获取图像高度和宽度 height = img.shape[0] width = img.shape[1]  #创建一幅图像 grayimg = np.zeros((height, width, 3), np.uint8)  #图像平均灰度处理方法 for i in range(height):     for j in range(width):         #灰度加权平均法         gray = 0.30 * img[i,j][0] + 0.59 * img[i,j][1] + 0.11 * img[i,j][2]         grayimg[i,j] = np.uint8(gray)  #显示图像 cv2.imshow("src", img) cv2.imshow("gray", grayimg)  #等待显示 cv2.waitKey(0) cv2.destroyAllWindows()
  其输出结果如图11-6所示:
  四.总结
  本文主要讲解图像点运算的灰度化处理,详细介绍常用的灰度化处理方法,并分享了图像颜色空间相互转换,以及三种灰度转换算法的实现。通过灰度处理,我们能有效将彩色图像转换为灰度图,为后续的边缘提取等处理提供支撑,也可能实现图像处理软件最简单的彩色图转黑白的效果,希望对您有所帮助。

如何使用python做量化交易介绍首先我不是量化工程师,我只是个后端工程师其次我对量化也不感兴趣,自己有几把刷子还是了解的,自己不适合做量化交易自己没有优秀的模型设计能力自己是个长线投资,一般一个股票都是至少拿仰望U9电动超跑发布0100kmh加速达到2秒级太平洋汽车新车频道1月5日,比亚迪汽车高端品牌仰望暨技术发布会在深圳召开,正式发布了仰望品牌核心技术易四方和百万级纯电动性能超跑U9。未来,易四方技术将标配搭载于仰望品牌全系车型。虽然说是旗舰机型,但是它的价格并不贵摩托罗拉虽然是功能手机时代的大品牌,但在智能手机时代的地位并不高。然而,当手机行业陷入衰退时,这个品牌突然爆发出惊人的战斗力。它不仅拥有很高的存在感,而且其型号的销量也在稳步上升,量子之歌IPO深陷亏损窘境退款剧增付费用户锐减,还涉嫌多起违规港湾商业观察施子夫12月21日,在线教育学习平台北京量子之歌科技有限公司(QuantaSingGroupLimited,以下简称,量子之歌)向美国证券交易委员会(SEC)递交F1文一加11正式发布屏幕显示素质引热议,看看大V作何评价时间来到年末之际,近期不少厂商相继召开新品发布会,为旗舰手机持续注入新鲜血液,让年底有意向换新机的小伙伴有了更大的选择空间。而要说目前市场热度最高的骁龙8Gen2新机,那么近日登场互联网老司机私藏的找客户资料方法!建议收藏!找客户资料的方式有很多,看处于何类需求,是深度的行业分析?还是直接需要某类某个特定人的客户信息,比如做销售需要找到客户的联系方式。当然不论哪种,最便捷的方式无疑是互联网搜索,因此具再次碰瓷小米13,天玑9200的vivoX90能行吗?关键它俩价格还一样自从高通把历代骁龙发布会又双叒叕提前后,很多手机厂商12月就趁早发布新机了,蓝厂还创造了首发提早小米数字系列半个月的记录。很多数码圈的粉丝也是十分喜欢看粮厂蓝厂这俩家撕逼的,快到过独家解读Meta紧急叫停全球数据中心在建项目背后的秘密独家解读Meta紧急叫停全球数据中心在建项目背后的秘密摘要Meta在全球运营着超过4000万平方英尺的18个数据中心园区,有47个数据中心正在建设中。如此庞大的设施规模,使得Met凯莉詹娜身穿黑色抹胸牛仔裙,留着白色眉毛,看起来时髦性感凯莉詹娜在洛杉矶穿着抹胸黑色套装摆造型时,她的眉毛染成了时尚的白色。在阿斯彭庆祝完节日后,不过她的男友特拉维斯缺席了卡戴珊家族的活动。凯莉詹娜加入了贝拉哈迪德茱莉娅福克斯等名人的行湿度传感器的应用场景湿度传感器是一种电子设备,可测量并报告部署环境的湿度值,例如部署在空气土壤或密闭空间中的周围环境,24小时在线监测湿度和空气温度。DAMW318B20湿度传感器湿度测量表明空气中存铁钉案死者用七巧板摆了一个猫的形状,狄公调查后说凶手是她唐高宗时,在宁州当地有一位武术高强的民间好汉,此人姓蓝名魁。蓝魁从小拜师当地的高人修炼拳术,长大后在江湖上以拳术闻名。此人行侠仗义,扶弱锄强,深受百姓的喜爱。这一年,狄仁杰被派到宁
胡锡进力挺中国扩充核武库面对美国威胁,我们要做好最坏准备1月31日胡锡进发表一篇文章,这篇文章谈及,在面对美国威胁时,中国必须扩充自己的核武库以应对最坏情况的发生,他之所以得出这一结论并做出这种主张,还是基于多方面考虑。第一,当前的俄乌丰李街道开展绿化环境清洁养护专项活动为进一步提升绿化水平改善人居环境,营造绿意盎然清新舒适的优美宜居环境,节后,丰李街道组织工作人员和志愿者开展绿化环境清洁养护专项工作,不断提升绿化颜值。工作人员和志愿者们深入辖区周海岸卫士海洋绿肺红树林守护海洋人类守护红树林今年1月1日,巴西总统卢拉签署多项与环境保护相关的行政法令,加强对包括红树林保护区在内的亚马孙地区的环境保护。去年11月,在阿联酋举办的第二届气候变化大会上,阿联酋气候变化与环境部刚收到100辆坦克,乌叫嚣夺回克里米亚,美国却劝其放弃乌东重镇近日,美国等北约国家相继允诺乌克兰豹2艾布拉姆斯等型号的坦克和其他重型武器,其中主战坦克高达300多辆。尽管这些坦克的交付日期不一,但据乌克兰外长库列巴透露,首批交付的坦克将超过1狂飙带火孙子兵法?评论员邱延波聚会闲聊,不看狂飙就跟不上话题?这段时间,电视剧狂飙屡屡上热搜,仿佛谁不提狂飙谁就落伍了一样。狂飙的火热,还带动了周边产品。由于在狂飙电视剧中出现,传统经典孙子兵法关注杭州亚运会传喜讯,曝两大欧洲国家报名参赛,中国代表团成大赢家北京时间1月31日,根据国内媒体发布的最新消息显示,两大欧洲国家俄罗斯和白俄罗斯将有望派500人参加杭州亚运会,这个消息传来后,让即将在杭州举办的本次亚运会赛事,受到了全球的瞩目,孙中山曾预言中国若定都这3个城,有望称霸亚洲,是哪3个城?自从1840年鸦片战争开始,中国就惨遭西方列强的肆意蹂躏。为了救中国,很多仁人志士,寻找救中国于水火之中的方法和途径。康有为梁启超的保皇派,和孙中山的革命派是当时救中国的两大派别。中国第一位女皇帝,称帝比武则天还要早37年,却下场凄惨一提起中国的女皇帝,大多数人都会想起武周皇帝武则天,的确,作为中国历史上唯一的正统女皇帝,她政启开元,治宏贞观,自公元690年称帝以来,文治武功都十分了得。但她却不是中国的第一位女史学道光时期大清仍是全球第一大国,为何鸦片战争惨败于英国清宣宗爱新觉罗旻宁(1782年1850年),清朝入关后第六位皇帝,嘉庆皇帝第二子。公元1820年七月即位,年号道光,时年29岁,是清朝唯一以嫡长子身份继承皇位的皇帝,在位30年。道1979年,6名越南女俘虏为活命色诱解放军,我军3招让其后悔!1979年,我军抓到了6名越南女兵,并将她们送到了战俘营。但没想到的是,在战俘营,这些女兵不好好改造,反而想方设法勾引解放军,这是怎么回事?进入战俘营后,立即有几名解放军对她们搜身追光这些球衣里传递的新春祝福,我们收到啦!北京时间30日凌晨巴黎圣日耳曼队在与兰斯队进行的法甲联赛比赛中身着中文名字球衣参赛给球迷带来惊喜与感动虽然大巴黎最终没能赢球但他们给大家带来的春节祝福估计还是会让不少球迷对这家俱乐