汇川AM600 PLC及CODESYS数据采集的一点经验

CODESYS 是一个比较有名的PLC软件平台,据说被很多PLC厂家采用,但是,我工作中很少接触到相关的产品,最近在研究录波软件时,才开始学习它。

首先研究的是倍福的数据采集,倍福提供了一个ADS的通讯库,在其环境下可以通过变量名,非常高效地进行数据采集(首先为变量确定内部地址,随后就可以通过内部地址批量采集)。由于倍福是基于CODESYS系统,因此,对其初始印象还不错。

随后,接触到了汇川的AM600PLC,它更接近CODESYS原始生态,编程软件与CODESYS开发系统几乎一样,其变量类型与高级语言一样丰富,且不需要明确的地址,但是,作为一个PLC系统,也提供硬件存储区域,内部变量可以使用I、Q、M存储器,这些存储器的寻址非常灵活,可以按照位、字节、字、双字进行寻址。与西门子不同的是,西门子各种类型都是按照字节的编号进行编号,但是,CODESYS则是各种类型独立编号(相互关系见下图),这样,外部访问时,必须进行地址的变换和反变换,并注意字节的顺序

CODESYS对于运行系统保护严密,不允许外部直接访问其内部变量,号称都是要通过其gateway软件才能进行访问(见下面的架构),那么,为什么PLC-ANALYZER和IBA PDA都能直接按照变量名进行数据采集呢?(一个事实:他们都是德国的公司)

ce8e91c64dcf45ac8283bc4e1bc7aa1f

好在PLC厂家可以开放自己的通讯协议,比如汇川PLC提供MODBUS TCP协议,且默认开启从站模式,外部用户可以直接通过该协议访问其I、Q、M区域。

CODESYS为内部变量指定M存储区域时,只需要指定起始地址,然后根据变量类型确定占用长度,因此,下面的定义都是等价的,都是指定变量使用从MB4开始的4个字节

real0 AT %MD1:REAL;

real0 AT %MW2:REAL;

real0 AT %MB4:REAL;

dint1 AT %MD1:DINT;

dint1 AT %MW2:DINT;

dint1 AT %MB4:DINT;

MODBUS TCP仅以字为单位进行M区域访问,因此,长度不等于一个字的访问都必须转换成字进行访问。由于每个字包括2个字节(比如:MW1包括MB2、MB3),因此,字节都是成对采集,且从偶数字节开始。但是,CODESYS内部却可以从单数字节开始使用M区域,下面的定义是可以正常工作的(西门子也是按照字节进行内部组织的),因此,在采集和结果解析时,必须要考虑跨字的情况,以及高低字节的顺序(测试一下即可确定)

bool1 AT %MX0.7:BOOL;

Lint1 AT %MB5:LINT;

string1 AT %MB101:STRING;

Wstring2 AT %MB11:WSTRING;

通过MODBUS TCP协议,经过各种地址、表达方式的转化,打包,采集,拆分,PLC-Recorder软件实现了汇川AM系列的高速、批量采集,支持bool、byte、int、dint、lint、Uint、Udint、Ulint、real、Lreal、string、wstring等类型。应该可以适用到其他支持MODBUS TCP的CODESYS系统,大家有机会时可以试用。

PLC-Recorder的地址参照CODESYS内部规则,完全可以按照PLC内部的规则写地址和类型,软件会自动确定需要采集的字范围,并准确提取其中的相关部分,因此,上面这些变量在本软件的地址和类型确定方法(部分):

PLC内部的定义

本软件的起始地址

本软件的变量类型

boo1A AT %IX0.7

IX0.7

bool

boo1B AT %QX1.1

QX1.1

bool

real0 AT %MD1:REAL;

MD1

float

real0 AT %MW2:REAL;

MW2

float

real0 AT %MB4:REAL;

MB4

float

dint1 AT %MD1:DINT;

MD1

Int32

dint1 AT %MW2:DINT;

MW2

Int32

dint1 AT %MB4:DINT;

MB4

Int32

bool1 AT %MX0.7:BOOL;

MX0.7

bool

Lint1 AT %MB5:LINT;

MB5

Int64

string1 AT %MB101:STRING;

MB101

String

Wstring2 AT %MB11:WSTRING;

MB11

WString

byte1 AT %MB10:BYTE;

MB10

byte

double1 AT %MB150: LREAL;

MB150

double

关于字符串的处理,有很多特殊的地方,不同的PLC有不同的数据结构(主要是在长度确定上,西门子是将长度写在前面,CODESYS和日系的是在结尾加内容为0的字节,或者字),string类型是ASCII字符串,每个字符一个字节,而WString则是Unicode格式,每个字符2个字节,其查找结尾的方法也不同,比如:当字符为ASCII时,字符的第2个字节会是0,字符串"12"的字节串为: 31 0 32 0 0 0;而字符串 "中国"的字节串为:2D 4E FD 56 0 0,因此,必须寻找字开始的字节,避免将ASCII的0字节误认为是结束标志,这在变量的开始字节是单号字节时,将更加复杂。

CODESYS介绍说可以通过plchandler按照变量名进行采集(应该是类似于倍福的ADS的通讯,或者反过来),有相关经验的朋友请不吝赐教,我看看能否实现通过变量名进行内部变量的批量采集。

2021年2月14日

<think>好的,用户想了解汇川PLC上位机通信所使用的协议,提到了MODBUS RTU和CANopen。首先我需要确认汇川PLC常用的通信协议有哪些。根据用户提供的引用内容,汇川AM401和AM403系列程序搭配了总线伺服和触摸屏,可能使用的是基于CODESYS的平台,因为CODESYS通常支持多种工业通信协议。 汇川PLC通常支持的协议包括MODBUS RTU/TCP、CANopen,还可能支持EtherCAT或Profinet,但用户特别提到了MODBUS RTU和CANopen。需要确认这些协议是否适用于上位机通信。MODBUS RTU是串行通信协议,常用于传统设备,而CANopen多用于运动控制,适合总线伺服系统。此外,CODESYS环境可能使用自家的通信协议,比如CoDeSys over TCP/IP。 用户的问题还涉及如何实现通信,可能需要更具体的步骤,比如配置步骤、编程接口或使用库。但根据引用中的全ST编写和CODESYS高级编程,可以推断汇川PLC可能使用基于CODESYS的协议栈,支持MODBUS和CANopen。此外,上位机如果是汇川的触摸屏IT7070系列,可能使用Modbus或其他汇川自定义协议。 需要确保回答涵盖用户提到的协议,并可能补充其他相关协议如EtherCAT,同时提供实际应用场景,如MODBUS用于简单数据交换,CANopen用于伺服控制。还要注意引用用户提供的资料,说明这些协议在口罩机程序中的应用,比如凸轮同步控制可能使用CANopen的同步机制。 最后,生成相关问题时要围绕协议选择、配置、应用场景和故障排除,帮助用户深入理解。</think>### 汇川PLC上位机通信协议解析 汇川PLC(如AM401、AM403系列)与上位机通信时,主要支持以下工业通信协议: 1. **MODBUS RTU/TCP** - **MODBUS RTU**:基于RS-485/RS-232的串行通信协议,常用于简单数据读写和设备控制[^1]。 - **MODBUS TCP**:基于以太网的协议,适用于高速、大容量数据传输场景。 2. **CANopen** - 用于总线伺服控制,支持多轴同步(如凸轮同步控制、封边轴随动跟随控制)。 - 在复杂运动控制系统中表现优异,例如实现伺服电机的JOG、回原点、绝对定位等功能[^1]。 3. **EtherCAT** - 部分高端型号可能支持EtherCAT协议,适用于高实时性要求的场景(如高速口罩机生产线)。 4. **汇川自定义协议** - 部分设备可能使用基于CODESYS的通信接口,通过ST语言编程实现定制化数据交换。 --- ### 协议应用场景对比 | 协议 | 特点 | 典型应用 | |--------------|--------------------------|------------------------------| | MODBUS RTU | 简单、低成本、低速 | 传感器数据采集、基础控制 | | CANopen | 多节点、实时性强 | 伺服系统同步、多轴运动控制 | | EtherCAT | 超高速、低延迟 | 高速生产线、精密设备控制 | --- ### 配置建议 1. **MODBUS RTU配置** - 需设置波特率(如9600/19200)、数据位、校验位,通过PLC的串口模块(如AM401-CPU1608TP)实现。 - 示例代码(ST语言): ```st MB_MASTER( PORT := 1, SLAVE_ADDR := 1, DATA_ADDR := 40001, LEN := 10, MODE := 0 ); ``` 2. **CANopen配置** - 使用CODESYS的CANopen库,配置对象字典(OD)参数,如PDO映射、同步周期等[^1]。 - 伺服驱动器的通信参数需与PLC保持一致(如节点ID、波特率)。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值