ST语言中定时器转换为C语言的研究_第1页
ST语言中定时器转换为C语言的研究_第2页
ST语言中定时器转换为C语言的研究_第3页
ST语言中定时器转换为C语言的研究_第4页
ST语言中定时器转换为C语言的研究_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、    st语言中定时器转换为c语言的研究    李雨真摘  要: c语言具有良好的可移植性,适合于可编程控制器(programmable logical controller,plc)的嵌入式系统实现和研发;而定时器在plc系统负责时序逻辑描述,具有很重要的作用。文章着重研究如何将plc结构化文本(structured text,st)语言中的定时器转换为c语言程序的问题。介绍了st定时器时间自动机模型的构建,以及将该时间自动机描述为c程序,并采用uppaal模型检测工具进行验证,从而保证转换前后功能的一致性。关键词: 结构化文本; 定时器;

2、 时间自动机; uppaal:tp301.6          文献标志码:a     :1006-8228(2019)06-12-04abstract: having good portability, c language is suitable for realizing and developing the embedded system of programmable logical controller. and timer is responsible for sequential logic des

3、cription and plays an important role in plc system. this article focuses on how to convert the timer in plc structured text (st) language into c language. the construction of st timer time automata model is introduced, and the model is described with c language program. the model checker uppaal is u

4、sed for verification to ensure the consistency of functions before and after the conversion.key words: structured text; timer; timed automata; uppaal0 引言随着电子技术的发展,嵌入式处理器的性能日益增强,逐渐达到plc的性能要求。凭借着易于设计开放式硬件架构的优点,以嵌入式处理器为核心的嵌入式可编程控制器(embedded programmable logic control, eplc)成为一种新型的plc形态1。eplc具有灵活的硬件结构,使

5、用简单且开发周期短2,受到国内外诸多研究人员的关注。c语言具有可移植性强的特点,且广泛适用于嵌入式设备3,st语言是一种类似于pascal的高级编程语言4,将st语言转换为c语言能够为eplc的实现和研发提供一种参考和借鉴意义。然而,st语言支持时间类型,且其中的定时器在plc系统中负责时序逻辑描述,起着关键的作用。因此,本文着重研究st语言中定时器转换为c语言的问题。国内外有关plc中定时器的建模和验证工作在文献5-9中提出,推进了定时模块在国内外的研究进展,但仍存在不足之处。文献5-6提出基于时间自动机的定时器建模方法,但验证复杂不易理解。文献7提出一种基于特定布尔代数的验证方法。文献8采

6、用coq工具验证定时器,该方法对用户要求较高。文献9采用普通petri网对定时器建模,只分析逻辑错误,未考虑时间信息。综上,本文提出一套针对定时器的st程序与c程序到时间自动机的转换方法。方法的研究思路是采用时间自动机分别对st中定时器功能块与转换后的定时器c函数进行建模,并使用uppaal工具验证转换前后的一致性。1 st语言中定时器建模对st语言中的定时器功能块,本文通过对定时器特性的分析,提取出定时器的通性,抽象成一个含有时间信息的通用模型,再结合各个定时器特性,将其转换成符合的时间自动机。根据iec61131-3标准规定,定时器主要分为以下三种:接通延迟定时器(ton)、断电延迟定时器

7、(tof)和定时脉冲定时器(tp),且分辨率有1ms、10ms、100ms。定时器的时序图如图1所示。通过分析定时器时序图可知,当定时器开始工作时,当前已计时间et从0开始线性增长,当达到预设时间pt时,保持et等于pt。因此,可以根据当前已计时间et的变化将定时器抽象成时间自动机,定时器可以分为三种状态:初始状态(et=0)、工作状态(0<et< p> 初始状态init。表示定时器不工作,初始化定时器各参数。 工作状态work。表示定时器处于运行时,时钟开始计时,且在该状态下始终满足et处于范围(0,pt)。 输出状态tout。表示et=pt,改变定时器输出值q。再将定时器

8、内部计算过程模拟为变迁,通过改变变迁使能的顺序,达到定时器输入/输出动作切换的目的,从而實现st语言中定时器到时间自动机的转换。基于上述对st定时器建模原理的阐述,结合iec61131-3标准对定时器的定义,在建模实现过程中将定时器定义为结构体类型,如表1所示。in为输入的使能变量,pt为输入的预设时间变量,et为输出的当前已计时间变量,q为输出的输出值变量。针对不同功能的定时器具体建模,从而得到各类定时器的时间自动机模型。本文以ton为例构建的定时器模型如图2所示。2 c语言中定时器函数建模对于定时器转换后的c函数,本文采用中间形式的表示方法,将相应的定时函数转换为时间自动机。c语言中的定时

9、器函数是根据定时器特性所实现的,这里以ton函数为例,该函数实现的伪代码如表2。由于st中功能块的输出结果是可以存取的,因此在c函数中输出变量的类型为指针数据类型。函数体中的curtime()函数返回系统当前时间。2.1 建模原理c程序到时间自动机的转换采用中间表示(intermediate representation, ir)的形式。根据时间自动机语法和语义,ir具有满足条件ci(ta中的guard)和赋值ai(ta中的迁移)两个表达式。赋值表达式ai具有“v:=e”形式,其中v是变量,e是表达式。条件c和表达式e定义如下(其中为比较操作):每一个ir的表示形式及其相应的平行分支形式如下。

10、ir用来表示指令的语法,可以翻译为两个位置l与l'之间的迁移,翻译如表3所示。如果对于所有的ij,但是,所有条件构成的一个全集,即,从而所有的条件互斥。2.2 建模结果根据建模原理可知,当遇到分支语句时,将分支语句的判断条件作为迁移的guard值,条件成立后的赋值语句作为迁移的update值。从表2描述的ton函数伪代码可以看出,函数体共有2个if语句,根据ir方法可以得出ton的平行分支表达形式如下:读取ton平行分支表达,并将其转换为时间自动机。根据上述原理,所构建的c函数中ton的时间自动机如图3所示。3 定时器验证uppaal工具提供了强大的模拟器和验证器10,可以在验证器中利

11、用时序逻辑tctl来验证一些关注的性质。因此,本文采用该工具验证定时器转换前后功能的一致性,验证标准为:当c程序中定时器函数所对应的时间自动机到达(未到达)最终状态t时,st定时器对应的时间自动机也到达(未到达)最终状态tout。所使用的性质验证语句如表4所示。在uppaal的验证器中分别输入表4中的验证语句,结果如图4所示。结果表明,针对定时器的st语言程序与c语言程序所建立的时间自动机模型等价。4 小结本文针对plc中的定时器展开研究,提出定时器中st程序和c程序到时间自动机的转换方法,并采用uppaal工具进行验证,结果表明两种语言描述的定时器是一致的。以uppaal为工具对时间自动机做

12、模型检测时,随着时间自动机数量、时钟变量的增多,验证过程的复杂性将提高、耗时增加,甚至可能会导致验证无法顺利完成。因此,下一步工作重点是刻画出st语言转时间自动机的优化方法,使得在功能等价的情况下,状态尽可能精简,从而提高正确性验证的效率。此外,我们还将进一步研究st语言中其他功能块的验证及实际应用。参考文献(references):1 ahmed i, obermeier s, sudhakaran s, et al. programma-ble logic controller forensicsj. ieee security & privacy,2017.15(6):18-24

13、2 alves t, das r, morris t. embedding encryption and machine learning intrusion prevention systems on programmable logic controllersj. ieee embedded systems letters, 2018.10(3):99-1023 bispo j, cardoso j m p. a matlab subset to c compilertargeting embedded systemsj. software: practice and exper

14、ience,2017.47(2): 249-2724 彭瑜,何衍庆.智能制造工业控制软件规范及其应用m.机械工业出版社,2018.5 mader a, wupper h. timed automaton models for simpleprogrammable logic controllersc/ euromicro conference on real-time systems. citeseer,1999.6 zhou m, he f, gu m, et al. translation-based model checking for plc programsc/ 2009

15、33rd annual ieee international computer software and applications conference. ieee computer society,2009.7 roussel j m , faure j m . an algebraic approach for plc programs verificationc/ international workshop on discrete event systems. ieee,2002.8 wan h, chen g, song x, et al. formalisation andverification of programmable logic controllers timers in coqj. iet software,2011.5(1):32-429 溫世刚,罗继亮,倪会娟等.基于普通petri网的梯形图中接通延时定时器的建模方法j.计算机科学,2014.41(7):153-15610 david a, larsen k g, legay a, et a

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论