scipy.spatial.transform.Rotation.

as_matrix#

Rotation.as_matrix(self)#

表示为旋转矩阵。

3D 旋转可以使用旋转矩阵表示,它是行列式等于 +1 的 3 x 3 实正交矩阵 [1]

返回:
matrixndarray,形状为 (3, 3) 或 (N, 3, 3)

形状取决于初始化时使用的输入形状。

备注

此函数之前名为 as_dcm。

在 1.4.0 版本中添加。

参考文献

示例

>>> from scipy.spatial.transform import Rotation as R
>>> import numpy as np

表示单个旋转

>>> r = R.from_rotvec([0, 0, np.pi/2])
>>> r.as_matrix()
array([[ 2.22044605e-16, -1.00000000e+00,  0.00000000e+00],
       [ 1.00000000e+00,  2.22044605e-16,  0.00000000e+00],
       [ 0.00000000e+00,  0.00000000e+00,  1.00000000e+00]])
>>> r.as_matrix().shape
(3, 3)

表示具有单个旋转的堆栈

>>> r = R.from_quat([[1, 1, 0, 0]])
>>> r.as_matrix()
array([[[ 0.,  1.,  0.],
        [ 1.,  0.,  0.],
        [ 0.,  0., -1.]]])
>>> r.as_matrix().shape
(1, 3, 3)

表示多个旋转

>>> r = R.from_rotvec([[np.pi/2, 0, 0], [0, 0, np.pi/2]])
>>> r.as_matrix()
array([[[ 1.00000000e+00,  0.00000000e+00,  0.00000000e+00],
        [ 0.00000000e+00,  2.22044605e-16, -1.00000000e+00],
        [ 0.00000000e+00,  1.00000000e+00,  2.22044605e-16]],
       [[ 2.22044605e-16, -1.00000000e+00,  0.00000000e+00],
        [ 1.00000000e+00,  2.22044605e-16,  0.00000000e+00],
        [ 0.00000000e+00,  0.00000000e+00,  1.00000000e+00]]])
>>> r.as_matrix().shape
(2, 3, 3)