python opencv实现图像配准与比较


Posted in Python onFebruary 09, 2021

本文实例为大家分享了python opencv实现图像配准与比较的具体代码,供大家参考,具体内容如下

代码 

from skimage import io
import cv2 as cv
import numpy as np
import matplotlib.pyplot as plt
 
img_path1 = '2_HE_maxarea.png'
img_path2 = '2_IHC_maxarea.png'
 
img1 = io.imread(img_path1)
img2 = io.imread(img_path2)
img1 = np.uint8(img1)
img2 = np.uint8(img2)
 
# find the keypoints and descriptors with ORB
orb = cv.ORB_create()
kp1, des1 = orb.detectAndCompute(img1,None)
kp2, des2 = orb.detectAndCompute(img2,None)
 
# def get_good_match(des1,des2):
#  bf = cv.BFMatcher()
#  matches = bf.knnMatch(des1, des2, k=2)
#  good = []
#  for m, n in matches:
#   if m.distance < 0.75 * n.distance:
#    good.append(m)
#  return good,matches
# goodMatch,matches = get_good_match(des1,des2)
# img3 = cv.drawMatchesKnn(img1,kp1,img2,kp2,matches[:20],None,flags=2)
 
# create BFMatcher object
bf = cv.BFMatcher(cv.NORM_HAMMING, crossCheck=True)
# Match descriptors.
matches = bf.match(des1,des2)
# Sort them in the order of their distance.
matches = sorted(matches, key = lambda x:x.distance)
# Draw first 20 matches.
img3 = cv.drawMatches(img1,kp1,img2,kp2,matches[:20],None, flags=2)
 
 
goodMatch = matches[:20]
if len(goodMatch) > 4:
 ptsA= np.float32([kp1[m.queryIdx].pt for m in goodMatch]).reshape(-1, 1, 2)
 ptsB = np.float32([kp2[m.trainIdx].pt for m in goodMatch]).reshape(-1, 1, 2)
 ransacReprojThreshold = 4
 H, status =cv.findHomography(ptsA,ptsB,cv.RANSAC,ransacReprojThreshold);
 #其中H为求得的单应性矩阵矩阵
 #status则返回一个列表来表征匹配成功的特征点。
 #ptsA,ptsB为关键点
 #cv2.RANSAC, ransacReprojThreshold这两个参数与RANSAC有关
 imgOut = cv.warpPerspective(img2, H, (img1.shape[1],img1.shape[0]),flags=cv.INTER_LINEAR + cv.WARP_INVERSE_MAP)
 
# 叠加配准变换图与基准图
rate = 0.5
overlapping = cv.addWeighted(img1, rate, imgOut, 1-rate, 0)
io.imsave('HE_2_IHC.png', overlapping)
err = cv.absdiff(img1,imgOut) 
 
# 显示对比
plt.subplot(221)
plt.title('orb')
plt.imshow(img3)
 
plt.subplot(222)
plt.title('imgOut')
plt.imshow(imgOut)
 
plt.subplot(223)
plt.title('overlapping')
plt.imshow(overlapping)
 
plt.subplot(224)  
plt.title('diff') 
plt.imshow(err)
 
plt.show()

结果:

python opencv实现图像配准与比较

python opencv实现图像配准与比较

python opencv实现图像配准与比较

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python用UUID库生成唯一ID的方法示例
Dec 15 Python
详解python进行mp3格式判断
Dec 23 Python
python算法演练_One Rule 算法(详解)
May 17 Python
使用python实现knn算法
Dec 20 Python
python实现手机销售管理系统
Mar 19 Python
Python实现微信小程序支付功能
Jul 25 Python
Tornado实现多进程/多线程的HTTP服务详解
Jul 25 Python
Python hmac模块使用实例解析
Dec 24 Python
不到20行实现Python代码即可制作精美证件照
Apr 24 Python
Python几种常见算法汇总
Jun 02 Python
零基础小白多久能学会python
Jun 22 Python
使用python对excel表格处理的一些小功能
Jan 25 Python
python urllib和urllib3知识点总结
Feb 08 #Python
Python3.9.1中使用match方法详解
Feb 08 #Python
python读取excel数据并且画图的实现示例
Feb 08 #Python
Python爬取某平台短视频的方法
Feb 08 #Python
利用Python批量识别电子账单数据的方法
Feb 08 #Python
Python命令行参数argv和argparse该如何使用
Feb 08 #Python
python 实现Requests发送带cookies的请求
Feb 08 #Python
You might like
PHP高级对象构建 多个构造函数的使用
2012/02/05 PHP
php中url函数介绍及使用示例
2014/02/13 PHP
php第一次无法获取cookie问题处理
2014/12/15 PHP
一个简单安全的PHP验证码类、PHP验证码
2016/09/24 PHP
PHP对XML内容进行修改和删除实例代码
2016/10/26 PHP
PHP基于socket实现客户端和服务端通讯功能
2017/07/13 PHP
laravel框架select2多选插件初始化默认选中项操作示例
2020/02/18 PHP
如何让您的中波更粗更长 - 中波框形天线制作
2021/03/10 无线电
javascript实现的像java、c#之类的sleep暂停的函数代码
2010/03/04 Javascript
IE8提示Invalid procedure call or argument 异常的解决方法
2012/09/30 Javascript
jQuery的context属性用法实例
2014/12/27 Javascript
jQuery实现个性翻牌效果导航菜单的方法
2015/03/09 Javascript
Javascript中typeof 用法小结
2015/05/12 Javascript
js实现页面跳转的几种方法小结
2016/05/16 Javascript
浅谈jquery之on()绑定事件和off()解除绑定事件
2016/10/26 Javascript
基于JS实现仿百度百家主页的轮播图效果
2017/03/06 Javascript
seajs中模块依赖的加载处理实例分析
2017/10/10 Javascript
Vue组件开发之LeanCloud带图形校验码的短信发送功能
2017/11/07 Javascript
在nginx上部署vue项目(history模式)的方法
2017/12/28 Javascript
解决vue+element 键盘回车事件导致页面刷新的问题
2018/08/25 Javascript
Python显示进度条的方法
2014/09/20 Python
python用来获得图片exif信息的库实例分析
2015/03/16 Python
Python的Django框架安装全攻略
2015/07/15 Python
TF-IDF算法解析与Python实现方法详解
2017/11/16 Python
解决pycharm安装后代码区不能编辑的问题
2018/10/28 Python
详解python Todo清单实战
2018/11/01 Python
PyCharm 设置SciView工具窗口的方法
2019/01/15 Python
详解Python计算机视觉 图像扭曲(仿射扭曲)
2019/03/27 Python
Python3.5内置模块之time与datetime模块用法实例分析
2019/04/27 Python
pycharm重命名文件的方法步骤
2019/07/29 Python
Python列表切片常用操作实例解析
2020/03/10 Python
python hmac模块验证客户端的合法性
2020/11/07 Python
python爬虫爬取某网站视频的示例代码
2021/02/20 Python
深入解析HTML5使用SVG图像时的viewBox属性用法
2015/09/02 HTML / CSS
党支部对照检查材料
2014/08/25 职场文书
破坏寝室公物检讨书
2014/11/17 职场文书