PLC梯形图编译原理.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PLC梯形图编译原理 IL语言非常接近汇编语言,编码后,PLC处理器能很容易识别,但是梯形图是图形元素,CPU不容易识别,所以要将梯形图先编译为IL语言。本文提供了一种递归编译的方式,不完善的地方,还请见谅。 转换思路: 将梯形图以网络为单位进行遍历,选择一个网络进行分析,梯形图本质是块和块之间的串联,串联的块中又可能包含了并联关系,但是并联关系中,其实也是串联块的并联。如图1: ? ? 在整个梯形图编译的过程中,主要使用2个步骤(或者叫函数),一个步骤分析块之间的串联关系,一个步骤分析块之间的并联关系。 ? 步骤0:先初始化开始行为网络的第一行,开始列为第一列,结束列为最后一列。然后进去步骤1。 步骤1、 ?????? (1)建立一个块堆栈BlockStack,输出堆栈OutputStack。 (2)首先将图进行串联块的分析。将分析到的块压入BlockStack,输出块压入OutputStack. (3)遍历BlockStack,对每一个块进行分析, 1)如果块的行数大于1,表示块中有并联关系,到步骤2分析该块。 ????????????? 如果块不是第一个块,则要在并联关系解释完后,加入ANB指令。 2)如果块的行数等于1,表示块已经是最简串联块,直接输出块的语句。 ????????????? 如果块是第一个块,使用LD加载第一个元素,依次往后使用AND。(至于使用LDI,还是ANI,请判断元素的类型。) ????????????? 如果块不是第一个块,使用AND加载第一个元素,依次往后使用AND。 (3)遍历输出块。 ???????????? 如果输出块是多行,使用步骤2分析输出块。 ???????????? 如果输出块是单行,则直接输出块中元素:OUT、SET、RST。 步骤2、 ?????? (1)首先判断传入的块是输出块还是普通块。如果是输出块,建立一个记录标志。 建立一个或堆栈.OrBlockStack. 分析块Blcok中由哪几个串联块并联而成,将块压入OrBlockStack中. A、遍历OrBlockStack,每一个串联块进行步骤1串联分析。 B、为每一个串联块加上并联关系。 1)如果是输出:如果一共有2个分支,则第一个分支加入MPS,第二个分支加入MPP。 ???????????? 如果分支大于2个,则第一个分支加入MPS,最后一个分支加入MPP,其他分支加入MPR。 2)如果不是输出:如果串联块中横线方向元素个数大于1个,加入ORB,(来源:/)如果只有一个元素,加入OR,进入步骤3检查代码。如果没有元素,就是短路。报错。 步骤3:全部完成后,对指令进行分析,如果有 LD Xn OR 这样的指令,要合并为: OR Xn. 举例说明: 梯形图程序如图1,可以划分为3个块:块1,块2,输出块。3个之间是串联的关系。 图1 (现在是在步骤1中)依次将块1,块2,输出块传入步骤2,根据步骤1可知,块2后面需要加入ANB指令。 块1传入步骤2后,可以分析到块1是由2个串联块A、B并联组成的。如图2: 图2 (现在是在步骤2中)依次将A、B传入步骤1,根据步骤2可知,B传入步骤1后,要加上ORB指令。 块A传入步骤1后,可以分析到块A是由3个块a,b,c串联组成的,如图3: (现在是在步骤1中)然后依次将a,b,c传入到步骤2中进行分析,根据步骤1可知,b进入步骤2后,要加入ANB指令,C进入步骤2后,也要加入ANB指令。 块a可以分析得到是由3个单行的串联a1,a2,a3块并联组成的。 (现在是在步骤2中)再依次把a1,a2,a3传入步骤1进行串联分析,根据步骤2可知,X2传入步骤1后,要加入OR指令,X3传入步骤1后,也要加入OR指令。 a1进入步骤1,可以得到a1只有一行,所以直接输出a1为 LD X1 a2传入步骤1,可以得到 LD X2 OR a3传入步骤1可以得到 LD X3 OR 最后对指令进行分析,只要有 LD Xn Or 这样的,都合并为OR Xn. 整理后得到指令为: ?????? LD X1 ?????? OR X2 ?????? OR X3 。 依次往后遍历,最后能得到所有的指令为: LD X1 OR X2 OR X3 LD X4 OR X5 ANB LD X6 OR X7 ANB LD X9 OR X10 LD X11 LD X12 ANB ORB LD X13 OR X14 LD X15 OR X16 ANB OR X17 ANB OUT Y1 在这个算法中,将梯形图元素分块,是最关键的,所以要处理好梯形图元素的分块,至于怎么分块,就需要自己想了哟~ .

文档评论(0)

精品报告 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档