智慧交通day01-算法库02:imutils

1.imutils功能简介

imutils是在OPenCV基础上的一个封装,达到更为简结的调用OPenCV接口的目的,它可以轻松的实现图像的平移,旋转,缩放,骨架化等一系列的操作。

安装方法:

pip install imutils

在安装前应确认已安装numpy,scipy,matplotlib和opencv。

2.imutils的使用方法

2.1 图像平移

OpenCV中也提供了图像平移的实现,要先计算平移矩阵,然后利用仿射变换实现平移,在imutils中可直接进行图像的平移。

translated = imutils.translate(img,x,y)

参数:

  • img:要移动的图像
  • x:沿x轴方向移动的像素个数
  • y: 沿y轴方向移动的像素个数

2.2 图像缩放

图片的缩放在OPenCV中要注意确保保持宽高比。而在imutils中自动保持原有图片的宽高比,只指定宽度weight和Height即可。

img = cv.imread("lion.jpeg")
resized = imutils.resize(img,width=200)print("原图像大小: ",img.shape)
print("缩放后大小:",resized.shape)plt.figure(figsize=[10, 10])
#subplot表示将多个图放在同一个窗口里的语句,用subplot(m,n,p)指定要放置的图的位置。在一个窗口中,m表示有m行,n表示有n列,一共可以放置m*n个图。按从左到右,从上到下数,第p个就是要放的位置(p<m*n)
plt.subplot(1,2,1)#一个FIGURE图形生成一行两列两个子图,后面一个1表示当前激活第二个子图。
plt.imshow(cv.cvtColor(img, cv.COLOR_BGR2RGB))
plt.title('原图')
plt.axis("off")
plt.subplot(1,2,2)
plt.imshow(cv.cvtColor(resized, cv.COLOR_BGR2RGB))
plt.title('缩放结果')
plt.axis("off")
plt.show()

下图是对图像进行缩放后的结果:

2.3 图像旋转

在OpenCV中进行旋转时使用的是仿射变换,在这里图像旋转方法是imutils.rotate(),跟2个参数,第一个是图片数据,第二个是旋转的角度,旋转是朝逆时针方向。同时imutils还提供了另一个相似的方法, rotate_round(),它就是按顺时针旋转的。

import cv2
import imutilsimage = cv2.imread('lion.jpeg')
rotated = imutils.rotate(image, 90)   #顺时针                                                                                   
rotated_round = imutils.rotate_bound(image, 90)   #逆时针                              plt.figure(figsize=[10, 10])plt.subplot(1,3,1)
plt.imshow(img[:,:,::-1])
plt.title('原图')
plt.axis("off")plt.subplot(1,3,2)
plt.imshow(rotated[:,:,::-1])
plt.title('逆时针旋转90度')
plt.axis("off")plt.subplot(1,3,3)
plt.imshow(rotated_round[:,:,::-1])
plt.title('顺时针旋转90度')
plt.axis("off")plt.show()

结果如下:

2.4 骨架提取

骨架提取,是指对图片中的物体进行拓扑骨架(topological skeleton)构建的过程。imutils提供的方法是skeletonize(),第二个参数是结构参数的尺寸(structuring element),相当于是一个粒度,越小需要处理的时间越长。

import cv2
import imutils
# 1 图像读取
img = cv2.imread('lion.jpeg')
# 2 灰度化
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)                                  
# 3 骨架提取
skeleton = imutils.skeletonize(gray, size=(3, 3))  
# 4 图像展示
plt.figure(figsize=(10,8),dpi=100)
plt.subplot(121),plt.imshow(img[:,:,::-1]),plt.title('原图')
plt.xticks([]), plt.yticks([])
plt.subplot(122),plt.imshow(skeleton,cmap="gray"),plt.title('骨架提取结果')
plt.xticks([]), plt.yticks([])
plt.show()

效果如下:

2.5 Matplotlib显示

Python中彩色图像使用 OpenCV 加载时是 BGR 模式。但是 Matplotib 是 RGB 模式。所以彩色图像如果已经被 OpenCV 读取,那它将不会被 Matplotib 正确显示。

在OpenCV中,图像以BGR顺序使用该cv2.imshow功能时效果很好。

但是,如果使用Matplotlib显示图像的话,该plt.imshow函数将假定图像按RGB顺序排列,最终导致图像与原图不同。

2.5.1 用OpenCV显示图像

原始图像:

 (从你的全世界路过----稻城亚丁)

原始颜色显示:

#coding:utf-8
# 导入图像显示所用到的包
import cv2
# 显示彩色图像  可认为默认为图像原始色彩
# 导入图片位置
img_path = './img.jpg'
# 读取图像
src_img = cv2.imread(img_path)
# 获取图像高度和宽度
img_info = src_img.shape
print("图像的高度为:{} 高度为:{} 通道数为:{}".format(img_info[0],img_info[1],img_info[2]))
# 显示图像
cv2.imshow("src_img",src_img)
cv2.waitKey(0)
cv2.destroyAllWindows()

显示结果:

 灰度图像显示:

#coding:utf-8
# 导入图像显示所用到的包
import cv2
# 显示彩色图像  可认为默认为图像原始色彩
# 导入图片位置
img_path = './img.jpg'
# 读取灰度图像
src_img = cv2.imread(img_path,0)
# 获取图像高度和宽度
img_info = src_img.shape
print("图像的高度为:{} 高度为:{}".format(img_info[0],img_info[1]))
# 显示图像
cv2.imshow("src_img",src_img)
cv2.waitKey(0)
cv2.destroyAllWindows()

显示结果:

2.5.2 用Matplotlib显示图像

原始图像:

 原始颜色显示:

问题分析:OpenCV中的图像是以BGR的通道顺序存储的,然而今天所讲的Matplotlib是以RGB模式显示的,所以如果直接进行显示显示的话,将不会是我们想看到的结果,比如:

#coding:utf-8
# 导入图像显示所用到的包
import cv2
import matplotlib.pyplot as plt# 显示彩色图像  可认为默认为图像原始色彩
# 导入图片位置
img_path = './img.jpg'
img = cv2.imread(img_path)
# 灰度图显示,cmap(color map)需要设定为gray
plt.imshow(img)
plt.show()

显示结果:

正确的显示:需要将图像通道进行转换为RGB

#coding:utf-8
# 导入图像显示所用到的包
import cv2
import matplotlib.pyplot as plt# 显示彩色图像  可认为默认为图像原始色彩
# 导入图片位置
img_path = './img.jpg'
img = cv2.imread(img_path)
img_cvt = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
# 灰度图显示,cmap(color map)需要设定为gray
plt.imshow(img_cvt)
plt.show()

显示结果:

 灰度图像显示:

#coding:utf-8
# 导入图像显示所用到的包
import cv2
import matplotlib.pyplot as plt# 显示彩色图像  可认为默认为图像原始色彩
# 导入图片位置
img_path = './img.jpg'
img = cv2.imread(img_path,0)
# 灰度图显示,cmap(color map)需要设定为gray
plt.imshow(img, cmap='gray')
plt.show()

显示结果:

分析:仔细观看代码就会发现,opencv读取后的图像已经是灰度图了,但是在用plt显示的时候,还得在参数汇总加上gray,不然显示出来还是色彩空间不对。

例如:

#coding:utf-8
# 导入图像显示所用到的包
import cv2
import matplotlib.pyplot as plt# 显示彩色图像  可认为默认为图像原始色彩
# 导入图片位置
img_path = './img.jpg'
img = cv2.imread(img_path) # 这里为直接读取原始图像
# 灰度图显示,cmap(color map)需要设定为gray
plt.imshow(img, cmap='gray')
plt.show()

显示结果:

2.5.3 快速解决BGR转RGB模式显示的

调用cv2.cvtColor解决此问题,也可以使用opencv2matplotlib便捷功能。

img = cv.imread("lion.jpeg")
plt.figure()
plt.imshow(imutils.opencv2matplotlib(img))

2.6 OPenCV版本的检测

OpenCV 4发布之后,随着主要版本的更新,向后兼容性问题尤为突出。在使用OPenCV时,应检查当前正在使用哪个版本的OpenCV,然后使用适当的函数或方法。在imutils中的is_cv2()、is_cv3()和is_cv4()是可用于自动确定当前环境的OpenCV的版本简单的功能。

print("OPenCV版本: {}".format(cv2.__version__))
print("OPenCV是2.X? {}".format(imutils.is_cv2()))
print("OPenCV是3.X? {}".format(imutils.is_cv3()))
print("OPenCV是4.X? {}".format(imutils.is_cv4()))

输出是:  


总结

  1. imutils是基于OPenCV的便利的图像处理工具包
  2. 使用imutils可以轻松的完成图像平移,缩放,旋转,骨架提取等功能

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/469759.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux 常用操作指令(随时更新)

ls: 查看当前目录下文件列表 -l 列出文件详细信息l(list) -a 列出当前目录下所有文件及目录&#xff0c;包括隐藏的a(all) mkdir 创建目录 -p 创建目录&#xff0c;若无父目录&#xff0c;则创建p(parent) cd 切换目录 touch 创建…

北京中软国际软件测试面试,中软国际软件测试面试题 2012年中软国际软件测试笔试题...

一&#xff0e;简答题&#xff1a;(60分)1. 写出软件测试的基本流程。(2. 分别用等价类划分和边界值方法设计测试用例测试密码域。要求密码必须是数字或字母且必须大于6位小于15位。(6分)3. 用SQL语句查询前十条记录&#xff1f;(6分)4. 什么是唯一索引&#xff0c;非唯一索引&…

16进制数组转字符串

修改函数原型&#xff0c;确保每次malloc后可以释放堆控件 char * HexToString(char *str,unsigned char Hex[],unsigned char lenth) {unsigned char i0,j0;unsigned char tema,temp;//char *str(char*)malloc(lenth*2);for(i0;i<lenth;i){tema(Hex[i]>>4)&0x0F;…

智慧交通day01-算法库03:cv.dnn

1.DNN模块 1.1. 模块简介 OpenCV中的深度学习模块&#xff08;DNN&#xff09;只提供了推理功能&#xff0c;不涉及模型的训练&#xff0c;支持多种深度学习框架&#xff0c;比如TensorFlow&#xff0c;Caffe,Torch和Darknet。 OpenCV那为什么要实现深度学习模块&#xff1f;…

高标清硬盘播出服务器,高标清4通道SDI硬盘播出服务器 XUAPX4000HD

原标题&#xff1a;高标清4通道SDI硬盘播出服务器 XUAPX4000HDXUAP多通道硬盘自动播出系全系统设计 IP/TS/SDI多种播出模式XUAP系统采用先进硬件译码技术的自动播出系统&#xff0c;可依设定时间自动化切换影片与触发连动外围设备&#xff0c;如 矩阵、录像机、切换器 等&#…

行为科学统计第3章

行为科学统计 Statistics for the Behavioral Sciences 人生很累&#xff0c;现在不累&#xff0c;以后更累啦&#xff5e; 第3章 集中趋势 引言&#xff1a;一个平均数最主要的优势是它提供了单个数字&#xff0c;这个数字可以描述整个分布&#xff0c;并且可以被用于与其他分…

linux驱动层获取当前的系统时间

#include <linux/timer.h> #include <linux/timex.h> #include <linux/rtc.h>/*添加到合适位置*/struct timex txc; struct rtc_time tm;do_gettimeofday(&(txc.time));rtc_time_to_tm(txc.time.tv_sec,&tm);printk("UTC time :%d-%d-%d %d:%d…

智慧交通day02-车流量检测实现01:总览

随着城市交通量的迅猛增加&#xff0c;车流量统计已成为智能交通系统中一项关键技术和热门研究方向。高效而精确的车流量检测可以交通管理者和决策者&#xff0c;以及驾驶员提供数据支撑&#xff0c;从而为交通调度&#xff0c;降低拥堵情况的发生&#xff0c;提高道路利用率有…

从qq服务器删除误收邮件,如何恢复从qq邮箱删除的电子邮件

Qq邮箱恢复意外删除的邮件方法第1步: 如果您删除邮件&#xff0c;则无论是普通删除还是完整删除&#xff0c;都可以选择在几秒钟内撤消&#xff0c;以便恢复以前意外删除的邮件. 也就是说&#xff0c;在删除消息后&#xff0c;请在删除上述提示后单击“撤消”. 如果提示消息消失…

linux-虚拟机安装

第一步&#xff1a;下载 安装虚拟机&#xff01; 链接: http://pan.baidu.com/s/1nuGLwsL 密码: 2qdy 第二步&#xff1a;镜像文件&#xff01; 链接: http://pan.baidu.com/s/1nuGLwsL 密码: 2qdy linux 命令大全&#xff1a; arch 显示机器的处理器架构(1) uname -m 显示机器…

安卓JNI传结构体

安卓层代码: package com.demouhf.uhfjni;import android.util.Log; class Foo {protected int len;protected String name; } public class Demouhf {static {try {Log.i("JNI", "wqf Trying to load libnhf.so");/* 調用gsensor.so */System.loadLibra…

智慧交通day02-车流量检测实现02:多目标追踪

1.多目标跟踪分类 多目标跟踪&#xff0c;即MOT&#xff08;Multi-Object Tracking&#xff09;&#xff0c;也就是在一段视频中同时跟踪多个目标。MOT主要应用在安防监控和自动驾驶等领域中。 1.1 初始化方法 多目标跟踪&#xff0c;即MOT&#xff08;Multi-Object Trackin…

GIT非常好的整理

初始化配置 C代码 #配置使用git仓库的人员姓名 git config --global user.name "Your Name Comes Here" #配置使用git仓库的人员email git config --global user.email youyourdomain.example.com #配置到缓存 默认15分钟 git config --global cred…

centos虚拟机wifi设置代理服务器,vmware虚拟机centos在宿主机连WIF..._网络编辑_帮考网...

caotongjiang新兵答主12-13TA获得超过6747个赞资料:netmask ip地址 broadcast 子网掩码 gateway 网关 dns DNS服务器vmware三种网络连接上网设置&#xff1a;1.桥接方式(bridge) :默认使用vmnet0将虚拟机的ip设置与主机同网段未使用ip,其余与主机相同:ip地址与主机同段相异,子网…

PHP mysql_real_escape_string() 函数

mysql_real_escape_string (PHP 4 > 4.3.0, PHP 5) mysql_real_escape_string — 转义 SQL 语句中使用的字符串中的特殊字符&#xff0c;并考虑到连接的当前字符集 Warning 本扩展自 PHP 5.5.0 起已废弃&#xff0c;并在将来会被移除。应使用 MySQLi 或 PDO_MySQL 扩展来替换…

ValueError: check_hostname requires server_hostname的解决办法

在用pip安装scikit-image库时报错&#xff1a;ValueError: check_hostname requires server_hostname 报错ValueError: check_hostname requires server_hostname通常是因为版本冲突等原因&#xff0c;查遍网上众多大佬总结的经验后&#xff0c;最终发现是由网络代理导致的问题…

微软笔试题(看到的写答案啊)

int func(int n, int* r) {printf("n%d *r%d\n",n,*r);//加了个打印的东西 return n && (*r n) && func(n-1, r); }int main() {int r 0;func(100, &r);return 0; }&&还具有短路的功能&#xff0c;即如果第一个表达式为false&#xff…

salesforce 零基础学习(五十四)常见异常友好消息提示

异常或者error code汇总&#xff1a;https://developer.salesforce.com/docs/atlas.en-us.api.meta/api/sforce_api_calls_concepts_core_data_objects.htm 做项目的时候有很多异常是我们经常遇到的&#xff1a; 1.空指针异常&#xff1b; 2.死锁或者超时&#xff1b; 3.级联删…

datasnap ajax jsonp,有没有办法在Delphi DataSnap REST服务器上使用JSONP?

似乎没有办法使用DataSnap来实现带有Padding的JSONP(JSON)解决方案&#xff0c;但是我想在这里抛出这个问题以防有人解决了这个问题。有没有办法在Delphi DataSnap REST服务器上使用JSONP&#xff1f;背景&#xff1a;JSONP是一种利用HTML脚本元素的跨站点引用功能来克服XmlHtt…

PackagesNotFoundError: The following packages are not available from current channels:

解决方法很简单。 先输入以下命令&#xff1a; conda config --append channels conda-forge 在安装你所需要的包即可。