24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 3414  |  回复: 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;
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

YBQ大学

禁虫 (正式写手)

★ ★
lovibond(金币+2): 不适合作为资源帖,但是要鼓励原创分享 2011-06-27 21:00:00
本帖内容被屏蔽

2楼2010-09-03 13:26:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

想飞的猪

木虫 (正式写手)

引用回帖:
Originally posted by YBQ大学 at 2010-09-03 13:26:46:
运行不会报错吧

你是在哪个平台上写的

这个只是计算没有涉及太多的接口,什么平台都可以吧!而且我不知道你的平台指什么,系统还是开发软件,我的是在XP用VC++6.0写的!

感觉你的编程能力不是很...!
好好学学吧!
3楼2010-09-04 12:48:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

牛耕地

银虫 (初入文坛)

0.8

顶!好东西!
4楼2011-02-17 15:50:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

想飞的猪

木虫 (正式写手)

引用回帖:
Originally posted by 牛耕地 at 2011-02-17 15:50:00:
顶!好东西!

谢谢!以后多交流!我用OpenGL做了个东西!
5楼2011-02-17 20:42:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

牛耕地

银虫 (初入文坛)

好,我就是做虚拟人动画的,对这个也比较了解。
不过我没有实现过IK的东西,能把你的东西分享一下吗?
引用回帖:
Originally posted by 想飞的猪 at 2011-02-17 20:42:08:



谢谢!以后多交流!我用OpenGL做了个东西!

6楼2011-02-18 09:29:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

想飞的猪

木虫 (正式写手)

引用回帖:
Originally posted by 牛耕地 at 2011-02-18 09:29:02:
好,我就是做虚拟人动画的,对这个也比较了解。
不过我没有实现过IK的东西,能把你的东西分享一下吗?


IK是什么啊?
7楼2011-02-18 13:27:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

牛耕地

银虫 (初入文坛)

inverse kinematics

你计算雅可比不是用来求解逆运动学吗?
引用回帖:
Originally posted by 想飞的猪 at 2011-02-18 13:27:15:


IK是什么啊?

8楼2011-02-18 15:07:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

想飞的猪

木虫 (正式写手)

引用回帖:
Originally posted by 牛耕地 at 2011-02-18 15:07:10:
inverse kinematics

你计算雅可比不是用来求解逆运动学吗?


哦!呵呵!
9楼2011-02-18 17:47:42
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

ytinghost3

铁杆木虫 (著名写手)

帖子真精彩!
已经收录到淘贴专辑《机器人技术专辑
谎言与誓言的区别在于:一个是听的人当真了,一个是说的人当真了。
10楼2011-09-01 22:14:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 想飞的猪 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085600材料与化工301分求调剂院校 +16 刺痛jk 2026-04-06 17/850 2026-04-06 19:47 by 电池阿白
[考研] 274求调剂求调剂 +5 Jachenbingoo 2026-04-06 5/250 2026-04-06 17:20 by 蓝云思雨
[考研] 材料工程310专硕调剂 +14 捞捞我…. 2026-04-04 15/750 2026-04-06 14:18 by lqwchd
[考研] 362求调剂一志愿中国石油大学 +4 我要考大 2026-04-06 6/300 2026-04-06 14:11 by 无际的草原
[考研] 化学调剂求助 +8 LULONG1 2026-04-03 8/400 2026-04-06 10:26 by dongzh2009
[考研] 0855求调剂材料 +11 红桃灼灼 2026-04-04 12/600 2026-04-06 10:26 by 蓝云思雨
[考研] 找调剂 +10 楚乔乔 2026-04-01 10/500 2026-04-05 22:19 by syh9288
[考研] 322求调剂 +3 嗯哼哼恒 2026-04-05 3/150 2026-04-05 19:52 by nepu_uu
[考研] 348求调剂 +6 wukira 2026-04-04 6/300 2026-04-05 18:11 by 猪会飞
[考研] 323分(计算机视觉和大模型项目)能直接上手 +3 chaoxiicy 2026-04-01 3/150 2026-04-05 00:50 by chongya
[考研] 290求调剂 +7 luoziheng 2026-04-04 7/350 2026-04-04 23:17 by lqwchd
[考研] 295求调剂 +4 A你好研究生 2026-04-04 5/250 2026-04-04 22:46 by yu221
[考研] 一志愿上海大学生物学346 +3 上海大学346调剂 2026-04-03 3/150 2026-04-04 20:20 by dongzh2009
[考研] 321求调剂 +13 认真求上学 2026-04-02 13/650 2026-04-04 18:23 by macy2011
[考研] 求调剂 +3 usbdndj 2026-04-03 3/150 2026-04-03 14:10 by dxiaoxin
[考研] 一志愿北交大材料工程总分358 +8 cs0106 2026-04-01 9/450 2026-04-02 10:36 by 不吃魚的貓
[考研] 材料求调剂 +10 呢呢妮妮 2026-04-01 13/650 2026-04-02 09:17 by olim
[考研] 省双一流重点一本大学招收调剂 +4 wwwwffffff 2026-03-31 7/350 2026-04-01 15:23 by wwwwffffff
[考研] 材料调剂 +11 一样YWY 2026-03-31 11/550 2026-04-01 11:35 by wangjy2002
[考研] 土木304求调剂 +5 顶级擦擦 2026-03-31 5/250 2026-04-01 08:15 by fdcxdystjk¥
信息提示
请填处理意见