【计算机视觉】使用仿射变换将一幅图像放置到另一幅图像中

这篇博客探讨了如何利用计算机视觉中的仿射变换,通过`Haffine_from_points`函数计算单应性矩阵,将一幅图像精确地放置到另一幅图像中。介绍了`image_in_image`函数的应用,它允许指定图像的角点坐标,实现图像的合理定位。同时,还讲解了alpha通道在处理图像透明度中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、涉及函数及原理:

1、Haffine_from_points函数

  计算单应性矩阵H,仿射变换,使得tp是fp经过仿射变换H得到的。该函数会返回给定对应点对的最优仿射变换。该函数是使用对应点对来计算过仿射变换矩阵。

  • 仿射变换

    仿射变换属于单应性变换,单应性变换是将一个平面内的点映射到另一个平面内的二维投影变换。仿射变换就是允许图像任意伸缩的变换,可以保持原来的线共点,点共线的关系不变,保持原来相互平行的线仍然平行,保持原来的中点仍然是中点,保持原来在一直线上几段线段之间的比例关系不变。但是仿射变换不能保持原来的线段长度不变,也不能保持原来的夹角角度不变。如下图:

仿射变换包含一个可逆矩阵A和一个平移向量t=[tx,ty]。 

仿射变换函数

Haffine_from_points函数代码:

from pylab import *
def Haffime_from_points(fp,tp):

    if fp.shape !=tp.shape:
        raise RuntimeError('number of point do not match')

    #对点进行归一化
    #映射起始点
    m = mean(fp[:2],axis=1)
    maxstd=max(std(fp[:2],axis=1))+1e-9
    C1 = diag([1
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值