返回顶部
首页 > 资讯 > 后端开发 > GO >如何从透视变换的连接点集计算变换矩阵
  • 617
分享到

如何从透视变换的连接点集计算变换矩阵

2024-04-05 00:04:29 617人浏览 安东尼
摘要

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题是《如何从透视变换的连接点集计算变换矩阵》,很明显是关于golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错

各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题是《如何从透视变换的连接点集计算变换矩阵》,很明显是关于golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错的话,欢迎各位多多点评和分享!

问题内容

我正在尝试使用 libvips 实现相当于 imagemagick 透视扭曲的功能 Http://www.imagemagick.org/usage/violets/#perspective

根据这个答案如何在 vips 中执行透视扭曲变换?可以使用mapim来实现

但是我不明白如何将 imagemagick 中使用的一组连接点转换为这种类型的转换矩阵

T = [1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0003, 0.0001]


解决方案


可以通过求解该线性方程组找到变换向量:

/ x0 y0  1  0  0  0 -x0*u0 -y0*u0 \ /c00\ /u0\
| x1 y1  1  0  0  0 -x1*u1 -y1*u1 | |c01| |u1|
| x2 y2  1  0  0  0 -x2*u2 -y2*u2 | |c02| |u2|
| x3 y3  1  0  0  0 -x3*u3 -y3*u3 |.|c10|=|u3|
|  0  0  0 x0 y0  1 -x0*v0 -y0*v0 | |c11| |v0|
|  0  0  0 x1 y1  1 -x1*v1 -y1*v1 | |c12| |v1|
|  0  0  0 x2 y2  1 -x2*v2 -y2*v2 | |c20| |v2|
\  0  0  0 x3 y3  1 -x3*v3 -y3*v3 / \c21/ \v3/

其中 x0.., y0.. 是目标坐标,u0.. v0.. 是源坐标。

以下是如何使用 Gonum 包解决这个问题:

func calculateTransfORMation(coordinates []float64) mat.VecDense {

    u0, v0, x0, y0 := coordinates[0], coordinates[1], coordinates[2], coordinates[3]
    u1, v1, x1, y1 := coordinates[4], coordinates[5], coordinates[6], coordinates[7]
    u2, v2, x2, y2 := coordinates[8], coordinates[9], coordinates[10], coordinates[11]
    u3, v3, x3, y3 := coordinates[12], coordinates[13], coordinates[14], coordinates[15]

    // The data must be arranged in row-major order, i.e. the (i*c + j)-th
    // element in the data slice is the {i, j}-th element in the matrix.
    Adata := []float64{
        x0, y0, 1, 0, 0, 0, -x0 * u0, -y0 * u0,
        x1, y1, 1, 0, 0, 0, -x1 * u1, -y1 * u1,
        x2, y2, 1, 0, 0, 0, -x2 * u2, -y2 * u2,
        x3, y3, 1, 0, 0, 0, -x3 * u3, -y3 * u3,
        0, 0, 0, x0, y0, 1, -x0 * v0, -y0 * v0,
        0, 0, 0, x1, y1, 1, -x1 * v1, -y1 * v1,
        0, 0, 0, x2, y2, 1, -x2 * v2, -y2 * v2,
        0, 0, 0, x3, y3, 1, -x3 * v3, -y3 * v3,
    }
    A := mat.NewDense(8, 8, Adata)
    b := mat.NewVecDense(8, []float64{u0, u1, u2, u3, v0, v1, v2, v3})
    result := mat.VecDense{}
    var err error
    err = result.SolveVec(A, b)
    if err != nil {
        fmt.Print(err)
    }
    return result
}

以上就是《如何从透视变换的连接点集计算变换矩阵》的详细内容,更多关于的资料请关注编程网公众号!

您可能感兴趣的文档:

--结束END--

本文标题: 如何从透视变换的连接点集计算变换矩阵

本文链接: https://lsjlt.com/news/596345.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何从透视变换的连接点集计算变换矩阵
    各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题是《如何从透视变换的连接点集计算变换矩阵》,很明显是关于Golang的文章哈哈哈,其中内容主要会涉及到等等,如果能帮到你,觉得很不错...
    99+
    2024-04-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作