张大头 电机驱动模块 modbus-rtu 通信 pymodbus 3.8.3

# pymodbus 3.8.3# Y轴  30齿  有减速机 变速比 19:1  距离变角位移:360/30/2*Sy_mm*19  地址 2
# X轴  丝杠1204      每周移动4mm   距离变角位移:360/4*Sx_mm        地址 3
# Z轴  20齿  无减速机              距离变角位移:360/20/2*Sz_mm     地址 4
# GT2同步皮带  齿距离2mmfrom pymodbus.client.serial import ModbusSerialClientfrom pymodbus.payload import BinaryPayloadBuilderclass MotorRTU:def __init__(self, x_port='COM3', x_baud=115200,x_parity='N',x_stop_bits=1,x_byte_size=8):# 配置串行通信参数self.client = ModbusSerialClient(#method='rtu',        # 使用RTU模式port=x_port,         # 串行端口,根据你的设备连接情况修改baudrate=x_baud,       # 波特率,与你的设备设置相匹配timeout=3,           # 超时时间(秒)parity=x_parity,          # 校验位:无(N),奇(O),偶(E)stopbits=x_stop_bits,          # 停止位:1bytesize=x_byte_size           # 数据位:8
        )self.reg_list = list()# 在Modbus协议中,功能码0x04(十六进制表示)用于读取输入寄存器(Input Registers)def read_04(self,reg_address =0x0046,reg_count=3,slave_address =1):#清空,准备放新的结果
        self.reg_list.clear()ret = False# 连接到Modbus RTU服务器if self.client.connect():print("成功连接到Modbus RTU服务器")# 读取输入寄存器address = reg_address   # 寄存器起始地址(从0开始)count   = reg_count     # 要读取的寄存器数量result = self.client.read_input_registers(address,count=count,slave=slave_address)#功能码号 04# 检查读取是否成功if not result.isError():print("读取成功")for register in result.registers:self.reg_list.append(register)print(f"寄存器值: {register}")ret = Trueelse:print("读取失败")# 关闭连接
            self.client.close()else:print("无法连接到Modbus RTU服务器")return ret#在Modbus协议中,功能码0x06(十六进制表示)用于预置单个寄存器(Preset Single Register)def write_06(self,reg_address =0x000E,reg_value=0x0001,slave_address =1):# 要写入的值(注意:Modbus寄存器通常存储16位值)value = reg_value  # 示例值,确保它在0到65535的范围内# 将值转换为两个字节(Modbus寄存器是16位的)value_bytes = value.to_bytes(2, byteorder='big')  # 大端序,根据设备文档可能需要调整# 地址(注意:地址可能因设备而异)address = reg_address  # 示例地址ret = Falsetry:# 连接到Modbus服务器(从设备)if self.client.connect():# 预置单个寄存器(功能码0x06)# 注意:pymodbus的write_register方法内部处理了功能码0x06的调用result = self.client.write_register(address, int.from_bytes(value_bytes, byteorder='big'),slave=slave_address)# 检查写入是否成功if result.isError():print("写入失败,错误代码:", result.status)else:print("写入成功")ret = Trueelse:print("无法连接到Modbus服务器")except Exception as e:print("发生异常:", e)finally:# 关闭连接
            self.client.close()print("已关闭连接")return retdef  write_10(self, reg_address =0x00F0, reg_list=None, slave_address =1):# 要写入的数据(这里以两个16位寄存器为例,每个寄存器存储一个无符号整数)# 要写入的数据(这里以两个16位寄存器为例,每个寄存器存储一个无符号整数)if reg_list is None:reg_list = [0x0000,0x0000 ]values = reg_list # 示例值ret = False# 尝试连接到Modbus服务器(从设备)并写入数据try:if self.client.connect():# 写入多个保持寄存器(功能码10H)# 注意:unit参数对应于从设备的地址或ID,根据设备配置设置# 直接将值列表传递给write_registers方法result = self.client.write_registers(address=reg_address, values=values, slave=slave_address )# 检查写入是否成功if result.isError():print("写入失败,错误代码:", result.status)else:print("写入成功")ret = Trueelse:print("无法连接到Modbus服务器")except Exception as e:print("发生异常:", e)finally:# 关闭连接
            self.client.close()print("已关闭连接")return ret#"解除堵转控制" 的英文可以翻译为 "Deactivate Stall Control" 或 "Disable Stall Prevention Control"。# 在这里,“stall”指的是电机或机械设备在负载过大时停止转动的状态,而“control”指的是对这种情况进行控制或预防的机制。def deactivate_stall_ctrl(self,motor_id =0x01):#串口地址ret = self.write_06(reg_address=0x000E, reg_value=0x0001, slave_address=motor_id )return ret# 不得超过65535# 按照梯形曲线控制电机速度、加速度,运行指定的角位移,单位度def trapezoid_position_ctrl(self,motor_id =0x01,      #串口地址is_ccw_direction = 1,# 方向 cw:0positive_acceleration = 2000,# RPM/snegative_acceleration = 2000,# RPM/smax_speed =2000,             # 最高RPMangular_displacement=36000,  # 角位移,度is_absolute_angular = 0):    # 0,相对角位移#相对运动是以当前位置角度为起点进行相对位置运动,绝对运动是#以上电时/清零后的位置角度为零点进行绝对位置坐标运动# 按照梯形曲线控制电机速度、加速度,运行指定的角位移,单位度low_word_angular_displacement =angular_displacement%0x10000high_word_angular_displacement =angular_displacement>>16values =[is_ccw_direction,positive_acceleration,negative_acceleration,max_speed,low_word_angular_displacement,high_word_angular_displacement,is_absolute_angular]ret = self.write_10(reg_address=0x00F6, reg_list=values, slave_address=motor_id)return ret#力矩模式控制的英文翻译是 "Torque Mode Control"。在这个模式下,电机或执行器的输出力矩(或扭矩)是被直接控制的变量,#而不是速度或位置。力矩模式控制常用于需要精确控制输出力或扭矩的应用中,如机器人关节驱动、精密加工设备等。def torque_limit_ctrl(self,motor_id =0x01,          #串口地址is_ccw_direction=0x0000, #方向 cw:0current_slope=5000,      #电流斜率(Ma/s)torque_current=100):    #力矩电流(Ma)values = [is_ccw_direction, current_slope,torque_current,0]ret = self.write_10(reg_address=0x00E2, reg_list=values, slave_address=motor_id)return ret# 使用示例
if __name__ == "__main__":motor_rtu= MotorRTU()#motor_rtu.read_04(reg_address =0x0046,reg_count=3,slave_address =1)#motor_rtu.write_06(reg_address =0x000E,reg_value=0x0001,slave_address =1)#motor_rtu.write_10(reg_address=0x00F0, reg_list=[0,2000,36000,0,0], slave_address=1)
    motor_rtu.trapezoid_position_ctrl(motor_id=0x01,  # Serial port address of the motor (电机串口地址)is_ccw_direction=0,  # Direction of rotation (1 for counterclockwise, 0 for clockwise) (旋转方向,1为逆时针,0为顺时针)positive_acceleration=2000,  # Acceleration rate in RPM per second when accelerating (加速时的加速度,单位:RPM/s)negative_acceleration=2000,  # Deceleration rate in RPM per second when decelerating (减速时的减速度,单位:RPM/s)max_speed=5000,  # Maximum speed of the motor in RPM (电机的最高速度,单位:RPM)angular_displacement=36000,  # Angular displacement in degrees (角位移,单位:度)is_absolute_angular=0  # 0 for relative angular displacement, 1 for absolute (0表示相对角位移,1表示绝对角位移)
    )motor_rtu.deactivate_stall_ctrl(motor_id =0x01)#串口地址# motor_rtu.torque_limit_ctrl(  #单纯力矩控制#     motor_id=0x01,            # Serial port address of the motor (电机的串口地址)#     is_ccw_direction=0x0000,  # Direction flag (0x0000 for clockwise, potentially other values for counterclockwise or to indicate no specific direction) (方向标志,0x0000表示顺时针,其他值可能表示逆时针或无特定方向)#     current_slope=5000,       # Current slope in milliamperes per second (mA/s) (电流斜率,单位:毫安/秒)#     torque_current=120        # Torque current in milliamperes (mA) (力矩电流,单位:毫安)# )

 

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

五. Redis 配置内容(详细配置说明)

五. Redis 配置内容(详细配置说明) @目录五. Redis 配置内容(详细配置说明)1. Units 单位配置2. INCLUDES (包含)配置3. NETWORK (网络)配置3.1 bind(配置访问内容)3.2 protected-mode (保护模式)3.3 port(端口)配置3.4 timeout(客户端超时时间)配置3.5 tcp-keepalive()配置4…

一文搞懂编程在开源软件运动中的应用

一文搞懂编程在开源软件运动中的应用一文搞懂编程在开源软件运动中的应用一理解开源软件运动文本内容开源软…………```HTML一文搞懂编程在开源软件运动中的应用一、理解开源软件运动:<!DOCTYPE html><html><head><meta charset="UTF-8"> &…

makefile在编译后输出STM32的Flash RAM占用情况的方法

本文介绍了在用makefile组织的STM32工程中,怎么在编译完成后计算并显示Flash和RAM占用情况的方法。知乎 - STM32 GCC工程编译后输出FLASH RAM使用占比的方法 里面这个方法看得我血压飙升,本身代码很不直观,写起来要反斜杠,还留了两行没用的代码,还有各种依赖命令,subst和…

您的干净代码可能是别人的技术债务

您的干净代码可能是别人的技术债务 为什么软件模式必须适应团队规模,以及如何正确操作。 大卫罗德纳斯 博士由作者生成 在软件开发中,我们面临着一个奇怪的悖论:对于一个团队来说,使代码更干净、更易维护、更优雅的架构决策,可能会让另一个团队觉得更复杂、更僵化、更麻烦…

读算法简史:从美索不达米亚到人工智能时代02古老的算法

苏美尔文字起源于湿黏土陶筹,楔形文字记录了苏美尔语,促进社会发展。阿卡德、巴比伦帝国相继统治,文字变迁。19世纪欧洲考古学家破译文字。美索不达米亚算法复杂,包括六十进制和毕达哥拉斯定理。埃及数学留存少,欧几里得算法著名。1. 苏美尔 1.1. 位于苏美尔地区的乌鲁克,…

计量经济学——空间计量概述(十八)

img { display: block; margin-left: auto; margin-right: auto } table { margin-left: auto; margin-right: auto } 空间计量经济学(Spatial Econometrics)创新性地解决了经典计量方法在空间数据分析中的局限性,研究地理观测值之间的相互关系。近年来,在人文社会科学的“…

经济经济学——空间计量概述(十八)

img { display: block; margin-left: auto; margin-right: auto } table { margin-left: auto; margin-right: auto } 空间计量经济学(Spatial Econometrics)创新性地解决了经典计量方法在空间数据分析中的局限性,研究地理观测值之间的相互关系。近年来,在人文社会科学的“…

Cisco NX-OS System Software - ACI 16.1(2g)F - 适用于 ACI 模式下的 Nexus 9000 系列交换机系统软件

Cisco NX-OS System Software - ACI 16.1(2g)F - 适用于 ACI 模式下的 Nexus 9000 系列交换机系统软件Cisco NX-OS System Software - ACI 16.1(2g)F 适用于 ACI 模式下的 Cisco Nexus 9000 系列交换机系统软件 请访问原文链接:https://sysin.org/blog/cisco-aci-16/ 查看最新…

Cisco APIC 6.1(2g)F - 应用策略基础设施控制器

Cisco APIC 6.1(2g)F - 应用策略基础设施控制器Cisco APIC 6.1(2g)F - 应用策略基础设施控制器 Application Policy Infrastructure Controller (APIC) 请访问原文链接:https://sysin.org/blog/cisco-apic-6/ 查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org思科…

Python多线程爬取亚马逊商品数据

前言 新年快乐 1.环境准备 使用miniconda为亚马逊创建一个新环境,防止feapder和其他包冲突(比如scrapy)。 # 创建一个新的 Conda 环境: conda create -n python_feapder python=3.12# 查看已创建的环境 conda info --envs# 激活环境 conda activate python_feapder# 安装所…

Debug: debugger失效排查

MarkTime: 2024-11-24 19:25:17 LogTime: 2024-11-24 19:25:17记一次 debugger 断点失效原因的排查版本说明Chrome: 131.0.6778.86 Vue: 3.2.27结论检查 是否启用了 谷歌浏览器 的 自定义排除规则, 并把 node_modules 给排除了 检查 前端项目配置文件eslint 是否有覆盖规则, 使…

Debug: 前端发送请求参数传递null, 后端转换实体类对应变量自动注入默认值

MarkTime: 2024-11-18 16:19:47 LogTime: 2024-11-25 01:26:05实体类属性未正确定义原因导致: ​ 基础数据类型未被初始化, 会对对应变量赋予默认值(int: 0; boolean: false;...) ​ 包装类型允许存储null, 不会进行默认值赋予, 实体类中如果需要设置默认值需要自行指定(privat…