找回密码
 注册
关于网站域名变更的通知
查看: 731|回复: 3
打印 上一主题 下一主题

MATLAB机器人工具箱实现6轴机械臂在球和平面画字母

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2021-7-19 10:08 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
1 在平面上画字母C$ J' |# H. Z% P  S) F
  • mdl_puma560
  • aplha=pi/4:pi/40:2*pi-pi/4;
  • k=inf;                  % 斜面斜率k
  • r=1;
  • letterShrink=0.2;       %缩放倍数
  • letterTranslX=0.4;      % 沿X平移量
  • letterTranslY=0;        % 沿Y平移量
  • letterTranslZ=0;        % 沿Z平移量
  • if k==inf   % 垂直平面
  •     z=r*cos(aplha);
  •     x= diag(zeros(length(z)));
  •     y=r*sin(aplha);
  •     path=[diag(zeros(length(y))),y',z'];
  •     path=[path(1,:)+0.5*[-1,0,0];path;path(end,:)+0.5*[-1,0,0]];   % 垂直平面上的C
  •     y=-0.5:0.1:0.5;
  •     z=-0.5:0.1:0.5;
  •     [Y, Z] = meshgrid(y, z);
  •     X=ones(size(Y))*letterTranslX;
  •     mesh(X,Y,Z)
  •     hold on
  •     initPoint=path(1,:)+0.5*[-1,0,0];
  • else
  •     x=r*cos(aplha);
  •     y=r*sin(aplha);
  •     z=k*x;
  •     path=[x',y',z'];
  •     path=[path(1,:)+0.5*[-k,0,1];path;path(end,:)+0.5*[-k,0,1]];  % 斜率为k的斜面上的C
  •     x=0:0.1:1;
  •     y=-0.5:0.1:0.5;
  •     [X,Y]=meshgrid(x,y);
  •     z=k*(X-letterTranslX);
  •     mesh(X,Y,z)
  •     hold on
  •     initPoint=path(1,:)+0.5*[-k,0,1];
  • end
  • plot3(letterShrink*path(:,1)+letterTranslX,letterShrink*path(:,2)...
  •     +letterTranslY,letterShrink*path(:,3)++letterTranslZ,'color','k','LineWidth',1)
  • p=mstraj(path,[0.8,0.8,0.6],[],initPoint,0.4,0.1);
  • Tp=transl(letterShrink*p);
  • Tp=homtrans(transl(letterTranslX, letterTranslY, letterTranslZ),Tp);
  • p560.tool=transl([0,0,0.2])*trotx(pi);
  • q=p560.ikine6s(Tp);
  • p560.plot(q)
    7 A- r$ e+ j8 a, g

5 T  V- ?3 v. v" e5 D. N8 c% J2 s+ a- S+ L
k=0. O$ U1 O2 Z& w  ^: x' F

" b' _4 b( D( ?
1 `0 G- ?+ ]0 v- t* v* }8 w0 d7 H: T0 Z
' |4 j" x% u+ l* W: L: u4 o
k=1
/ J, a/ a  ^7 r7 s& A  S. C. g. ?( r2 e1 x2 ]* n' Q

8 n0 L7 C$ _2 ^$ t4 a+ U+ @% Q2 V! R1 @: S- J0 D

8 U1 c, X1 {7 v7 Tk=inf
$ k7 C$ m# B! b  ]! M  S/ s- U4 u0 \; l5 x5 j, E/ C% `  X5 j0 K$ y

' O7 f2 N* \. z$ c- F3 i
8 G+ m0 ?3 O+ Z0 R/ g5 g. m# ~. k
2 在球面上画字母E
; o" Z+ J0 ^! r; W! S7 Y) P7 T# x  C6 i2 T! \* _
  • clc;
  • clear
  • close all
  • mdl_puma560
  • letterShrink=0.2;       %缩放倍数
  • letterTranslX=0.4;      % 沿X平移量
  • letterTranslY=0;      % 沿Y平移量
  • letterTranslZ=-1;      % 沿Z平移量
  • r=0.3;
  • [x y z]=sphere(50);
  • mesh(r*x+letterTranslX,r*y+letterTranslY,r*z+letterTranslZ);%绘制半径为2的球
  • hold on
  • path=[1,-1,1,;1,-1,0;1,-1,0;0,-1,0;0,1,0;1,1,0;1,1,1;0,0,1;0,0,0;1,0,0;1,0,1]*letterShrink;
  • initPoint=path(1,:);
  • path=mstraj(path,[0.5,0.5,0.3],[],initPoint,0.1,0.2);
  • [m,n]=size(path);
  • x1=path(:,1);
  • y1=path(:,2);
  • indexDraw=(path(:,3)==letterTranslZ);
  • indexNotDraw=(path(:,3)~=letterTranslZ);
  • path(indexDraw,3)=sqrt(r^2-(x1(indexDraw)).^2-(y1(indexDraw)).^2);
  • path(indexNotDraw,3)=path(indexNotDraw,3)+sqrt(r^2-(x1(indexNotDraw)).^2-(y1(indexNotDraw)).^2);
  • for i=1:m
  •     path(i,:)= path(i,:)+[letterTranslX,letterTranslY,letterTranslZ];
  • end
  • plot3(path(:,1),path(:,2),path(:,3),'color','k','LineWidth',2)
  • rotate3d on
  • p560.tool=transl([0,0,0.5])*trotx(pi);
  • Tp=transl(path);
  • q=p560.ikine6s(Tp);
  • p560.plot(q)
    % L" _: T( U. ~* K' x7 t

, G9 S0 ]) \6 I& q+ w& G% R$ ?* }. `1 x9 @  p

2 Z6 Q1 [( ?/ D+ G# T " T+ d0 x0 M& ]% t9 S6 x7 _

该用户从未签到

2#
发表于 2021-7-19 11:20 | 只看该作者
MATLAB机器人工具箱实现6轴机械臂在球和平面画字母

该用户从未签到

3#
发表于 2021-7-19 11:20 | 只看该作者
MATLAB机器人工具箱实现6轴机械臂在球和平面画字母
  • TA的每日心情
    擦汗
    2019-11-19 15:26
  • 签到天数: 1 天

    [LV.1]初来乍到

    4#
    发表于 2021-7-19 11:20 | 只看该作者
    MATLAB机器人工具箱实现6轴机械臂在球和平面画字母
    您需要登录后才可以回帖 登录 | 注册

    本版积分规则

    关闭

    推荐内容上一条 /1 下一条

    EDA365公众号

    关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

    GMT+8, 2025-11-23 21:58 , Processed in 0.156250 second(s), 27 queries , Gzip On.

    深圳市墨知创新科技有限公司

    地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

    快速回复 返回顶部 返回列表