使用numpy中的旋转矩阵有效旋转一组点 [英] Efficiently rotate a set of points with a rotation matrix in numpy

查看:476
本文介绍了使用numpy中的旋转矩阵有效旋转一组点的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个3D点列表,它们存储在形状为(N,3)的numpy数组A和形状为(3,3)的旋转矩阵R中.我想就地为A中的每个点x计算R.x的点积.我可以天真地做到这一点:

I have a list of 3D points stored in numpy array A with shape (N,3) and a rotation matrix R with shape (3,3). I'd like to compute the dot product of R.x for each point x in A in-place. Naively I can do this:

for n in xrange(N):
    A[n,:] = dot(R, A[n,:]) 

是否可以通过本机numpy调用将其向量化?如果重要的话,N大约是几千.

Is there a way to vectorize this with a native numpy call? If it matters, N is on order of a couple thousand.

推荐答案

您可以将A与旋转矩阵的转置相乘:

You can multiply A with the transpose of the rotation matrix:

A = dot(A, R.T)

这篇关于使用numpy中的旋转矩阵有效旋转一组点的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆