scipy.spatial.transform.Rotation.

as_matrix#

Rotation.as_matrix(self)#

表示为旋转矩阵。

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

返回:
矩阵ndarray, 形状 (3, 3) 或 (N, 3, 3)

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

注释

此函数之前被称为 as_dcm。

Added in version 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)