许可优化
许可优化
产品
产品
解决方案
解决方案
服务支持
服务支持
关于
关于
软件库
当前位置:服务支持 >  软件文章 >  仿射变换与透视变换:二维坐标线性变换及其在人脸Landmark矫正中的应用

仿射变换与透视变换:二维坐标线性变换及其在人脸Landmark矫正中的应用

阅读数 1
点赞 0
article_banner


仿射变换:

仿射变换是一种二维坐标到二维坐标之间的线性变换,并保持二维图形的“平直性”。转换前平行的线,在转换后依然平行。如下图:

import cv2import numpy as npfrom matplotlib import pyplot as plt img = cv2.imread('lena.jpg', 1)rows,cols,channel = img.shape pts1 = np.float32([[50,50],[200,50],[50,200]])pts2 = np.float32([[10,100],[200,50],[100,250]]) M = cv2.getAffineTransform(pts1,pts2) dst = cv2.warpAffine(img,M,(cols,rows)) plt.subplot(121),plt.imshow(img),plt.title('Input')plt.subplot(122),plt.imshow(dst),plt.title('Output')plt.show()

透视变换:

透视变换需要3×3的变换矩阵,直线在变换后还是保持直线。为了构造变换矩阵,你需要输入图像的4个点和对应的要输出图像的4个点;要求这4个点其中3个点不共线。使用cv2.getPerspectiveTransform函数构造透视变换矩阵。代码:


import cv2import numpy as npfrom matplotlib import pyplot as plt img = cv2.imread('sudu.jpg', 1)rows,cols,ch = img.shape pts1 = np.float32([[56,65],[368,52],[28,387],[389,390]])pts2 = np.float32([[0,0],[300,0],[0,300],[300,300]]) M = cv2.getPerspectiveTransform(pts1,pts2) dst = cv2.warpPerspective(img,M,(300,300)) plt.subplot(121),plt.imshow(img),plt.title('Input')plt.subplot(122),plt.imshow(dst),plt.title('Output')plt.show()


还可以参考:仿射变换和透视变换


还可以用下面代码鼠标获取四个点进行仿射变换:


# -*- coding: utf-8 -*- import numpy as npimport cv2 def gen_point(event,x,y,flags,param):    if event == cv2.EVENT_LBUTTONDBLCLK:        print (x,y) # img = np.zeros((512,512,3),np.uint8)img = cv2.imread("lp.jpg")cv2.namedWindow('image', 2)cv2.setMouseCallback('image',gen_point) while(1):    cv2.imshow('image',img)    if cv2.waitKey(20) & 0xFF == 27:        breakcv2.destroyAllWindows()


免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删


相关文章
技术文档
QR Code
微信扫一扫,欢迎咨询~
customer

online

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 board-phone 155-2731-8020
close1
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

姓名不为空

姓名不为空
手机不正确

手机不正确

手机不正确
公司不为空

公司不为空

公司不为空