Как проверить, является ли матрица матрицей вращения? - PullRequest
0 голосов
/ 17 декабря 2018

У меня есть задача проверить, является ли матрица матрицей вращения, я пишу код следующим образом:

import numpy as np    

def isRotationMatrix(R):
    # some code here
    # return True or False

R = np.array([
    [0, 0, 1],
    [1, 0, 0],
    [0, 1, 0],
])
print(isRotationMatrix(R))  # Should be True
R = np.array([
    [-1, 0, 0],
    [0, 1, 0],
    [0, 0, 1],
])
print(isRotationMatrix(R))  # Should be False

Я не знаю, как реализовать функцию isRotationMatrix.


Мой наивный инструмент, он работает только для матрицы 3х3:

def isRotationMatrix(R_3x3):
    should_be_norm_one = np.allclose(np.linalg.norm(R_3x3, axis=0), np.ones(shape=3))
    x = R_3x3[:, 0].ravel()
    y = R_3x3[:, 1].ravel()
    z = R_3x3[:, 2].ravel()
    should_be_perpendicular = \
        np.allclose(np.cross(x, y), z) \
        and np.allclose(np.cross(y, z), x) \
        and np.allclose(np.cross(z, x), y)
    return should_be_perpendicular and should_be_norm_one

Ответы [ 2 ]

0 голосов
/ 17 декабря 2018

Я использую это определение матрицы вращения.Матрица вращения должна удовлетворять условиям M (M^T) = (M^T) M = I и det(M) = I.Здесь M^T обозначает транспонирование M, I обозначает единичную матрицу, а det(M) представляет определитель матрицы M.

Вы можете использовать следующий код Python, чтобы проверить, является ли матрица вращениемматрица.

import numpy as np

''' I have chosen `M` as an example. Feel free to put in your own matrix.'''
M = np.array([[0,-1,0],[1,0,0],[0,0,1]]) 

def isRotationMatrix(M):
    tag = False
    I = np.identity(M.shape[0])
    if np.all((np.matmul(M, M.T)) == I) and (np.linalg.det(M)==1): tag = True
    return tag    

if(isRotationMatrix(M)): print 'M is a rotation matrix.'
else: print 'M is not a rotation matrix.'  
0 голосов
/ 17 декабря 2018

Матрица вращения - это ортонормированная матрица , и ее определитель должен быть равен 1.
Мое орудие:

import numpy as np


def isRotationMatrix(R):
    # square matrix test
    if R.ndim != 2 or R.shape[0] != R.shape[1]:
        return False
    should_be_identity = np.allclose(R.dot(R.T), np.identity(R.shape[0], np.float))
    should_be_one = np.allclose(np.linalg.det(R), 1)
    return should_be_identity and should_be_one


if __name__ == '__main__':
    R = np.array([
        [0, 0, 1],
        [1, 0, 0],
        [0, 1, 0],
    ])
    print(isRotationMatrix(R))  # True
    R = np.array([
        [-1, 0, 0],
        [0, 1, 0],
        [0, 0, 1],
    ])
    print(isRotationMatrix(R))  # True
    print(isRotationMatrix(np.zeros((3, 2))))  # False
...