各位小伙伴们,大家好呀!看看今天我又给各位带来了什么文章?本文标题是《如何从透视变换的连接点集计算变换矩阵》,很明显是关于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
2024-04-05
2024-04-05
2024-04-05
2024-04-04
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0