5、matlab串联机器人DH改进型-手写正解函数(推荐)

本文介绍了一个手写矩阵函数myfkine.m,用于实现串联机器人的DH参数正解计算。通过与MATLAB内置工具的计算结果对比,验证了函数的正确性。提供了一个D-H改进型Matlab程序的下载链接。
摘要由CSDN通过智能技术生成

1、手写矩阵函数myfkine.m

%改进型D-H建模
function [T06]=myfkine(theta1,theta2,theta3,theta4,theta5,theta6)

%    theta      d         a           alpha
%    关节转角   关节距离   连杆长度     连杆扭角

MDH=[theta1     0.4       0.025       pi/2;
     theta2     0         0.56        0;
     theta3     0         0.035       pi/2;
     theta4     0.515     0           pi/2;
     theta5     0         0           pi/2;
     theta6     0.08       0         0];
 
T01=[cos(MDH(1,1))                 -sin(MDH(1,1))                 0               MDH(1,3);
     cos(MDH(1,4))*sin(MDH(1,1))    cos(MDH(1,4))*cos(MDH(1,1))  -sin(MDH(1,4))  -MDH(1,2)*sin(MDH(1,4));
     sin(MDH(1,4))*sin(MDH(1,1))    sin(MDH(1,4))*cos(MDH(1,1))   cos(MDH(1,4))   MDH(1,2)*cos(MDH(1,4));
     0                              0                             0               1];
T12=[cos(MDH(2,1))                 -sin(MDH(2,1))                 0               MDH(2,3);
     cos(MDH(2,4))*sin(MDH(2,1))    cos(MDH(2,4))*
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MatlabSimMechanics三自由度串联机器人正解反解-MyRobot_moveline.rar 上次我发了二自由度串联机器人正解和反解的贴子,可能这个论坛的高手觉得太简单了,都问我做的是是不是并联机器人。 前几天我感到很羞愧,也知道在这个论坛一定不能班门弄斧,本来我想把这次做的东西在年前就贴出来的,但是鼓励了一下自己,先做了一个六自由度机器人,我已经贴了出来。 这次是一个比较简单的串联三自由度机器人 手头也正准备做两个平面并联的机器人,还望大家多给我点意见。 我才只有大学三年级,毫无疑问是一个菜鸟,要好好向老鸟学习才是。 我先简单说明我建立模型的思路和步骤 首先,制作一个生成轨迹的子系统,这个用最简单的simulink就可以做出来。 然后,制作一个simmechanics的系统,这是整个仿真的关键部分,还是强调坐标系的灵活使用。 再者,制作一个位置逆解的程序,这里我个人比较喜欢使用数值解法,只要用一个matlabfun模块就可以把m文件和simulink结合起来,可以大大的减少工作量,实现复杂的功能。 最后,制作joint的输入模块,所有的输入都是转动的位移,这一步是最简单的。 主要用到matlab中的一个模块和一个命令Simechanics模块和优化工具箱中的fsolve命令 好了言归正传,我先说简单的三自由度机器人,这个就是最典型的PUMA机器人 但是我必须要说明的是,我只是为了演示simmechanics工具箱的使用,所以我把手腕的部分去除了,如果大家有兴趣的话希望在我的模型上加以改进。 这个机器人实际上就是三根连杆,三个转动副,连杆的长度分别为a1,a2和a3 必须要有三个输入才能得到一个稳定的位置,换句话说会有有三个方程,那么它们是 x=cos*cos*cos*a3-cos*sin*sin*a3 cos*cos*a2 y=sin*cos*cos*a3-sin*sin*sin*a3 sin*cos*a2 z=sin*cos*a3 cos*sin*a3 sin*a2 a1 其中th1,th2和th3是三个转动副的转角 这个是根据DH法推出来的,在这里我就不多说了,如果不用DH法也可以很简单的算出来,看大家的喜好了。 现在的任务就是,要使机器臂的末端走出一条直线来 那我就随便乱说了,原理和方法是一样的就可以了 就从沿直线走到吧 好了下面我就把m文件和仿真的图都贴出来 大家多给我点意见啊,有问题也可以发邮件给我,欢迎交流 xukai19871105@126.com %MyRobot有三个转动关节,共有三个自由度 %该文件用于在simulink中求解三个转动副的转角 function [result]=MyRobot_Inverse %方便编程,转化传入的数据 x=u; y=u; z=u; %三个连杆的长度 a1=1; a2=0.8; a3=0.5; %求解参数设置 options=optimset; %调用fsolve命令求解三个转角 result=fsolve; %求解三个转角的非线性方程组 function [theta]=NumericalSolution %方便编程,转化输入值 th1=u; th2=u; th3=u; theta=[cosd*cosd*cosd*a3-cosd*sind*sind*a3 cosd*cosd*a2-x;     sind*cosd*cosd*a3-sind*sind*sind*a3 sind*cosd*a2-y;     sind*cosd*a3 cosd*sind*a3 sind*a2 a1-z];
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Big_潘大师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值