前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >图像复合变换

图像复合变换

作者头像
裴来凡
发布2022-05-29 09:55:55
发布2022-05-29 09:55:55
36800
代码可运行
举报
运行总次数:0
代码可运行
代码语言:javascript
代码运行次数:0
运行
复制
import cv2
import numpy as np
from matplotlib import pyplot as plt  
img=cv2.imread('C:/Users/xpp/Desktop/Lena.png') 
height,width=img.shape[:2]
fx,fy=0.6,0.6#图像缩放比例
MAZ=np.float32([[fx,0,0],[0,fy,0]])#构造缩放变换矩阵
imgT1=cv2.warpAffine(img,MAZ,(width,height))#仿射变换, 黑色填充
dx,dy=50,200#dx=100向右偏移量,dy=50向下偏移量
MAT=np.float32([[1,0,dx],[0,1,dy]])#构造平移变换矩阵
imgT2=cv2.warpAffine(imgT1,MAT,(width,height),borderValue=(0,255,255))#实现仿射变换
theta=-30*np.pi/180#逆时针旋转 30°
cosTheta=np.cos(theta)
sinTheta=np.sin(theta)
MAR = np.float32([[cosTheta,-sinTheta,0],[sinTheta,cosTheta,0]])#构造旋转变换矩阵
imgT3=cv2.warpAffine(imgT2,MAR,(width,height),borderValue=(255,255,0))#实现仿射变换
theta=-30*np.pi/180#逆时针扭变 30°
MAS=np.float32([[1,np.tan(theta),0],[0,1,0]])#构造扭变变换矩阵
imgT4=cv2.warpAffine(imgT3,MAS,(width,height),borderValue=(255,0,255))#实现仿射变换
plt.figure(figsize=(9,6))
plt.subplot(221),plt.axis('off'),plt.title("T1:Zoom")
plt.imshow(cv2.cvtColor(imgT1, cv2.COLOR_BGR2RGB)),
plt.subplot(222),plt.axis('off'),plt.title("T2:Translation")
plt.imshow(cv2.cvtColor(imgT2, cv2.COLOR_BGR2RGB))
plt.subplot(223),plt.axis('off'),plt.title("T3:Rotation")
plt.imshow(cv2.cvtColor(imgT3, cv2.COLOR_BGR2RGB))
plt.subplot(224),plt.axis('off'),plt.title("T4:Shear")
plt.imshow(cv2.cvtColor(imgT4, cv2.COLOR_BGR2RGB))
plt.show()

算法:图像复合变换是指对给定的图像连续进行多次上述的平移、旋转、翻转、缩放、错切等基本变换,也称为级联变换。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-12-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 图像处理与模式识别研究所 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档