第一次编程操作UR10协作机器人的记录

2023-11-01 13:50

本文主要是介绍第一次编程操作UR10协作机器人的记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一次编程操作UR10协作机器人的记录

1 引言

UR机器人参考:丹麦优傲机器人 中文网页
alt
项目需要借来了一台UR10协作机器臂,用自带的触摸屏控制试验了一下,又从网上下载了一段基于C#的程序,大概读了一下,并用VS2015用C实现了对机械臂的控制,以下纪录。
注:这里只是工作记录,没深究内部原理和协议规定。

2 连接和端口

计算机与UR机器人的连接通过网络,通信采用了TCP/IP协议,在机械臂中可以设置自己的IP,如我工作时设置的192.168.0.77,计算机IP设置为与机器人在同一个IP网段,然后根据设置的IP和端口进行访问。
本文中机器人操作时用了两个连接端口

  1. 控制端口:即UR机器人设置的通信端口,30003;
  2. 状态端口:同一个IP的502端口,MODBUS端口。

控制端口可以在软件启动后就建立连接,然后与该端口通信就可以了,软件退出前关闭连接;
但这个MODBUS端口有一点要注意,需要随时读取随时建立连接,即建立的连接只有马上使用才可以,过一会就会被自动断开,分析应该是状态端口不允许被某一程序长时间占用,或者这个是UDP端口?(有机会测试一下)

3 通信协议

与机器人的控制和状态读取,都不需要提前握手,只要在需要时发送命令就可以了。

3.1 机器人状态读取

首先说状态的读取,即通过MODBUS端口读取机器人的当前状态,实际上就是读取机器人相应地址的寄存器数据。
需要读取状态寄存器时,向MODBUS端口发送命令,命令一般为一个12个字节的命令包,格式如下:

字节顺序含义备注
0-1字节读取数据方标识这里取0x00 0x01;
2-3字节协议ID这里取0x00 0x00;
4-5字节后面还有多少字节的信息高位在前(以下多字节数据均为高位在前,即与计算机字节顺序相反)
6字节未用保持0x00;
7字节功能码读取为0x03;
8-9字节要读取寄存器的起始地址
10-11字节读取寄存器数目

构造好以上格式的数据包,发送到状态端口(如上所述,发送前建立连接,发送接收数据完成后立即关闭连接)
发出命令包后等待接收返回数据
返回的数据的前9个字节为信息头,我这里为0x00 0x01 0x00 0x00 0x00 0x09 0x00 0x03 0x06,这里暂忽略其具体含义。
之后即为返回的需要的寄存器的值,数目为需要的寄存器数目,每个寄存器数据占两个字节,同样高位在前。
下表为我用到的寄存器地址及其含义

寄存器起始地址数量和含义备注
260 (0x0104)状态:是否开机是否紧急停机等260+0 是否开机;260+1 安全停机;260+2 紧急停机;260+3 显示模式
270 (0x010e)关节角度值,六个返回值的六个值均需除以1000,为弧度值;
400 (0x0190)坐标值,六个返回值的前三个为XYZ位置值,需要除以10000,单位为米;返回值的后三个为UVW,需要除以1000,为弧度值;

3.2 机器人运动控制

远程控制机器人运动,就是通过TCP向机器人发送运动控制的脚本字符串,我用到的运动控制指令主要有三个,实际上只要使用前两个就可以很好地控制机器人运动了。
注意:指令中,位置单位均为m,角度单位均为弧度,速度单位为m/s,加速度单位为m/s2。另外,指令后面必须加回车换行,即"\r\n"。

1. 停止指令

命令格式:stopl(1)
例:

	char* cmd = "stopl(1)\r\n";SendCommand(cmd,strlen(cmd));
2. MOVEL移动指令

命令格式:movel(p[x, y, z, u, v, w], a = avalue, v = vvalue)
其中x y z为三个轴的目标位置坐标,单位为米
u v w为旋转向量,单位为弧度
avalue与vvalue分别为移动时的加速度和速度
例:

	char cmd[1024];sprintf_s(cmd,"movel(p[""%lf, %lf, %lf, %lf, %lf, %lf""], a = %lf, v = %lf)\r\n",x,y,z,u,v,w,a,v);SendCommand(cmd,strlen(cmd));
3. MOVEJ移动指令

命令格式:movej(p[g1, g2, g3, g4, g5, g6], a = avalue, v = vvalue)
与movel指令格式一样,但参数是关节角度,未进行深入研究,这里仅试验了一下,具体关节含义待后续研究,这里略。
例:

	char cmd[1024];sprintf_s(cmd,"movej([""%lf, %lf, %lf, %lf, %lf, %lf""], a = %lf, v = %lf)\r\n",g1,g2,g3,g4,g5,g6,a,v);SendCommand(cmd,strlen(cmd));

这篇关于第一次编程操作UR10协作机器人的记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/323431

相关文章

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

Go Playground 在线编程环境

For all examples in this and the next chapter, we will use Go Playground. Go Playground represents a web service that can run programs written in Go. It can be opened in a web browser using the follow

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

Java并发编程之——BlockingQueue(队列)

一、什么是BlockingQueue BlockingQueue即阻塞队列,从阻塞这个词可以看出,在某些情况下对阻塞队列的访问可能会造成阻塞。被阻塞的情况主要有如下两种: 1. 当队列满了的时候进行入队列操作2. 当队列空了的时候进行出队列操作123 因此,当一个线程试图对一个已经满了的队列进行入队列操作时,它将会被阻塞,除非有另一个线程做了出队列操作;同样,当一个线程试图对一个空

动手学深度学习【数据操作+数据预处理】

import osos.makedirs(os.path.join('.', 'data'), exist_ok=True)data_file = os.path.join('.', 'data', 'house_tiny.csv')with open(data_file, 'w') as f:f.write('NumRooms,Alley,Price\n') # 列名f.write('NA