使用Python实现图像融合及加法运算
作者:华为云开发者社区 时间:2021-03-03 06:19:42
一.图像加法运算
1.Numpy库加法
其运算方法是:目标图像 = 图像1 + 图像2,运算结果进行取模运算。
当像素值<=255时,结果为“图像1+图像2”,例如:120+48=168
当像素值>255时,结果为对255取模的结果,例如:(255+64)%255=64
2.OpenCV加法运算
另一种方法是直接调用OpenCV库实现图像加法运算,方法如下:
目标图像 = cv2.add(图像1, 图像2)
此时结果是饱和运算,即:
当像素值<=255时,结果为“图像1+图像2”,例如:120+48=168
当像素值>255时,结果为255,例如:(255+64) = 255
两种方法对应的代码如下所示:
#encoding:utf-8
import cv2
import numpy as np
import matplotlib.pyplot as plt
#读取图片
img = cv2.imread('picture.bmp')
test = img
#方法一:Numpy加法运算
result1 = img + test
#方法二:OpenCV加法运算
result2 = cv2.add(img, test)
#显示图像
cv2.imshow("original", img)
cv2.imshow("result1", result1)
cv2.imshow("result2", result2)
#等待显示
cv2.waitKey(0)
cv2.destroyAllWindows()
输出结果如下图所示,其中result1为第一种方法,result2为第二种方法,白色点255更多。
注意:参与运算的图像大小和类型必须一致。下面是对彩 * 像进行加法运算的结果。
二.图像融合
图像融合通常是指将2张或2张以上的图像信息融合到1张图像上,融合的图像含有更多的信息,能够更方便人们观察或计算机处理。如下图所示,将两张不清晰的图像融合得到更清晰的图。
图像融合是在图像加法的基础上增加了系数和亮度调节量。
图像加法:目标图像 = 图像1 + 图像2
图像融合:目标图像 = 图像1 * 系数1 + 图像2 * 系数2 + 亮度调节量
主要调用的函数是addWeighted,方法如下:
dst = cv2.addWeighter(scr1, alpha, src2, beta, gamma)
dst = src1 * alpha + src2 * beta + gamma
其中参数gamma不能省略。
代码如下:
#encoding:utf-8
import cv2
import numpy as np
import matplotlib.pyplot as plt
#读取图片
src1 = cv2.imread('test22.jpg')
src2 = cv2.imread('picture.bmp')
#图像融合
result = cv2.addWeighted(src1, 1, src2, 1, 0)
#显示图像
cv2.imshow("src1", src1)
cv2.imshow("src2", src2)
cv2.imshow("result", result)
#等待显示
cv2.waitKey(0)
cv2.destroyAllWindows()
需要注意的是,两张融合的图像像素大小需要一致,如下图所示,将两张RGB且像素410*410的图像融合。
设置不同的比例的融合如下所示:
result = cv2.addWeighted(src1, 0.6, src2, 0.8, 10)
三.图像类型转换
图像类型转换是指将一种类型转换为另一种类型,比如彩 * 像转换为灰度图像、BGR图像转换为RGB图像。OPenCV提供了200多种不同类型之间的转换,其中最常用的包括3类,如下:
cv2.COLOR_BGR2GRAY
cv2.COLOR_BGR2RGB
cv2.COLOR_GRAY2BGR
代码如下所示:
#encoding:utf-8
import cv2
import numpy as np
import matplotlib.pyplot as plt
#读取图片
src = cv2.imread('01.bmp')
#图像类型转换
result = cv2.cvtColor(src, cv2.COLOR_BGR2GRAY)
#显示图像
cv2.imshow("src", src)
cv2.imshow("result", result)
#等待显示
cv2.waitKey(0)
cv2.destroyAllWindows()
输出结果如下图所示:
如果使用通道转化,则结果如下图所示:
result = cv2.cvtColor(src, cv2.COLOR_BGR2RGB)
图像处理通常需要将彩 * 像转换为灰度图像再进行后续的操作,更多知识后续将继续分享,希望对着喜欢,尤其是做图像识别、图像处理的同学。
来源:https://blog.51cto.com/u_15214399/5290506
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python3使用matplotlib绘制条形图
![](https://img.aspxhome.com/file/2023/9/98969_0s.jpg)
Python探索之实现一个简单的HTTP服务器
Python爬虫设置代理IP的方法(爬虫技巧)
关于Numpy中的行向量和列向量详解
使用PyInstaller库把Python程序打包成exe
![](https://img.aspxhome.com/file/2023/7/112527_0s.png)
苹果的“创新”
php中json_encode不兼容JSON_UNESCAPED_UNICODE的解决方案
Python 不同对象比较大小示例探讨
Python 普通最小二乘法(OLS)进行多项式拟合的方法
![](https://img.aspxhome.com/file/2023/0/87800_0s.jpg)
python爬取代理ip的示例
![](https://img.aspxhome.com/file/2023/1/85371_0s.png)
python重试装饰器的简单实现方法
pandas提升计算效率的一些方法汇总
php之redis短线重连案例讲解
如何使用图片精灵优化你的网站
![](https://img.aspxhome.com/file/UploadPic/20097/21/how_to_image_sprites-95s.jpg)
利用tkinter实现下拉框联动
![](https://img.aspxhome.com/file/2023/2/110262_0s.png)
详解Python中的__new__()方法的使用
浅谈tensorflow中张量的提取值和赋值
![](https://img.aspxhome.com/file/2023/2/115192_0s.jpg)
Python Tensor FLow简单使用方法实例详解
![](https://img.aspxhome.com/file/2023/2/109562_0s.png)
Python中提取人脸特征的三种方法详解
在Python中append以及extend返回None的例子
![](https://img.aspxhome.com/file/2023/1/97201_0s.jpg)