机器人动力学模型与MATLAB仿真

机器人刚体动力学由以下方程控制!!!

复制代码
startup_rvc
mdl_puma560
p560.dyn

提前计算出来这些"disturbance",然后在控制环路中将它"抵消"(有时候也叫前馈控制)

求出所需要的力矩,其中M项代表克服了机械臂的加速度惯量以及不同连杆之间的惯量影响所需力矩、C项代表了克服科里奥利力和离心力所需力矩、G项代表了克服地球引力力矩。

Inverse Dynamics叫做反向动力学,它的作用是输入想要的关节速度(qd)、关节加速度(qdd)、关节角度(q),输出为每个关节所需要的力矩(u)。当然也有正向动力学(forward dynamics),它的作用和反向动力学相反,输入关节角度(q)、关节速度(qd)、每个关节的力矩(u),输出为每个关节的加速度(qdd)

"前馈控制"的例子,它的作用是预先计算出所需的力矩,输入给控制器,"反馈"的存在是为了消除一些误差,例如摩擦力

复制代码
J=[-sin(q1)-sin(q1+q2) -sin(q1+q2);
    cos(q1)+cos(q1+q2) cos(q1+q2)];
d_J=[-dq1*cos(q1)-(dq1+dq2)*cos(q1+q2) -(dq1+dq2)*cos(q1+q2);
    -dq1*sin(q1)-(dq1+dq2)*sin(q1+q2) -(dq1+dq2)*sin(q1+q2)];
复制代码
function torque_out    = fcn(u_matrix,q1,q2)

%% Robot Joint and mass parameters
g=9.81;
m1=0.3;
m2=1;
l1=0.2;
l2=0.2;



%% B = M Matrix 
B=[  (m1+m2)*l1^2+m2*l2^2+2*m2*l2*l1*cos(q2)  (m2*l2^2+m2*l1*l2*cos(q2)) ; (m2*l2^2+m2*l1*l2*cos(q2))  m2*l2^2];

torque_out= B* u_matrix ;

end

C=-(m2\*l1\*l2\*sin(q2)\*(2\*q1dot\*q2dot+q2dot\^2)) ; -m2\*l1\*l2\*sin(q2)\*q1dot\^2;

G=(m1+m2)\*g\*l1\*cos(q1)+m2\*l2\*g\*cos(q1+q2) ; +m2\*g\*l2\*cos(q1+q2);

Minv= (m2\*l2\^2)/(((m1+m2)\*l1\^2\*l2\^2\*m2)-(m2\^2\*l1\^2\*l2\^2\*cos(q2))) -(m2\*l2\^2+m2\*l1\*l2\*cos(q2))/(((m1+m2)\*l1\^2\*l2\^2\*m2)-(m2\^2\*l1\^2\*l2\^2\*cos(q2))) ; -(m2\*l2\^2+m2\*l1\*l2\*cos(q2))/(((m1+m2)\*l1\^2\*l2\^2\*m2)-(m2\^2\*l1\^2\*l2\^2\*cos(q2))) ((m1+m2)\*l1\^2+m2\*l2\^2+2\*m2\*l2\*l1\*cos(q2))/(((m1+m2)\*l1\^2\*l2\^2\*m2)-(m2\^2\*l1\^2\*l2\^2\*cos(q2)));

参考文献:

平面2R机器人运动学与动力学建模基于平面2R机器人谈谈运动学和动力学建模的应用https://mp.weixin.qq.com/s/1gQTDHpyUkTMst_OdVFlnw

MATLAB 中的机械臂算法------动力学系列技术文章https://mp.weixin.qq.com/s/opQcpv02sysIcz8seg3lkQ

相关推荐
zzzzzz3109 天前
假如我是掘金管理员,我先给评论区装个'代码审查'系统
python·程序员·机器人
LDR00610 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术10 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
通信小呆呆10 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
码云数智-园园10 天前
C++20 Modules 模块详解
java·开发语言·spring
xiao5kou4chang6kai410 天前
MATLAB机器学习、深度学习--从数据预处理到模型训练
深度学习·机器学习·matlab·数据预处理
swordbob10 天前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
源分享10 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
Luminous.10 天前
C语言--day30
c语言·开发语言