POE指数积公式的简单matlab实现

news2024/9/28 9:27:08

参考现代机器人学
及机器人工程师进阶之路(八)指数积(PoE)建立机械臂模型及正运动
1.使用Robotics在matlab中建立一个简单的机械臂,方便验证后面的代码写的对不对

%Robotics 工具箱介绍: https://blog.csdn.net/weixin_43365751/article/details/100101827
%安装: https://petercorke.com/toolboxes/robotics-toolbox/
% clc
% clear 
%% 定义连杆
%L=Link([theta,d,a,alpha],standard/modified)%
%  theta        kinematic: joint angle  绕Z轴旋转角度
%  d            kinematic: link offset  绕Z轴平移距离
%  a            kinematic: link length  绕X轴平移距离
%  alpha        kinematic: link twist   绕X轴旋转角度
L1 = Link([0 0 0.1  pi/2]);  %关节2相对于关节1的参数
L2 = Link([0 0 0.2 0]);
L3 = Link([0 0 0.3 0]);
b=isrevolute(L1);  %Link 类函数,转动关节变量
robot=SerialLink([L1,L2,L3],'name','VIPER7','comment','LL');   %SerialLink 类函数
%robot.name='VIPER7';
%robot.comment='LL';

figure(2)
robot.display();  %Link 类函数,显示建立的机器人DH参数
%通过手动输入各个连杆转角,模型会自动运动到相应位置
theta=[0 0 0];
robot.plot(theta);   %展示
robot.teach(theta);       
pos=robot.fkine(theta)		%计算机器人正运动学,括号内为theta值

在这里插入图片描述
2.建立POE指数积的代码
步骤:
一、当机器人处于初始位置时,末端位形M
二、当机器人处于初始位置时,相对基坐标系的螺旋轴S 1 , ⋯ S n ,对应各个关节的旋转轴w和运动旋量v
v的计算公式为v=-w_h*q q为选取旋转轴上的一点的坐标 w_h为w的三维矩阵形式
三、用POE公式进行计算
在这里插入图片描述

L1 = 0.1; L2 = 0.2 ; L3 = 0.3;
%各轴角度
theta = [0,0,0];

%初始坐标  式(4.6)
M=[1 ,0 ,0, L1+L2+L3;
   0 ,1 ,0, 0;
   0 ,0 ,1, 0;
   0 ,0 ,0, 1];

%旋转轴 3*1
w1 = [0 ; 0; 1];
w2 = [0 ; 1; 0];
w3 = [0 ; 1; 0];

%转换成旋转矩阵的形式
w1_h = slove_m(w1);
w2_h = slove_m(w2);
w3_h = slove_m(w3);

%选取关节上的点 3*1
p1 = [0 ;0 ;0];
p2 = [L1;0 ;0];
p3 = [L1+L2;0 ;0];

%求线速度 85页【117】 v=-w*q
v1 = -w1_h*p1;
v2 = -w2_h*p2;
v3 = -w3_h*p3;

%式(3.85)
s1 = [w1_h,p1;0 ,0,0,0];
s2 = [w2_h,p2;0 ,0,0,0];
s3 = [w3_h,p3;0 ,0,0,0];

pos = esc(w1_h,v1,theta(1))*esc(w2_h,v2,theta(2))*esc(w3_h,v3,theta(3)) *M

%% 式(3.85)
function w_h = slove_m(w)
    w_h=[0, -w(3), w(2);
        w(3), 0, -w(1);
        -w(2), w(1), 0];
end

%% 命题3.25
function T = esc(w,v,theta)

    if NearZero(norm(w)) %式(3.89) 如果w=0
        T = [eye(3), v*theta; 0, 0, 0, 1];
    else  %式(3.88)
        T = [eye(3) + sin(theta) * w + (1 - cos(theta)) * w * w , ...
             (eye(3) * theta + (1 - cos(theta)) * w ...
              + (theta - sin(theta)) * w * w)* v;
             0, 0, 0, 1];
    end
end

%% 
function judge = NearZero(near)
    judge = norm(near) < 1e-6;
end

3.与Robotics 的计算结果进行对比
当 theta = [pi/4,pi/4,0] 时
POE的结果如下

pos =

    0.5000   -0.7071    0.5000    0.3207
    0.5000    0.7071    0.5000    0.3207
   -0.7071         0    0.7071   -0.3536
         0         0         0    1.0000

Robotics 的结果如下
在这里插入图片描述
x y的坐标差不多,不知道为啥z方向坐标相反了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/349508.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【使用secureCRT管理Linux系统】

使用secureCRT管理Linux系统 进入secureCRT快速连接虚拟机 默认是SSH2类型&#xff0c;红线是虚拟机的ip地址&#xff0c;绿线是虚拟机的用户名称 如果之后的页面出现了需要输入用户密码&#xff0c;那就是成功了&#xff0c;如果出现了Connection timed out 可能原因是电脑…

Spring如何整合MyBatis框架?使用XML及java类的配置方式

前言 Spring文章链接: 从头到尾Spring概念&#xff0c;家族&#xff0c;核心技术使用&#xff0c;事务这一篇就够了&#xff01;&#xff01;&#xff01;_千小半的博客-CSDN博客_spring最新技术 mybatis文章链接: MyBatis框架入门(含实例)_mybatis sqlsession创建和关闭_千小…

文华财经期货日内多空金叉波段彩带幅图指标公式,震荡区间决策预警信号指标公式

​期货指标公式不是交易的圣杯&#xff0c;也不是期货亏损后的救命稻草。请理性运用指标公式&#xff0c;独立决策&#xff0c;盈亏自负。 1.在期货交易中&#xff0c;大部分品种&#xff0c;大部分时间都是在走一个趋势行情。即使是形态内的震荡行情&#xff0c;也是在走一个…

redis 实现延迟队列及其他实现延迟队列

1、 前言 1.1、什么是延迟队列&#xff1f; 延时队列相比于普通队列最大的区别就体现在其延时的属性上&#xff0c;普通队列的元素是先进先出&#xff0c;按入队顺序进行处理&#xff0c;而延时队列中的元素在入队时会指定一个延迟时间&#xff0c;表示其希望能够在经过该指定…

虹科新品|HK-Edgility敏捷边缘计算套件

敏捷、经济高效且易于管理大规模IT服务基础设施 业务动态和数字化转型将业务资源和业务用户都推到了传统 IT 边界之外。业务资源和服务被虚拟化并迁移到云端。随着数字工作空间的发展和业务用户需要随时随地访问业务资源&#xff0c;越来越多的业务资源被推向网络边缘。 由于…

研报精选230216

目录 【行业230216东吴证券】环保行业月报&#xff1a;2023M1环卫新能源渗透率大增至11.91%&#xff0c;上海地区渗透率高达77%【行业230216国元证券】国元新食饮&#xff1a;一图君&#xff1a;22年白酒产量&#xff1a;同降6.2%【行业230216浙商证券】农林牧渔点评报告&#…

认识数据库

今天为大家带来数据库的知识 &#x1f680;1.什么是数据库 &#x1f680;2.数据库的分类 &#x1f680;3.数据库的存储 1.首先来聊一聊MySQL数据库的定义 已经学习了数据结构 数据结构是一门研究数据如何存储的学科&#xff0c;当数据是少量的时候&#xff0c;用数据结构…

在vue2使用百度脑图的kityminder-core进行二次开发思维导图,给节点绑定数据后添加新的图标

需求说明&#xff1a;在给某个节点绑定文件数据后&#xff0c;用户并不能一眼看出哪个节点上绑定了数据&#xff0c;因此需要在绑定文件数据后给节点上加一个图标用于标识。 添加图标 1、在kityminder-core/src/module/file.js文件中添加代码 &#xff08;file.js文件如何添加…

ChatGPT国内镜像站初体验:聊天、Python代码生成等

ChatGPT国内镜像站试用&#xff0c;聊天、Python代码生成。 (本文获得CSDN质量评分【92】)【学习的细节是欢悦的历程】Python 官网&#xff1a;https://www.python.org/ Free&#xff1a;大咖免费“圣经”教程《 python 完全自学教程》&#xff0c;不仅仅是基础那么简单…… …

基于离散时间频率增益传感器的P级至M级PMU模型的实现(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5;&#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密…

[足式机器人]Part3机构运动微分几何学分析与综合Ch01-4 平面运动微分几何学——【读书笔记】

本文仅供学习使用 本文参考&#xff1a; 《机构运动微分几何学分析与综合》-王德伦、汪伟 《微分几何》吴大任 Ch01-4 平面运动微分几何学1.2.3-2 点轨迹的Euler-Savary公式1.2.4 高阶曲率理论1.2.3-2 点轨迹的Euler-Savary公式 例1-7&#xff1a; 平面曲柄摇杆机构的 Euler-Sa…

VS中scanf为什么会报错

简单来讲&#xff0c;scanf会强行输入内容&#xff0c;所以是不安全的。 我们来看这样的例子&#xff1a; #include <iostream> using namespace std;int main() {char demo[3];scanf("%s", demo);return 0; }对于以上代码&#xff0c;当我们输入字符不超过3时…

联合身份验证与Cognito

Hello大家好&#xff0c;我们接下来讨论AWS联合身份验证的内容。 AWS联合身份验证 对于考试&#xff0c;联合身份验证部分是一块非常重要的内容。那什么是联合身份验证&#xff0c;它是做什么用的呢&#xff1f; 联合身份验证&#xff0c;是用来允许AWS外部用户&#xff0c;如…

vue2中使用 Tinymce 5.1.0使用过程举例

一、背景 vue-cli 版本 &#xff1a;vue/cli 4.5.15 查看脚手架版本的方法&#xff1a;Win R 打开运行输入&#xff1a; cmd &#xff0c;打开控制台输入 vue -V vue 版本&#xff1a;"vue": "^2.6.11", 二、安装 Tinymce 1、 --no-fund 是因为提示你…

C语言(表达式,语句和副作用和序列号)

目录 一.表达式 二.语句 三.副作用和序列点 一.表达式 由运算符和运算对象组合。最简单得表达式是一个单独的运算对象&#xff0c;以次为基础可以建立复杂的表达式 4 421 a*&#xff08;b c/d)/20 运算对象可以是常量&#xff0c;变量或二者得组合。一些表达式由子表达…

python--石头剪刀布游戏(列表)

本使用了下面几篇文章的知识&#xff1a; python(8)--列表初阶使用_码银的博客-CSDN博客 python(7)--if语句_码银的博客-CSDN博客 一、学习目标 利用列表实现石头剪刀布游戏 二、实验环境 Pycharm社区版、win11 三、代码 先贴代码&#xff0c;有需要的直接拿&#xff0c;想要进…

Hive提升篇-Hive修改事务

简介 Hive 默认是不允许数据更新操作的&#xff0c;毕竟它不擅长&#xff0c;即使在0.14版本后&#xff0c;做一些额外的配置便可开启Hive数据更新操作。而在海量数据场景下做update、delete之类的行级数据操作时&#xff0c;效率并不如意。 简单使用 修改HIVE_HOME/conf/hi…

JS逆向寻找生成bid变量的加密算法,一顿操作猛如虎,结果发现原来是混淆代码

分享一下最近我JS逆向的心得。 我最近使用Python爬取某个网站某个链接&#xff0c;cookie必须加入qgqp_b_id参数才能获取数据。 这个参数是一个32位字符串&#xff0c;通过浏览器的开发者工具分析网页源代码&#xff0c;了解到这个qgqp_b_id变量不是服务器返回给客户端的&…

Whids:一款针对Windows操作系统的开源EDR

关于Whids Whids是一款针对Windows操作系统的开源EDR&#xff0c;该工具所实现的检测引擎基于先前的 Gene项目构建&#xff0c;并专门设计可以根据用户定义的规则匹配Windows事件。 功能特性 1、为社区提供一款功能强大且开源的Windows EDR&#xff1b; 2、支持检测规则透明化…

有了java基础,迅速学完Python并做了一份笔记

面向过程Python简介Python和Java的解释方式对比Java&#xff1a;源代码 -> 编译成class -> Jvm解释运行Python&#xff1a;源代码 -> Python解释器解释运行我经常和身边的Java开发者开玩笑说&#xff1a;“Java真变态&#xff0c;别的语言都是要么直接编译要么直接解释…