python+opencv图像拼接-python opencv 图像拼接的实现方法
初级的图像拼接为将两幅图像简单的粘贴在一起,仅仅是图像几何空间的转移与合成,与图像内容无关。高级图像拼接也叫作基于特征匹配的图像拼接,拼接时消去两幅图像相同的部分,实现拼接合成全景图。
具有相同尺寸的图A和图B含有相同的部分与不同的部分,如图所示:
用基于特征的图像拼接实现后:
设图像高为h,相同部分的宽度为wx
拼接后图像的宽w=wA+wB-wx
因此,可以先构建一个高为h,宽为W*2的空白图像,将左图像向右平移wx,右图像粘贴在右侧。则右图像刚好覆盖左图像中的相同部分。最终拼接图像完成,完成后的图像左侧有宽度为wx的空白即为所检测出的两幅图像的相同部分,可根据需要选择是否去除。示例图如下。
实现上述效果的步骤如下:
1. 采用surft特征检测算法检测两幅图像的关键特征点;
2. 建立FLANN匹配器,采用目前最快的特征匹配(最近邻搜索)算法FlannBasedMatcher匹配关键点
3.从所匹配的全部关键点中筛选出优秀的特征点(基于距离筛选)
4. 根据查询图像和模板图像的特征描述子索引得出仿射变换矩阵
5. 获取左边图像到右边图像的投影映射关系
6. 透视变换将左图像放在相应的位置
7. 将有图像拷贝到特定位置完成拼接
先放python下利用opencv 进行图像拼接的代码,环境为python2.7+opencv2:
#coding: utf-8
import numpy as np
import cv2
leftgray = cv2.imread("1.jpg")
rightgray = cv2.imread("2.jpg")
hessian=400
surf=cv2.SURF(hessian) #将Hessian Threshold设置为400,阈值越大能检测的特征就越少
kp1,des1=surf.detectAndCompute(leftgray,None) #查找关键点和描述符
kp2,des2=surf.detectAndCompute(rightgray,None)
FLANN_INDEX_KDTREE=0 #建立FLANN匹配器的参数
indexParams=dict(algorithm=FLANN_INDEX_KDTREE,trees=5) #配置索引,密度树的数量为5
searchParams=dict(checks=50) #指定递归次数
#FlannBasedMatcher:是目前最快的特征匹配算法(最近邻搜索)
flann=cv2.FlannBasedMatcher(indexParams,searchParams) #建立匹配器
matches=flann.knnMatch(des1,des2,k=2) #得出匹配的关键点
good=[]
#提取优秀的特征点
for m,n in matches:
if m.distance < 0.7*n.distance: #如果第一个邻近距离比第二个邻近距离的0.7倍小,则保留
good.append(m)
src_pts = np.array([ kp1[m.queryIdx].pt for m in good]) #查询图像的特征描述子索引
dst_pts = np.array([ kp2[m.trainIdx].pt for m in good]) #训练(模板)图像的特征描述子索引
H=cv2.findHomography(src_pts,dst_pts) #生成变换矩阵
h,w=leftgray.shape[:2]
h1,w1=rightgray.shape[:2]
shft=np.array([[1.0,0,w],[0,1.0,0],[0,0,1.0]])
M=np.dot(shft,H[0]) #获取左边图像到右边图像的投影映射关系
dst_corners=cv2.warpPerspective(leftgray,M,(w*2,h))#透视变换,新图像可容纳完整的两幅图
cv2.imshow("tiledImg1",dst_corners) #显示,第一幅图已在标准位置
dst_corners[0:h,w:w*2]=rightgray #将第二幅图放在右侧
#cv2.imwrite("tiled.jpg",dst_corners)
cv2.imshow("tiledImg",dst_corners)
cv2.imshow("leftgray",leftgray)
cv2.imshow("rightgray",rightgray)
cv2.waitKey()
cv2.destroyAllWindows()
所用图像为:
拼接完成后的图像为:
测试一下抗干扰能力,所用图像:
拼接结果:
可见,抗干扰能力还是不错的,在测试中若拼接不成功,则注意以下两点:
1. 所用两幅图像尺寸是否相同,是否有相同的部分。
2. 适当调整hessian的值。
总结
以上所述是小编给大家介绍的python opencv 图像拼接的实现方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
python+opencv图像拼接-python opencv 图像拼接的实现方法相关推荐
- 超详细OpenCV之python操作
简介 OpenCV是一款由Intel公司俄罗斯团队发起并参与和维护的一个计算机视觉处理开源软件库,支持与计算机视觉和机器学习相关的众多算法,并且正在日益扩展. OpenCV-Python OpenCV ...
- 关于OpenCV for Python入门-图片和摄像头显示
OpenCV和Python结合的学习资料不多,网上的资料更是鱼目混杂,推荐大家OpenCV官方教程中文版 for Python,建议自行下载. 其实也算不上原创,多方摘取学习,是opencv学习的开始 ...
- 使用OpenCV,Python和dlib进行眨眼检测及计数
前三篇博客学习了 windows10+Python3.7安装dlib库进行面部标志识别 python dlib实现面部标志识别 使用python,dlib,OpenCV提取眼睛,鼻子,嘴唇及下颌 这篇 ...
- 使用OpenCV和Python计算图像的“彩色度”
使用OpenCV和Python计算图像"彩色度" 1. 效果图 2. 炫彩度量方法是什么? 3. 源代码 参考 你是否尝试过计算每个图像的炫彩值,并根据炫彩值对自己的图像数据集进行 ...
- 使用OpenCV和Python生成视频条形码
使用OpenCV和Python生成视频条形码 1. 效果图 2. 原理 2.1 步骤 2.2 项目结构 3. 源码 参考 这篇博客将演示如何使用Python + OpenCV生成视频条形码. 生成视频 ...
- 使用OpenCV和Python高效计算视频的总帧数
使用OpenCV和Python高效计算视频的总帧数 1. 效果图 2. 源码 参考 这篇博客将介绍两种使用OpenCV和Python计算视频文件中帧数的方法. 超级快,它依靠OpenCV的视频属性功能 ...
- OpenCV和Python动手操作计算机视觉学习教程
使用OpenCV和Python进行实际操作 面向初学者的OpenCV Python动手操作计算机视觉 你会学到: NumPy基础知识 基于OpenCV的人脸检测 使用OpenCV在图像和视频上绘制形状 ...
- python如何实现找图_利用OpenCV和Python实现查找图片差异
使用OpenCV和Python查找图片差异 flyfish 方法1 均方误差的算法(Mean Squared Error , MSE) 下面的一些表达与<TensorFlow - 协方差矩阵&g ...
- 利用OpenCV、Python和Ubidots构建行人计数器程序(附完整代码)
作者 | Jose Garcia 译者 | 吴振东 校对 | 张一豪.林亦霖,编辑 | 于腾凯 来源 | 数据派(ID:datapi) 导读:本文将利用OpenCV,Python和Ubidots来编写 ...
- 如何用 OpenCV、Python 和深度学习实现面部识别?
点击上方"小白学视觉",选择加"星标"或"置顶" 重磅干货,第一时间送达本文转自|新机器视觉 Face ID 的兴起带动了一波面部识别技术热 ...
最新文章
- 数据库 user schema sqlserver 关系
- easycode自定义模板转载
- 【BZOJ-2325】道馆之战 树链剖分 + 线段树
- JDB2导致磁盘io使用率高
- 前端学习(1138):正则表达式里面的量词符
- centos7-安装mysql5.6.36
- 笔记下UltraEdit的一些常用使用技巧
- java 毫秒转分钟和秒_毫秒转换为天、小时、分、秒
- jquery所有版本下载
- 广州图书馆跳转中国知网教程
- 成年人社交中的10个潜规则
- 眼球追踪技术 Unity+ HTC vive Pro + DroolonF1 (二)
- salesforce的前世今生
- MIDI音乐制作概论,常用插件与流行音乐模板
- MySQL忘记密码修改密码
- 【Linux】解决安装Anaconda后默认进入base环境的问题
- 安装hadoop 问题记录
- WinFrom内嵌chrome浏览器
- Ubuntu 16.04 LTS 安装libvips出现”Package vips was not found in the pkg-config search path”
- 因为 QUERY_ALL_PACKAGES 权限,我们上不了 Google Play 了
热门文章
- LeetCode-笔记-45.跳跃游戏II-贪心算法
- html创建等边三角形,CSS3 等边三角形组成星形图案
- 【Netty】传输(Transport)
- 今天大佬告诉你Spring Boot 实现通用 Auth 认证的 4 种方式!
- 绿米开关如何重置_小米米家墙壁开关实物到手实际体验
- rgb立方体用html语言,解读Unity中的CG编写Shader系列一
- web 平台搭建-LNMP-源码包(CentOS-7)
- nodejs没有net模块_Node.js实战16:用http模块创建web服务器
- bool类型返回值_Python 到底是强类型语言,还是弱类型语言?
- unity 可滚动文本_Unity3d如何实现滚动文本框?