micgor
级别: *
精华主题: * 篇
发帖数量: * 个
工控威望: * 点
下载积分: * 分
在线时间: (小时)
注册时间: *
最后登录: *
查看micgor的 主题 / 回贴
楼主  发表于: 2011-05-03 17:08
说起PLC的程序结构,大家都知道PLC有主程序、子程序(S7-300/400称为功能和功能块)和中断程序,好像没有什么好讨论的。实

际上不同的PLC的程序结构有很大的区别,程序结构体现了编程思想是否先进,决定了程序是否有很好的可重用性(可移植性)。可以

说程序结构是设计一个理想的自动化PLC产品首先应解决的最重要的问题。不少国产PLC在程序结构方面存在较大的问题,采用理想的程序结构

的国产PLC不多。例如有一家国产PLC自称与三菱的FX2N兼容,但是居然没有中断功能!
1  几种典型的PLC程序结构
    下面介绍几种常见的PLC的程序结构及其特点:
    1.某些国外的小型PLC的程序结构
    这些PLC的用户程序由主程序、子程序和中断程序组成。在每一个扫描循环周期,CPU都要调用一次主程序。主程序可以调用子程序

,小型控制系统可以只有主程序。
    中断程序用于快速响应中断事件。在中断事件发生时,CPU将停止执行当时正在处理的程序或任务,去执行用户编写的中断程序。

执行完中断程序后,继续执行被暂停执行的程序或任务。
    它们的子程序和中断程序没有局部变量,子程序没有输入、输出参数。
    2.西门子的S7-200的程序结构
    过程映像输入/输出(I/Q)、变量存储器V、内部存储器位M、定时器T、计数器C等属于全局变量。S7-200的程序组织单元(Program

Organizational Unit,简称为POU)包括主程序、子程序和中断程序。每个POU均有自己的64字节局部变量,局部变量只能在它所在的

POU中使用。与此相反,全局变量可以在各POU中使用。
下面是子程序可以使用的局部变量:
    1) TEMP (临时变量)是暂时保存在局部数据区中的变量。只有在执行该POU时,定义的临时变量才被使用,POU执行完后,不再保存

临时变量的数值。
    2) IN是由调用它的POU提供的输入参数。
    3) OUT是返回给调用它的POU的输出参数(子程序的执行结果)。
    4) IN_OUT是输入_输出参数,其初始值由调用它的POU传送给子程序,并用同一变量将子程序的执行结果返回给调用它的POU。
    主程序和中断程序的局部变量中只有临时变量TEMP。
    具有输入、输出参数和局部变量的子程序易于实现结构化编程,对于长期生产同类设备或生产线的厂家尤为有用。这些厂家的编程

人员为设备的各组件或工艺功能编写了大量的通用的子程序。即使不知道子程序的内部代码,只要知道子程序的功能和输入、输出参数

的意义,就可以通过程序之间的调用快速“组装”出满足不同用户要求的控制程序。就好像用数字集成电路芯片组成复杂的数字电路一

样。
    子程序如果没有输入、输出参数,它和调用它的程序之间没有清晰的接口,很难实现结构化编程。
    子程序如果没有局部变量,它和调用它的程序之间只能通过全局变量来交换数据,子程序内部也只能使用全局变量。将子程序和中

断程序移植到别的项目时,需要重新统一安排它们使用的全局变量,以保证不会出现地址冲突。当程序很复杂,子程序和中断程序很多

时,这种重新分配地址的工作量非常大。
    如果子程序和中断程序有局部变量,并且它们内部只使用局部变量,不使用全局变量,因为与其他POU没有地址冲突,不需作任何

改动,就可以将子程序移植到别的项目中去。
    3.西门子的S7-300/400的程序结构
    S7-300/400将子程序分为功能(Function,或称为函数)和功能块(Function Block)。
    S7-300/400的功能与S7-200的子程序基本上相同。它们均有输入、输出参数和临时变量,功能的局部数据中的返回值实际上属于输

出参数。它们没有专用的存储区,功能执行结束后,不再保存临时变量中的数据。
    可以用全局变量来保存那些在功能执行结束后需要保存的数据,但是会影响到功能的可移植性。
    功能块是用户编写的有自己专用的存储区(即背景数据块)的程序块,功能块的输入、输出参数和静态变量存放在指定的背景数据

块中,临时变量存储在局部数据堆栈中。每次调用功能块时,都要指定一个背景数据块。功能块执行完后,背景数据块中的数据不会丢

失,但是不会保存局部数据堆栈中的数据。
    功能块采用了类似于C++的封装的概念,将程序和数据封装在一起,具有很好的可移植性。
    S7-300/400的共享数据块可供所有的逻辑块使用。
    4.IEC 61131-3的程序结构
    IEC 61131-3是PLC的编程语言标准。IEC 61131-3是世界上第一个,也是至今为止唯一的工业控制领域的编程语言标准。IEC

61131-3有三种POU:程序、功能块和功能。
    功能是有多个输入参数和一个输出参数(返回值)的POU,返回值的名称与功能的名称相同,需要定义返回值的数据类型。调用具

有相同输入值的功能总是返回相同的结果。功能可以调用其他功能,但是不能调用功能块或程序。功能可定义的局部变量有VAR和

VAR_INPUT。
    功能块是有多个输入/输出参数和内部存储单元的POU,功能块的输出参数值与其内部存储单元的值有关。功能块可以调用其他功能

块或功能,但是不能调用程序。
    在调用功能块之前,必须在要调用功能块的POU中为每次调用声明功能块的实例,操作系统将为每次调用分配功能块专用的存储区

(类似于S7-300/400的背景数据块)。
    功能因为没有内部存储区,调用时不需要实例化。
    程序的行为和用途类似于功能块,程序具有输入和输出参数,而且可以具有内部存储区。程序通常包含有对功能和功能块的调用。
    IEC 61131-3定义了若干标准的功能和功能块。
    5.S7-300/400与IEC 61131-3程序结构的区别
    1)S7-300/400的功能可以有多个输出参数,返回值也属于输出参数。IEC 61131-3的功能只有一个返回值。
    2)IEC 61131-3的功能块用于保存局部变量的专用存储区是在声明功能块的实例时分配的,它对用户是不透明的,其他POU不能直

接访问该存储区。
    S7-300/400的功能块的局部变量(不包括临时变量)保存在它的背景数据块中。其他POU可以访问背景数据块中的变量。如果需要

多次调用同一个功能块来控制同一类型的被控对象,每次调用都需要指定一个背景数据块,但是这些背景数据块中的变量又很少,这样

在项目中就出现了大量的背景数据块。可以使用多重背景数据块来减少背景数据块的数量。但是需要增加一个用来管理多重背景的功能

块。
    3)S7-300/400的功能块的局部变量有临时变量和静态变量,IEC 61131-3的功能块的内部变量Var相当于S7-300/400的静态变量。
    4)S7-300/400将数据区划分为数据块来使用,数据块的大小与数据块中定义的变量的数据类型和变量的个数有关。IEC 61131-3没

有数据块的概念。
2  对国产PLC程序结构的建议
    1.小型PLC至少采用类似于S7-200的程序结构
    鉴于局部变量和子程序的输入、输出参数的重要作用,建议小型PLC至少采用类似于S7-200的程序结构,子程序有输入、输出变量

,子程序和中断程序有局部变量。
    其缺点是子程序没有专用的存储区,如果在执行完子程序后有需要保存的数据,不能使用子程序的临时局部变量,只能使用全局变

量来保存它们。这样的子程序没有完全解决可移植性问题。
    2.建议采用IEC 61131-3的程序结构
    S7-300/400或IEC 61131-3的程序结构比较理想,其功能块内部可以全部使用局部变量,不使用全局变量,彻底解决了程序块的可

移植性问题。相对而言,IEC 61131-3的程序结构比较简单。
    有的国产PLC自称符合IEC 61131-3标准,我认为该标准的核心和精髓是程序结构,是检验真假IEC 61131-3的试金石。为了产品的

长远发展,建议国产PLC采用IEC 61131-3的程序结构
本帖最近评分记录:
  • 下载积分:+2(雪花飘飘) 感谢分享
    左边的幸福
    级别: *
    精华主题: * 篇
    发帖数量: * 个
    工控威望: * 点
    下载积分: * 分
    在线时间: (小时)
    注册时间: *
    最后登录: *
    查看左边的幸福的 主题 / 回贴
    1楼  发表于: 2011-05-03 17:21
    写的不错哦,学习啦。
    科技改变未来
    知识就是让你秃头的力量
    级别: 家园常客
    精华主题: 0
    发帖数量: 553 个
    工控威望: 758 点
    下载积分: 10387 分
    在线时间: 439(小时)
    注册时间: 2011-04-18
    最后登录: 2024-11-06
    查看科技改变未来的 主题 / 回贴
    2楼  发表于: 2011-05-04 23:19
    晕啊 好多字啊
    535357
    级别: 略有小成
    精华主题: 0
    发帖数量: 122 个
    工控威望: 238 点
    下载积分: 843 分
    在线时间: 70(小时)
    注册时间: 2011-04-19
    最后登录: 2014-07-05
    查看535357的 主题 / 回贴
    3楼  发表于: 2011-05-05 09:02
    真正的高手!制造PLC的!我抄走了。
    雪花飘飘
    级别: VIP会员

    精华主题: 1 篇
    发帖数量: 2620 个
    工控威望: 2044 点
    下载积分: 6787 分
    在线时间: 3545(小时)
    注册时间: 2007-09-03
    最后登录: 2024-11-18
    查看雪花飘飘的 主题 / 回贴
    4楼  发表于: 2011-05-05 09:09
    好帖子。     
    cvlsam
    富士低压,POD(觸摸屏),PLC专卖
    级别: VIP会员

    精华主题: 3 篇
    发帖数量: 6769 个
    工控威望: 38370 点
    下载积分: 2995 分
    在线时间: 9505(小时)
    注册时间: 2006-09-13
    最后登录: 2024-11-18
    查看cvlsam的 主题 / 回贴
    5楼  发表于: 2011-05-05 09:16
    引用
    引用第3楼535357于2011-05-05 09:02发表的  :
    真正的高手!制造PLC的!我抄走了。


    廖常初老師寫的 ,比較粗略,為騰控撰寫。
    sy2kj
    www.sy2kj.com
    级别: 探索解密
    精华主题: 0
    发帖数量: 47 个
    工控威望: 149 点
    下载积分: 710 分
    在线时间: 41(小时)
    注册时间: 2010-12-14
    最后登录: 2013-11-29
    查看sy2kj的 主题 / 回贴
    6楼  发表于: 2011-05-05 14:01
    这有什么啊? 只要程序编制简单,流程图样式的结构,修改容易就行了,管他什么标准呢。