Python根据欧拉角求旋转矩阵的实例
时间:2021-04-21 09:37:52|栏目:Python代码|点击: 次
利用numpy和scipy,我们可以很容易根据欧拉角求出旋转矩阵,这里的旋转轴我们你理解成四元数里面的旋转轴
import numpy as np
import scipy.linalg as linalg
import math
#参数分别是旋转轴和旋转弧度值
def rotate_mat(self, axis, radian):
rot_matrix = linalg.expm(np.cross(np.eye(3), axis / linalg.norm(axis) * radian))
axis_x, axis_y, axis_z = [1,0,0], [0,1,0], [0, 0, 1]#分别是x,y和z轴,也可以自定义旋转轴
yaw = 0.7854 #pi/4
rot_matrix = rotate_mat(axis_z, yaw)#绕Z轴旋转pi/4
求出旋转矩阵后我们可以结合原始坐标, 直接用np.dot求出旋转前后的坐标.
new_coor = np.dot(old_coor, rot_matrix)
上一篇:python去除字符串中的换行符
栏 目:Python代码
下一篇:对Python 两大环境管理神器 pyenv 和 virtualenv详解
本文标题:Python根据欧拉角求旋转矩阵的实例
本文地址:http://www.codeinn.net/misctech/105632.html






