python数字图像处理实现图像的形变与缩放


Posted in Python onJune 28, 2022

skimage的transform模块

图像的形变与缩放,使用的是skimage的transform模块,函数比较多,功能齐全。

1、改变图片尺寸resize

函数格式为:

skimage.transform.resize(image,output_shape)

image: 需要改变尺寸的图片

output_shape: 新的图片尺寸

from skimage import transform,data
import matplotlib.pyplot as plt
img = data.camera()
dst=transform.resize(img, (80, 60))
plt.figure('resize')
plt.subplot(121)
plt.title('before resize')
plt.imshow(img,plt.cm.gray)
plt.subplot(122)
plt.title('before resize')
plt.imshow(dst,plt.cm.gray)
plt.show()

将camera图片由原来的512*512大小,变成了80*60大小。从下图中的坐标尺,我们能够看出来:

python数字图像处理实现图像的形变与缩放

2、按比例缩放rescale

函数格式为:

skimage.transform.rescale(image,scale[,...])

scale参数可以是单个float数,表示缩放的倍数,也可以是一个float型的tuple,如[0.2,0.5],表示将行列数分开进行缩放

from skimage import transform,data
img = data.camera()
print(img.shape)  #图片原始大小 
print(transform.rescale(img, 0.1).shape)  #缩小为原来图片大小的0.1倍
print(transform.rescale(img, [0.5,0.25]).shape)  #缩小为原来图片行数一半,列数四分之一
print(transform.rescale(img, 2).shape)   #放大为原来图片大小的2倍

结果为:

(512, 512)
(51, 51)
(256, 128)
(1024, 1024)

3、旋转 rotate

skimage.transform.rotate(image,angle[,...],resize=False)

angle参数是个float类型数,表示旋转的度数

resize用于控制在旋转时,是否改变大小 ,默认为False

from skimage import transform,data
import matplotlib.pyplot as plt
img = data.camera()
print(img.shape)  #图片原始大小
img1=transform.rotate(img, 60) #旋转90度,不改变大小 
print(img1.shape)
img2=transform.rotate(img, 30,resize=True)  #旋转30度,同时改变大小
print(img2.shape)   
plt.figure('resize')
plt.subplot(121)
plt.title('rotate 60')
plt.imshow(img1,plt.cm.gray)
plt.subplot(122)
plt.title('rotate  30')
plt.imshow(img2,plt.cm.gray)
plt.show()

显示结果:

python数字图像处理实现图像的形变与缩放

4、图像金字塔

以多分辨率来解释图像的一种有效但概念简单的结构就是图像金字塔。图像金字塔最初用于机器视觉和图像压缩,一幅图像的金字塔是一系列以金字塔形状排列的分辨率逐步降低的图像集合。金字塔的底部是待处理图像的高分辨率表示,而顶部是低分辨率的近似。当向金字塔的上层移动时,尺寸和分辨率就降低。

在此,我们举一个高斯金字塔的应用实例,函数原型为:

skimage.transform.pyramid_gaussian(image, downscale=2)

downscale控制着金字塔的缩放比例

import numpy as np
import matplotlib.pyplot as plt
from skimage import data,transform
image = data.astronaut()  #载入宇航员图片
rows, cols, dim = image.shape  #获取图片的行数,列数和通道数
pyramid = tuple(transform.pyramid_gaussian(image, downscale=2))  #产生高斯金字塔图像
#共生成了log(512)=9幅金字塔图像,加上原始图像共10幅,pyramid[0]-pyramid[1]
composite_image = np.ones((rows, cols + cols / 2, 3), dtype=np.double)  #生成背景
composite_image[:rows, :cols, :] = pyramid[0]  #融合原始图像
i_row = 0
for p in pyramid[1:]:
    n_rows, n_cols = p.shape[:2]
    composite_image[i_row:i_row + n_rows, cols:cols + n_cols] = p  #循环融合9幅金字塔图像
    i_row += n_rows
plt.imshow(composite_image)
plt.show()

python数字图像处理实现图像的形变与缩放

python数字图像处理实现图像的形变与缩放

上图,就是10张金字塔图像,下标为0的表示原始图像,后面每层的图像行和列变为上一层的一半,直至变为1

除了高斯金字塔外,还有其它的金字塔,如:

skimage.transform.pyramid_laplacian(image, downscale=2):

python数字图像处理实现图像的形变与缩放

以上就是python数字图像处理实现图像的形变与缩放的详细内容,更多关于python数字图像形变与缩放的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python中正则表达式的用法实例汇总
Aug 18 Python
Python错误提示:[Errno 24] Too many open files的分析与解决
Feb 16 Python
python实现员工管理系统
Jan 11 Python
Window10+Python3.5安装opencv的教程推荐
Apr 02 Python
python生成以及打开json、csv和txt文件的实例
Nov 16 Python
python Selenium实现付费音乐批量下载的实现方法
Jan 24 Python
Python把对应格式的csv文件转换成字典类型存储脚本的方法
Feb 12 Python
python的sorted用法详解
Jun 25 Python
Python实现语音识别和语音合成功能
Sep 20 Python
Python sklearn中的.fit与.predict的用法说明
Jun 28 Python
Python面向对象实现方法总结
Aug 12 Python
Django项目创建及管理实现流程详解
Oct 13 Python
在python中读取和写入CSV文件详情
Jun 28 #Python
python数字图像处理之图像的批量处理
如何利用python实现Simhash算法
Jun 28 #Python
python数字图像处理:图像的绘制
python数字图像处理数据类型及颜色空间转换
python数据分析之单因素分析线性拟合及地理编码
python可视化分析绘制带趋势线的散点图和边缘直方图
You might like
通过对php一些服务器端特性的配置加强php的安全
2006/10/09 PHP
在VS2008中编译MYSQL5.1.48的方法
2010/07/03 PHP
ThinkPHP3.1新特性之动态设置自动完成及自动验证示例代码
2014/06/23 PHP
PHP实现动态添加XML中数据的方法
2018/03/30 PHP
js 判断checkbox是否选中的操作方法
2012/11/09 Javascript
animate动画示例(泪奔的小孩)及stop和delay的使用
2013/05/06 Javascript
Javascript实现页面跳转的几种方式分享
2013/10/26 Javascript
js+html5实现canvas绘制椭圆形图案的方法
2016/05/21 Javascript
JavaScript将DOM事件处理程序封装为event.js 出现的低级错误问题
2016/08/03 Javascript
对javascript继承的理解
2016/10/11 Javascript
bootstrap 下拉多选框进行多选传值问题代码分析
2017/02/14 Javascript
Vue框架中正确引入JS库的方法介绍
2017/07/30 Javascript
集成vue到jquery/bootstrap项目的方法
2018/02/10 jQuery
在小程序中使用canvas的方法示例
2018/09/17 Javascript
nginx部署多个vue项目的方法示例
2020/09/06 Javascript
在antd中setFieldsValue和defaultVal的用法
2020/10/29 Javascript
[57:38]2018DOTA2亚洲邀请赛3月30日 小组赛A组 OpTic VS OG
2018/03/31 DOTA
Python连接MySQL并使用fetchall()方法过滤特殊字符
2016/03/13 Python
Python多进程multiprocessing.Pool类详解
2018/04/27 Python
Python实现监控Nginx配置文件的不同并发送邮件报警功能示例
2019/02/26 Python
python图形开发GUI库pyqt5的详细使用方法及各控件的属性与方法
2020/02/14 Python
python实现电子词典
2020/03/03 Python
Pytorch数据拼接与拆分操作实现图解
2020/04/30 Python
基于pytorch中的Sequential用法说明
2020/06/24 Python
Python解析微信dat文件的方法
2020/11/30 Python
如何避免常见的6种HTML5错误用法
2017/11/06 HTML / CSS
HTML5单选框、复选框、下拉菜单、文本域的实现代码
2020/12/01 HTML / CSS
H&M美国官网:欧洲最大的服饰零售商
2016/09/07 全球购物
BSTN意大利:德国街头和运动文化高品质商店
2020/12/22 全球购物
如何在发生故障的节点上重新安装 SQL Server
2013/03/14 面试题
与C++相比,Java中的数组有什么不同
2014/03/25 面试题
三好学生演讲稿范文
2014/04/26 职场文书
弘扬雷锋精神演讲稿
2014/05/10 职场文书
环境科学专业求职信
2014/08/04 职场文书
2015初中政教处工作总结
2015/07/21 职场文书
观看《信仰》心得体会
2016/01/15 职场文书