码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【机械】基于简化几何解法的六轴机械臂位置规划附matlab代码


    1 内容介绍

    基于简化几何解法的六轴机械臂位置规划附matlab代码

    2 部分代码

    clc;

    clear;

    %载入数据

    importfile('shuiping.mat');

    theta_shuiping=shuiping;

    %参数,单位/m

    a=0.1;

    L1=0.43;

    L2=0.65;

    L3=0.7;

    L4=0.088;

    H=pi/180;

    % %给定初始和终止角度

    % alpha1_st=80*pi/180;

    % alpha2_st=45*pi/180;

    % alpha1_en=50*pi/180;

    % %角度值

    % alpha1_st1=80;

    % alpha2_st1=45;

    % alpha1_en1=50;

    % jiange=3;

    % %开始计算

    % deltah=L2*sin(alpha1_st)-L3*sin(alpha2_st);

    % for i=1:(alpha1_st1-alpha1_en1)/jiange+1

    %     alpha1(i)=alpha1_st1-(i-1)*jiange;

    % end

    alpha1_st=theta_shuiping(1)*H;

    alpha2_st=45*pi/180;

    deltah=L2*sin(alpha1_st)-L3*sin(alpha2_st);

    alpha1=theta_shuiping;

    theta2=alpha1;

    alpha2=asin((L2*sin(alpha1*H)-deltah)/L3);

    theta3=90-theta2-alpha2/H;

    theta5=90-alpha2/H;

    %画图

    r2_s=a;

    h2_s=L1;   %L2起点

    r3_s=a+L2*cos(alpha1*H);

    h3_s=L1+L2*sin(alpha1*H);   %L2终点,L3起点;

    r4_s=r3_s+L3*cos(alpha2);

    h4_s=h3_s-L3*sin(alpha2);   %L3终点,L4起点;

    r4_e=r4_s;

    h4_e=h4_s-L4;

    %画连杆2,3,4

    figure(1)

    N=size(theta2,2);

    for i=1:N

        a=drawline(r2_s,r3_s(i),h2_s,h3_s(i));

        a=drawline(r3_s(i),r4_s(i),h3_s(i),h4_s(i));

        a=drawline(r4_s(i),r4_e(i),h4_s(i),h4_e(i));

    end

    %画底座和连杆1

    a=drawline2(-0.2,0.2,0,0);

    a=drawline2(0,0,0,0.2);

    a=drawline2(0,0.1,0.2,0.43);

    plot(r4_e,h4_e,'b','LineWidth',3)

    %题目横纵坐标及范围

    axis([-0.25 1.1 0 1.2])

    xlabel('r/m');

    ylabel('z/m');

    grid on

    axis equal

    % title('机械臂水平方向直线运动');

    figure(2)

    plot(theta2,'-');

    hold on

    plot(theta3,'-.');

    hold on

    plot(theta5,'--');

    % title('各关节运动曲线');

    legend('theta2','theta3','theta5')

    axis([1 20 -40 90])

    xlabel('序列号');

    ylabel('关节角/°');

      set(gcf,'color','white');

      set(gca,'FontSize',15);

      

    function a=drawline(x1,x2,y1,y2)

      x=[x1,x2];

      y=[y1,y2];

      plot(x,y,'k','LineWidth',0.8)

      hold on

      a=1;

        set(gcf,'color','white');

      set(gca,'FontSize',15);

    end

    function a=drawline2(x1,x2,y1,y2)

      x=[x1,x2];

      y=[y1,y2];

      plot(x,y,'k','LineWidth',2)

      hold on

      a=1;

    end

    3 运行结果

    4 参考文献

    [1]鲁飞. 基于改进蚁群算法的机械臂路径规划研究[D]. 合肥工业大学.

    博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机、雷达通信、无线传感器等多种领域的Matlab仿真,相关matlab代码问题可私信交流。

    部分理论引用网络文献,若有侵权联系博主删除。

  • 相关阅读:
    SpringCloud--nacos 入门使用
    鸿蒙HarmonyOS实战-ArkUI事件(组合手势)
    前端该如何优雅地Mock数据
    Java - Gson和Fastjson如何选择?
    Sui发布RPC2.0 Beta,拥抱GraphQL并计划弃用JSON-RPC
    设计模式之观察者模式(优先使用对象组合的原则)的C++实现
    [Git入门]---gitee注册及代码提交
    基于神经网络的自动驾驶,人工智能在无人驾驶
    【算法】【floodfill】洪水灌溉
    两台实体机器4个虚拟机节点的Hadoop集群搭建(Ubuntu版)
  • 原文地址:https://blog.csdn.net/qq_59747472/article/details/126795019
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号