scipy.spatial.transform.Rotation.
as_matrix#
- Rotation.as_matrix(self)#
Als Rotationsmatrix darstellen.
3D-Rotationen können mithilfe von Rotationsmatrizen dargestellt werden, die 3x3 reelle orthogonale Matrizen mit Determinante +1 sind [1].
- Rückgabe:
- matrixndarray, Form (3, 3) oder (N, 3, 3)
Die Form hängt von der Form der bei der Initialisierung verwendeten Eingaben ab.
Hinweise
Diese Funktion wurde früher als_dcm aufgerufen.
Hinzugefügt in Version 1.4.0.
Referenzen
Beispiele
>>> from scipy.spatial.transform import Rotation as R >>> import numpy as np
Eine einzelne Rotation darstellen
>>> 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)
Einen Stapel mit einer einzelnen Rotation darstellen
>>> 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)
Mehrere Rotationen darstellen
>>> 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)