面向对象编程是计算机语言的一种先进的编程模式,在工业控制系统的PLC程序中也可以采用这种设计思想,虽然我们无法实现面向对象的很多特点如“继承”,甚至于它根本就不具备面向对象编程语言的特点,但面向对象编程的基本概念就是类和类的实例(即对象),我们只需要使用这种概念就可以了。在计算机编程中我们需要把一些事物抽象和归纳,才能编写类,而在工业控制系统中,控制对象如:电机,阀等等是很明显的控制类别,不需要抽象就可以很明显的针对它们编写类,以下将会用到西门子的Step7编程语言和施奈德的Unity 编程语言来讲解PLC的面向对象编程。
一、 实现方式
面向对象编程在Step7中使用功能块(即FB)编程,一谈到此大家就会想到西门子提出的模块化编程,不错,就是这个模块化编程,但西门子提出的模块化、背景数据块、多重背景等名词并不能让大家很明白的理解和使用这种的设计理念。
如果大家从面向对象编程的角度去理解,则可以很好的理解这种设计模式。“FB块”被看 成“类”,它可以被看成是对相似的控制对象的代码归纳,如对MM440的变频器可以编写FB块:MtrMM440,这在面向对象编程中称为“类”,当需要 编程控制具体的电机时,可以给它分配一个背景DB块,在面向对象编程中称为类的实现(即创建类的实例:对象),当需要控制多个电机时,可以分配不同的背景 DB到这个FB块,即创建类的多个实例。Step7中有另外一种程序块,即FC块,以FC块为主的编程在西门子中称为结构化编程,这也可以类比于计算机编程中的面向过程编程,即纯粹以函数为主体的编程。
施奈德的Unity软件编程可以更好的理解面向对象编程。它的DFB定义中包含输入/输出参数,私有/共有变量,以及代码实现,而这正是计算机的面向对象 编程中“类”的基本元素,而创建类的实例(对象)就像创建普通的“布尔”变量一样,只需在“Function Blocks”中定义这种“类”的变量即可。
Step7和Unity都可以采用面向过程和面向对象编程方式,这两种编程方式的区别类似于计算机语言中的C语言和C++语言编程的区别。
以下的讲解将会把Step7中的FB和Unity中的DFB称为“类”,Step7中的FB+背景DB以及Unity中DFB的实例称为“对象”。
二、 面向对象编程架构
以上讲解的是实现细节,而编程思想是建立在程序架构上的,不是某个局部使用了面向对象方式,则可以称之为这种编程就是面向对象编程。这种编程需要从以下方面着手:
1、 电路设计的结构化。
这里主要以自动线为主介绍,对于单机机床可以是它的简化结构:
、自动线层:这是高层次,它拥有一个主PLC,对属于它下面的各区域控制、工程层:拥有独立的配送电系统,但没有PLC,只有分布式模块,由自动线控制。顾名思义,它有着较大的独立性,可以作为一个单独的工程项目设计和制造,当自动线比较小时,可以省略该层次。
、功能组层:根据工艺划分,将实现某一个工艺功能的区段设备划分为一个功能组,它隶属于工程层,当工程层被省略时,隶属于自动线层。面向对象编程并不一定要求使用以上的结构,但好的电气结构更利于面向对象编程。
2、 任何控制对象逻辑都在“类”中实现。
为了做到这点,必须分析与控制对象相关的信息,譬如,对于一个电机,有以下相关的信息需要考虑:
输入信息:
、电路保护信息,如电机的空气开关,热继电器等。
、功能保护信息,如运动电机的限位开关,风机的风压开关,油泵的油位开关等。
、启动和终止条件,以上的电路保护和功能保护都可能导致电机运转终止,复位也可能导致重启动,但这里的条件指的是正常运行的启动和终止条件,譬如顺序控制的流程步。
、控制模式:如手动和自动等。
、故障复位:通过复位信息,重新启动。
输出信息:
、控制输出,如控制电机的主接触器。
、状态信息输出
、故障输出
状态储存信息:
用于代码实现的中间变量以及可以被人机界面读出的状态变量等。把以上信息都整合到一个类中,并尽量使类的参数标准化。不过,同编程语言还是存在一些差别,针对Step7,应该遵循的标准是:程序结构由FC实现,对象控制由FB实现,如下的一种结构体系(其电气结构来自上面的介绍):这只不过是一个粗略的PLC程序架构体系,好的架构应该更完善和科学。
3、 规划好数据结构
数据结构的定义相当重要,并尽量统一这些结构,不要顾虑存储空间,当今的PLC内存足以容纳大量的数据。说明一点的是在Step7中尽量不要在类的外部定义数据结构(UDT),而是在类里面定义,虽然会造成不同类中同一结构的重复性定义,但却提高了类的独立性。
在接下来的篇幅中,我们来对比一下这两种编程方式:
面向对象编程的优点与梯形图逻辑相比,面向对象编程有以下优点 :
• 代码可移植,易于重复使用 ;
• 易于使用数学函数、循环等 ;
• 几乎在每一门计算机编程课程中,都会教授面向对象编程 ;
• 代码可以在各种硬件平台上运行。
要掌握面向对象编程,首先需要理解对象的概念及其使用。一旦对象或模块类编写完成, 就很容易通过多次调用来实现重复利用。例如,创建一个对象来控制电机,用来处理所有输入、输出和故障。当需要时,可以通过多次实例化 该单一控制对象,来控制多个电机。这就是所谓的按需实例化。当需要控制多个电动机时, 可以多次使用该单个物体。它在需要时调用,并在使用时创建实例。
每个电机的每个实例都有自己的特性,如电机停机、电机运行、电机转速、电机过载 等。大多数编程工作都是在创建对象时完成的。这是一种与梯形逻辑不同的思维方式,而且更强大,因为一旦构建了一个对象,它就很容易使用和重用。面向对象编程更易于执行复杂的数学函数、循环计算、数组和嵌套子例程。几乎每一门计算机编程——无论是高中、大学、还是网络上的教程,都会教授这方面的知识。创建的代码是可移植的,可以在各种硬件平台上运行。
“梯形图逻辑遵循继电器控制 系统中使用的梯形电气图的格 式,大多数人都可以快速学习 并掌握它。”
不过,与梯形图逻辑相比,面向对象编程有以下缺点 :
• 费用更高 ;
• 更陡峭的学习曲线 ;
• 对于维护人员来说,故障排除不是特别 容易 ;
• 在将源代码上传到处理器之前,通常需要编译。
与梯形图逻辑相比,面向对象编程往往需要更多的内存和更强的处理能力,因此费用就更高。面向对象编程语言的学习时间可能更长。很可能需要课堂学习,需要大量的时间、实践、测试和应用来掌握核心概念。编程人员必须经常研究面向对象编程,以便使用跟踪器来追踪代码,或调试器来调试逻辑。使用这种类型的编程,可能很难实现实时在线监视功能。
在将源代码下载到控制器之前,必须对其进行编译。通常,源代码并不保存在处理器内存中。这意味着必须小心备份源代码,因为编译过的代码通常是不可编辑的。使用面向对象编程,库文件必须与在编译过程中使用的其它资源相连接。如果不了解连接和资源,将很难使程序运行。
梯形图逻辑优势:梯形图逻辑是一种简单且自文档化的编码方法,甚至有人怀疑它是否是一种编程语言。它遵循继电器控制系统中使用的梯形电气图的格式,大多数人都可以快速学习并掌握它。它是在过去的数十年来唯一在机器自动化领域中大规模应用的编程语言,并且在可预见的将来, 仍然是自动化行业中使用的主要编程语言之一。
随着时间的推移,具有不同背景的人从不同领域进入该行业,各种编程语言被引入工业自动化工具箱中。其中包括功能块编程、结构化文本、状态编程和顺序功能图。这 4 种编程语言和梯形图逻辑,构成了IEC61131-3 国际电工委员会 (IEC) 的标准编程语言。
IEC61131 背后的逻辑是 :如果每个供应商都遵循该标准,那么至少在某种程度上,一个人只需学习这 5 种编程语言,就可以轻松地在来自不同供应商提供的平台之间进行切换。然而,事实却并非如此。
基本梯形图逻辑(如使用继电器触点和线圈)也是一样的 ;但是在编程时,必须学习每个供应商的语法和用户体验,以及如何使用编程平台的详细信息。尽管缺乏标准化,但与面向对象编程相比,梯形图逻辑有以下优势 :
• 非常适合机器和过程控制 ;
• 由于本质上是自文档,因此更易于理解;
• 易于对受控系统进行故障排除 ;
• 易于调试 ;
• 源代码通常可以存储在处理器中。
梯形图逻辑非常适合于机器和过程控制, 特别是具有大量离散输入、输出(I/O)的自动化系统。多年来,梯形图逻辑也在不断改进,以处理模拟量I/O,使其更适合于众多的过程控制应用。
与机器控制应用相比,过程应用中模拟量 I/O 的比例往往较高。
因为梯形图逻辑比面向对象编程更易于使用,因此众多熟练的技术人员和工程人员可以快速学习梯形图逻辑。逻辑高度系统化、有序化,再加上其具有自文档的性质,使其更易于理解和掌握。在启动某个设备之前,每行代码都必须为真。如果有 5 个电机需要控制,那么至少需要 5行代码,实现了高度简化。
“梯形图逻辑源代码和描述符通常保存在控制器中,无需访问源代码,这可以消除程序员在试图理解编译程序所遭受的挫败。”
对电气工程师和维护人员来讲,梯形图逻辑非常直观。虽然梯形图逻辑需要有与面向对象编程不同的思维方式,但通过学习可以快速掌握,并且理解他人编写的代码所需的时间也较少。逻辑何时为真,何时为假,一清二楚。即使编程经验有限的人,也很容易弄清楚开或关、线圈通电、比较变量和常见的数学函数。
它简单易用,简化了故障排除和调试工作。监视逻辑时,可以很容易明白目前正在发生的工况。无需软件学位或编程技能。有了梯形图逻辑,维护人员和工程人员就很容易跟踪流程,了解正在发生的事情。可以将梯形图逻辑看作真值表。如果左边的逻辑为真,则右侧的逻辑就会启动。
梯形图逻辑源代码和描述符,通常被保存在控制器中。这可以消除程序员在试图理解编译程序而无法访问源代码时所遭受的挫败,面向对象编程也是如此。
然而,与面向对象编程相比,梯形图逻辑也有如下缺点 :
• 计算机程序员和 IT人员对梯形图逻辑不熟悉 ;
• 难于进行数学函数、文本和数据处理 ;
• 依赖于扫描时间 ;
• 需要专门的硬件来执行, 如可编程逻辑控制器 (PLC) 。
梯形图逻辑是计算机程序员和IT人员所不熟悉的一种符号语言,他们在学校里并没有学习这种语言。在梯形图逻辑中处理数学函数、文本字符串和数据可能会很困难,这主要是因为梯形图逻辑初并不是为了处理这些函数而设计的。
梯形图逻辑也依赖于扫描时间。较大的程序,需要更长的时间来扫描和处理逻辑。执行梯形 图逻辑时,读取输入、扫描逻辑、 更新数据表和输出、执行通信, 然后循环重复。可以实现中断和其它编程技术等功能,以确保更快地执行某些逻辑。
尽管配置了梯形图逻辑的基于软件的PLC可以在PC上运行, 但通常硬件 ( 如 PLC)要与编程软件相匹配,两者好都是从同一个供应商处购买的。这样就可以确保兼容性,但如果想要更换供应商,则不是特别方便。
除了比较梯形图逻辑和面向对象编程的利弊外,用户还应该评估这些编程语言在将要部署的环境中的使用情况。如果工厂或设施已实现了梯形图逻辑的标准化,那么即使面向对象编程更适合于该应用,也不鼓励将梯形图逻辑更换为 面向对象编程。随着面向对象编程的使用日益增多,预计在未来几十年内,它将与梯形图逻辑共存。一个有远见的自动化人士,好要掌握这两种语言。