| 查看: 3190 | 回复: 13 | ||||||
想飞的猪木虫 (正式写手)
|
[交流]
【原创】六自由度机器人Jacobian(雅克比)矩阵计算类已有1人参与
|
|
作者:想飞的猪 说明:MLGetIdentityMat为获得单位矩阵函数 MLMatMulti为矩阵相乘函数 和OpenCV求逆矩阵函数cvInvert没有给出请大家自己写一下!很简单的! typedef struct RobotJacobian6 { //变量! //各关节传递矩阵! union { struct { double AMat[6][4][4]; }; double A0to1[4][4]; double A1to2[4][4]; double A2to3[4][4]; double A3to4[4][4]; double A4to5[4][4]; double A5to6[4][4]; }; union { struct { double TMat[6][4][4]; }; struct { double T0to6[4][4]; double T1to6[4][4]; double T2to6[4][4]; double T3to6[4][4]; double T4to6[4][4]; double T5to6[4][4]; }; }; //末端位姿! double EndPose[4][4]; //D-H参数表! double DHParam[6][4];//顺序为:Angle d_L a_L a_A! //雅克比矩阵! double EndJacobian[6][6]; //逆雅克比矩阵! double EndInvJacobian[6][6]; //基坐标的笛卡尔微分运动到末端坐标的传递矩阵! double JBasetoEnd[6][6]; double T_1to6[4][4];//该矩阵的姿态与基坐标一致,位置与末端坐标一致! //以便可以按照基坐标进行平动和绕基坐标轴方向转动! double mInput[6]; //输入! double mOutput[6];//输出! int mMode; void GetAMat() { for (int i=0;i<6;i++) { MLGetDHTransMat(AMat,DHParam[0],DHParam[1],DHParam[2],DHParam[3]); } } void GetTMat() { MLGetIdentityMat(T5to6); MLMatMulti(AMat[5],T5to6); MLMatMulti(AMat[4],T5to6,T4to6); MLMatMulti(AMat[3],T4to6,T3to6); MLMatMulti(AMat[2],T3to6,T2to6); MLMatMulti(AMat[1],T2to6,T1to6); MLMatMulti(AMat[0],T1to6,T0to6); } void UpdateAngle(double Angles[6])//Angles为弧度! { for (int i=0;i<6;i++) { DHParam[0]=Angles; } GetAMat(); GetEndPose(); GetTMat(); GetEndJacobian(); GetEndInvJacobian(); GetJBasetoEnd(); } void Inti(double DHparameter[6][4]) { for (int i=0;i<6;i++) { for (int j=0;j<4;j++) { DHParam[j]=DHparameter[j]; } } GetAMat(); GetEndPose(); GetTMat(); GetEndJacobian(); GetEndInvJacobian(); GetJBasetoEnd(); for (i=0;i<6;i++) { mInput=0; mOutput=0; } mMode=BASE; } void GetEndPose() { MLGetIdentityMat(EndPose); for (int i=0;i<6;i++) { MLMatMulti(AMat[5-i],EndPose); } } void GetEndJacobian() { for (int i=0;i<6;i++) { EndJacobian[0]=-1*TMat[Xx][Nn]*TMat[Yy][Pp]+TMat[Yy][Nn]*TMat[Xx][Pp]; EndJacobian[1]=-1*TMat[Xx][Oo]*TMat[Yy][Pp]+TMat[Yy][Oo]*TMat[Xx][Pp]; EndJacobian[2]=-1*TMat[Xx][Aa]*TMat[Yy][Pp]+TMat[Yy][Aa]*TMat[Xx][Pp]; EndJacobian[3]=TMat[Zz][Nn]; EndJacobian[4]=TMat[Zz][Oo]; EndJacobian[5]=TMat[Zz][Aa]; } } void GetEndInvJacobian() { double Data1[36]; CvMat Mat1 = cvMat( 6,6,CV_64FC1,Data1); double Data2[36]; CvMat Mat2 = cvMat( 6,6,CV_64FC1,Data2); for (int i=0;i<6;i++) { for (int j=0;j<6;j++) { cvmSet(&Mat1,i,j,EndJacobian[j]); } } cvInvert(&Mat1,&Mat2,CV_SVD); for (i=0;i<6;i++) { for (int j=0;j<6;j++) { EndInvJacobian[j]=cvmGet(&Mat2,i,j); } } } void EndOutput(double Input[6], double Output[6])//Output为角速度! { MLMatMulti_3(EndInvJacobian,Input,Output); } void GetJBasetoEnd() { double TransMat[4][4]; MLGetIdentityMat(TransMat); TransMat[0][3]=-1*EndPose[0][3]; TransMat[1][3]=-1*EndPose[1][3]; TransMat[2][3]=-1*EndPose[2][3]; MLMatMulti(TransMat,EndPose,T_1to6); JBasetoEnd[0][0]=T_1to6[Xx][Nn]; JBasetoEnd[0][1]=T_1to6[Yy][Nn]; JBasetoEnd[0][2]=T_1to6[Zz][Nn]; JBasetoEnd[1][0]=T_1to6[Xx][Oo]; JBasetoEnd[1][1]=T_1to6[Yy][Oo]; JBasetoEnd[1][2]=T_1to6[Zz][Oo]; JBasetoEnd[2][0]=T_1to6[Xx][Aa]; JBasetoEnd[2][1]=T_1to6[Yy][Aa]; JBasetoEnd[2][2]=T_1to6[Zz][Aa]; for (int i=3;i<6;i++) { for (int j=0;j<3;j++) { JBasetoEnd[j]=0; } } JBasetoEnd[3][3]=T_1to6[Xx][Nn]; JBasetoEnd[3][4]=T_1to6[Yy][Nn]; JBasetoEnd[3][5]=T_1to6[Zz][Nn]; JBasetoEnd[4][3]=T_1to6[Xx][Oo]; JBasetoEnd[4][4]=T_1to6[Yy][Oo]; JBasetoEnd[4][5]=T_1to6[Zz][Oo]; JBasetoEnd[5][3]=T_1to6[Xx][Aa]; JBasetoEnd[5][4]=T_1to6[Yy][Aa]; JBasetoEnd[5][5]=T_1to6[Zz][Aa]; JBasetoEnd[0][3]=T_1to6[Yy][Pp]*T_1to6[Zz][Nn]-T_1to6[Zz][Pp]*T_1to6[Yy][Nn];//(P×N)x JBasetoEnd[0][4]=T_1to6[Zz][Pp]*T_1to6[Xx][Nn]-T_1to6[Xx][Pp]*T_1to6[Zz][Nn];//(P×N)y JBasetoEnd[0][5]=T_1to6[Xx][Pp]*T_1to6[Yy][Nn]-T_1to6[Yy][Pp]*T_1to6[Xx][Nn];//(P×N)z JBasetoEnd[1][3]=T_1to6[Yy][Pp]*T_1to6[Zz][Oo]-T_1to6[Zz][Pp]*T_1to6[Yy][Oo];//(P×O)x JBasetoEnd[1][4]=T_1to6[Zz][Pp]*T_1to6[Xx][Oo]-T_1to6[Xx][Pp]*T_1to6[Zz][Oo];//(P×O)y JBasetoEnd[1][5]=T_1to6[Xx][Pp]*T_1to6[Yy][Oo]-T_1to6[Yy][Pp]*T_1to6[Xx][Oo];//(P×O)z JBasetoEnd[2][3]=T_1to6[Yy][Pp]*T_1to6[Zz][Aa]-T_1to6[Zz][Pp]*T_1to6[Yy][Aa];//(P×A)x JBasetoEnd[2][4]=T_1to6[Zz][Pp]*T_1to6[Xx][Aa]-T_1to6[Xx][Pp]*T_1to6[Zz][Aa];//(P×A)y JBasetoEnd[2][5]=T_1to6[Xx][Pp]*T_1to6[Yy][Aa]-T_1to6[Yy][Pp]*T_1to6[Xx][Aa];//(P×A)z } void BaseOutput(double BaseInput[6], double Output[6])//Output为角速度! { double EndInput[6]; MLMatMulti_3(JBasetoEnd,BaseInput,EndInput); EndOutput(EndInput,Output); } void SetInput(double Input[6]) { for (int i=0;i<6;i++) { mInput=Input; } } void SetMode(int mode) { mMode=mode; } void GetOutput(int mode=BASE) { int i=0; int j=0; switch(mode) { case eND: EndOutput(mInput,mOutput); break; case BASE: BaseOutput(mInput,mOutput); break; } } RobotJacobian6() { } RobotJacobian6(double DHparameter[6][4]) { Inti(DHparameter); } }MLJacobian; |
» 收录本帖的淘帖专辑推荐
机器人技术专辑 | 蓝袋 | 机器人学 |
» 猜你喜欢
请问有评职称,把科研教学业绩算分排序的高校吗
已经有6人回复
2025冷门绝学什么时候出结果
已经有6人回复
Bioresource Technology期刊,第一次返修的时候被退回好几次了
已经有7人回复
真诚求助:手里的省社科项目结项要求主持人一篇中文核心,有什么渠道能发核心吗
已经有8人回复
寻求一种能扛住强氧化性腐蚀性的容器密封件
已经有5人回复
请问哪里可以有青B申请的本子可以借鉴一下。
已经有4人回复
请问下大家为什么这个铃木偶联几乎不反应呢
已经有5人回复
天津工业大学郑柳春团队欢迎化学化工、高分子化学或有机合成方向的博士生和硕士生加入
已经有4人回复
康复大学泰山学者周祺惠团队招收博士研究生
已经有6人回复
AI论文写作工具:是科研加速器还是学术作弊器?
已经有3人回复
» 本主题相关价值贴推荐,对您同样有帮助:
逆矩阵中的某一列的和与原矩阵是什么关系?如何计算?
已经有4人回复
关于基于VC的矩阵类
已经有3人回复
自由度到底是怎么算的啊!
已经有3人回复
四自由度步行机器人结构设计
已经有5人回复
在坐标转换里,Jacobian矩阵到底怎么用的
已经有5人回复
求C++ MFC矩阵相乘代码!!!
已经有5人回复
如何修改雅克比矩阵
已经有4人回复
自由度的计算,求解
已经有7人回复
从心理学角度看机器人要具备智慧的关键几步
已经有3人回复
【求助】矩阵相乘
已经有8人回复
★ ★
lovibond(金币+2): 不适合作为资源帖,但是要鼓励原创分享 2011-06-27 21:00:00
lovibond(金币+2): 不适合作为资源帖,但是要鼓励原创分享 2011-06-27 21:00:00
|
本帖内容被屏蔽 |
2楼2010-09-03 13:26:46
想飞的猪
木虫 (正式写手)
- 应助: 40 (小学生)
- 金币: 12225.4
- 散金: 1831
- 红花: 9
- 帖子: 584
- 在线: 156.7小时
- 虫号: 584434
- 注册: 2008-08-01
- 性别: GG
- 专业: 机器人学及机器人技术
3楼2010-09-04 12:48:37
牛耕地
银虫 (初入文坛)
- 应助: 0 (幼儿园)
- 金币: 224.3
- 散金: 20
- 帖子: 35
- 在线: 24.6小时
- 虫号: 1156142
- 注册: 2010-11-26
- 性别: GG
- 专业: 计算机应用技术
4楼2011-02-17 15:50:00
想飞的猪
木虫 (正式写手)
- 应助: 40 (小学生)
- 金币: 12225.4
- 散金: 1831
- 红花: 9
- 帖子: 584
- 在线: 156.7小时
- 虫号: 584434
- 注册: 2008-08-01
- 性别: GG
- 专业: 机器人学及机器人技术
5楼2011-02-17 20:42:08
牛耕地
银虫 (初入文坛)
- 应助: 0 (幼儿园)
- 金币: 224.3
- 散金: 20
- 帖子: 35
- 在线: 24.6小时
- 虫号: 1156142
- 注册: 2010-11-26
- 性别: GG
- 专业: 计算机应用技术
6楼2011-02-18 09:29:02
想飞的猪
木虫 (正式写手)
- 应助: 40 (小学生)
- 金币: 12225.4
- 散金: 1831
- 红花: 9
- 帖子: 584
- 在线: 156.7小时
- 虫号: 584434
- 注册: 2008-08-01
- 性别: GG
- 专业: 机器人学及机器人技术
7楼2011-02-18 13:27:15
牛耕地
银虫 (初入文坛)
- 应助: 0 (幼儿园)
- 金币: 224.3
- 散金: 20
- 帖子: 35
- 在线: 24.6小时
- 虫号: 1156142
- 注册: 2010-11-26
- 性别: GG
- 专业: 计算机应用技术
8楼2011-02-18 15:07:10
想飞的猪
木虫 (正式写手)
- 应助: 40 (小学生)
- 金币: 12225.4
- 散金: 1831
- 红花: 9
- 帖子: 584
- 在线: 156.7小时
- 虫号: 584434
- 注册: 2008-08-01
- 性别: GG
- 专业: 机器人学及机器人技术
9楼2011-02-18 17:47:42
ytinghost3
铁杆木虫 (著名写手)
- 应助: 113 (高中生)
- 金币: 7263.5
- 散金: 611
- 红花: 31
- 帖子: 2940
- 在线: 339.7小时
- 虫号: 931663
- 注册: 2009-12-21
- 专业: 机构学与机器人

10楼2011-09-01 22:14:38













回复此楼