step7编程语言与指令

上传人:xins****2008 文档编号:146411938 上传时间:2022-08-31 格式:DOC 页数:15 大小:138.50KB
返回 下载 相关 举报
step7编程语言与指令_第1页
第1页 / 共15页
step7编程语言与指令_第2页
第2页 / 共15页
step7编程语言与指令_第3页
第3页 / 共15页
点击查看更多>>
资源描述
S7-300/400的编程语言与指令系统3.1 S7-300/400的编程语言3.1.1 PLC编程语言的国际标准IEC 61131是PLC的国际标准,19921995年发布了IEC 61131标准中的14部分,我国在1995年11月发布了GB/T 15969-1/2/3/4(等同于IEC 61131-1/2/3/4)。IEC 61131-3广泛地应用PLC、DCS和工控机、 “软件PLC”、数控系统、RTU等产品。定义了5种编程语言1) 指令表IL(Instruction list):西门子称为语句表STL。2) 结构文本ST(Structured text):西门子称为结构化控制语言(SCL)。3) 梯形图LD(Ladder diagram):西门子简称为LAD。4) 功能块图FBD (Function block diagram):标准中称为功能方框图语言。5) 顺序功能图SFC(Sequential function chart):对应于西门子的S7 Graph。3.1.2 STEP 7中的编程语言梯形图、语句表和功能块图是3种基本编程语言,可以相互转换。 1顺序功能图(SFC) :STEP 7中的S7 Graph2梯形图(LAD)直观易懂,适合于数字量逻辑控制。“能流”(Power flow)与程序执行的方向。3. 语句表(STL):功能比梯形图或功能块图强。4功能块图(FBD):“LOGO!”系列微型PLC使用功能块图编程。5结构文本(ST):STEP 7的S7 SCL(结构化控制语言)符合EN 61131-3标准。SCL适合于复杂的公式计算、复杂的计算任务和最优化算法,或管理大量的数据等。6S7 HiGraph 编程语言图形编程语言S7 HiGraph 属于可选软件包,它用状态图(state graphs)来描述异步、非顺序过程的编程语言。7S7 CFC 编程语言可选软件包CFC(Continuous Function Chart,连续功能图)用图形方式连接程序库中以块的形式提供的各种功能。8编程语言的相互转换与选用在STEP 7编程软件中,如果程序块没有错误,并且被正确地划分为网络,在梯形图、功能块图和语句表之间可以转换。如果部分网络不能转换,则用语句表表示。语句表可供喜欢用汇编语言编程的用户使用。语句表的输入快,可以在每条语句后面加上注释。设计高级应用程序时建议使用语句表。梯形图适合于熟悉继电器电路的人员使用。设计复杂的触点电路时最好用梯形图。功能块图适合于熟悉数字电路的人使用。S7 SCL编程语言适合于熟悉高级编程语言(例如PASCAL或C语言)的人使用。S7 Graph,HiGraph和CFC可供有技术背景,但是没有PLC 编程经验的用户使用。S7 Graph对顺序控制过程的编程非常方便,HiGraph适合于异步非顺序过程的编程,CFC适合于连续过程控制的编程。3.2 S7-300/400 CPU的存储区3.2.1 数制 1二进制数二进制数的1位(bit)只能取0和1这两个不同的值,用来表示开关量的两种不同的状态。该位的值与线圈、触点的关系。ON/OFF,TURE/FALSE。二进制常数:2#1111_0110_1001_0001。2十六进制数十六进制的16个数字是09和AF, 每个占二进制数的4位。B#16#,W#16#,DW#16#, W#16#13AF(13AFH)。逢16进1,例如B#16#3C3161260。3BCD码BCD码用4位二进制数表示一位十进制数,十进制数9对应的二进制数为1001。最高4位用来表示符号,16/32位BCD码的范围。BCD码实际上是十六进制数,但是各位之间逢十进一。296对应的BCD码为W#16#296,或2#0000 0010 1001 0110。2#0000 0001 0010 1000对应的十进制数也是296,对应的十进制数为。3.2.2 基本数据类型1位(bit):位数据的数据类型为BOOL(布尔)型。I3.2的意义。2字节(Byte)3字(Word)表示无符号数。取值范围为W#16#0000W#16#FFFF。4双字(Double Word)表示无符号数。范围DW#16#0000_0000DW#16#FFFF_FFFF。516位整数(INT,Integer)是有符号数,补码。最高位为符号位,为0时为正数,取值范围为-32 76832 767。632位整数(DINT,Double Integer)最高位为符号位,取值范围为-2 147 483 6482 147 483 647。图3-6 字节、字和双字732位浮点数浮点数又称实数(REAL),表示为1.m ,例如123.4可表示为1.234 。根据ANSI/IEEE标准浮点数1.m 式中指数e = E +127(1 e 254),为8位正整数。ANSI/IEEE 标准浮点数占用一个双字(32位)。因为规定尾数的整数部分总是为1,只保留尾数的小数部分m(022位)。浮点数的表示范围为1.175495 3.402 823 1038。图3-7 浮点数的结构用很小的存储空间(4个字节)可以表示非常大和非常小的数。PLC输入和输出的数值大多是整数,浮点数的运算速度比整数运算的慢。L#为32位双整数常数,例如L# +5。P#为地址指针常数,例如P#M2.0是M2.0的地址。S5T#是16位S5时间常数,格式为S5T#aD_bH_cM_dS_eMS。S5T#4S30MS = 4s30ms,取值范围为S5T#0S5T#2H_46M_30S_0MS(9990s),时间增量为10ms。C#为计数器常数(BCD码),例如C#250。8位ASCII字符用单引号表示,例如 ABC。T#为带符号的32位IEC时间常数,例如T#1D_12H_30M_0S_250MS,时间增量为1ms。DATE是IEC日期常数,例如D#2004-1-15。取值范围为D#1990-1-1D#2168-12-31。TOD#是32位实时时间(Time of day)常数,时间增量为1ms,例如TOD#23:50:45.300。B(b1,b2) B(b1,b2, b3,b4)用来表示2个字节或4个字节常数。3.2.3 复合数据类型与参数类型1复合数据类型通过组合基本数据类型和复合数据类型可以生成下面的数据类型:(1) 数组(ARRAY)将一组同一类型的数据组合在一起,形成一个单元。(2) 结构(STRUCT)将一组不同类型的数据组合在一起,形成一个单元。(3) 字符串(STRING)是最多有254个字符(CHAR)的一维数组。(4) 日期和时间(DATE_AND_TIME)用于存储年、月、日、时、分、秒、毫秒和星期,占用8个字节,用BCD格式保存。星期天的代码为1,星期一星期六的代码为27。例如DT#2004-07-15-12:30:15.200为2004年7月15日12时30分15.2秒。(5) 用户定义的数据类型UDT (user-defined data types)。在数据块DB和逻辑块的变量声明表中定义复合数据类型。2参数类型为在逻辑块之间传递参数的形参(formal parameter,形式参数)定义的数据类型:(1) TIMER(定时器)和COUNTER(计数器):对应的实参(actual parameter,实际参数)应为定时器或计数器的编号,例如T3,C21。(2) BLOCK(块):指定一个块用作输入和输出,实参应为同类型的块。 (3) POINTER(指针):指针用地址作为实参。例如P#M50.0。(3) ANY:用于实参的数据类型未知或实参可以使用任意数据类型的情况,占10个字节。3.2.5 系统存储器1过程映像输入/输出(I/Q)在扫描循环开始时,CPU读取数字量输入模块的输入信号的状态,并将它们存入过程映像输入(process image input,PII)中。在扫描循环中,用户程序计算输出值,并将它们存入过程映像输出表(process image output,PIQ)。在循环扫描结束时将过程映像输出表的内容写入数字量输出模块。I和Q均以按位、字节、字和双字来存取,例如I0.0, IB0, IW0和ID0。与直接访问I/O模块相比的优缺点。2内部存储器标志位(M)存储器区3定时器(T)存储器区时间值可以用二进制或BCD码方式读取。4计数器(C)存储器区计数值(0999)可以用二进制或BCD码方式读取。5共享数据块(DB)与背景数据块(DI)DB为共享数据块,DBX2.3,DBB5,DBW10和DBD12。DI为背景数据块,DIX, DIB,DIW和DID。6外设I/O区(PI/PO)外设输入(PI)和外设输出(PQ)区允许直接访问本地的和分布式的输入模块和输出模块。可以按字节(PIB或PQB)、字(PIW或PQW)或双字(PID或PQD)存取,不能以位为单位存取PI和PO。3.2.6 CPU中的寄存器1累加器(ACCUx)累加器用于处理字节、字或双字的寄存器。S7-300有两个32位累加器(ACCU1和ACCU2),S7-400有4个累加器(ACCU1ACCU4)。数据放在累加器的低端(右对齐)。2状态字寄存器(16位)首次检测位/FC, 逻辑运算结果(RLO);状态位STA不能用指令检测;OR位暂存逻辑“与”的操作结果(先与后或);算术运算或比较指令执行时出现错误,溢出位OV被置1。OV位被置1时溢出状态保持位OS位也被置1,OV位被清0时OS仍保持为1,用于指明前面的指令执行过程中是否产生过错误。条件码 1(CC1)和条件码0(CCO)综合起来用于表示在累加器1中产生的算术运算或逻辑运算的结果与0的大小关系、比较指令的执行结果或移位指令的移出位状态。二进制结果位(BR)在一段既有位操作又有字操作的程序中,用于表示字操作结果是否正确。在梯形图的方框指令中,BR位与ENO有对应关系,用于表明方框指令是否被正确执行:如果执行出现了错误,BR位为0,ENO也为 0;如果功能被正确执行,BR位为 1,ENO也为 1。图3-9 状态字的结构3数据块寄存器:DB和DI寄存器分别用来保存打开的共享数据块和背景数据块的编号。3.3 位逻辑指令位逻辑指令用于二进制数的逻辑运算。位逻辑运算的结果简称为RLO。3.3.1 触点指令1 触点与线圈A(And,与)指令来表示串联的常开触点。O (Or,或)指令来表示并联的常开触点。AN (And Not,与非)来表示串联的常闭触点,ON (Or Not)来表示并联的常闭触点。输出指令“=”将RLO写入地址位,与线圈相对应。L20.0是局域变量。将梯形图转换为语句表时,局域变量L20.0是自动分配的。A( A I 0.0 AN I 0.1 O I 0.2 ) A I 0.3 ON C 5 = L 20.0 A L 20.0 = Q 4.3 A L 20.0 = Q 4.4 A L 20.0 AN I 3.4= Q 4.62 取反触点 3电路块的串联和并联4中线输出指令 下面是图3-14(b)中第一行对应的语句表。A I0.0 AN I0.1 = M0.1 A M0.1 A I0.3 = Q4.3Network 1:AI0.3AI0.0FP=Q4.5 Network 2: AI0.3AI0.0FN=Q4.3A I0.3A(A I0.4BLD 100 FN M0.1 ) = Q4.5【例3-1】设计故障信息显示电路,故障信号I0.0为1使Q4.0控制的指示灯以1Hz的频率闪烁。操作人员按复位按钮I0.1后,如果故障已经消失,指示灯熄灭。如果没有消失,指示灯转为常亮,直至故障消失。设置CPU的属性时,在“Cycle/Clock Memory”标签页令M1为时钟存储器字节,其中的M1.5提供周期为1s的时钟脉冲。 SET与CLR(Clear)指令将RLO(逻辑运算结果)置位或复位,紧接在它们后面的赋值语句中的地址将变为1状态或0状态。SET/将RLO置位= M0.2/M0.2的线圈“通电”CLR/将RLO复位= Q4.7/Q4.7的线圈“断电”3.4.1 定时器指令在CPU内部,时间值以二进制格式存放,占定时器字的09位。可以按下列的形式将时间预置值装入累加器的低位字:(1) 十六进制数W#16#wxyz,其中的w是时间基准,xyz是BCD码形式的时间值。(2) S5T#aH_bM_cS_Dms,例如S5T#18S。时基代码为二进制数00,01,10和11时,对应的时基分别为10ms,100ms,1s和10s。6脉冲定时器类似于上升沿触发的单稳态电路。S5脉冲定时器(Pulse S5 Timer),S为设置输入端,TV为预置值输入端,R为复位输入端;Q为定时器位输出端,BI输出不带时基的十六进制格式,BCD输出BCD格式的当前时间值和时基。定时器中的S,R,Q为BOOL(位)变量,BI和BCD为WORD(字)变量,TV为S5TIME量。各变量均可以使用I, Q, M, L, D存储区, TV也可以使用定时时间常数S5T#。A I 1.2FR T0/允许定时器T0再起动AI 0.0L S5T#2s /预置值2s送入累加器1SP T0 /启动T0AI 0.1R T0 /复位T0L T0 /将T0的十六进制时间当前值装入累加器1T MW10/将累加器1的内容传送到MW10LC T0 /将T0的BCD时间当前值装入累加器1.T MW12/将累加器1的内容传送到MW12A T0 /检查T0的信号状态= Q 4.0/T0的定时器位为1时,Q4.0的线圈通电仅在语句表中使用的FR指令允许定时器再起动,即控制FR的RLO(I1.2)由0变为1状态时,重新装入定时时间,定时器又从预置值开始定时。再起动只是在定时器的起动条件满足(图3-28中的I0.1=1)时起作用。该指令可以用于所有的定时器,但是它不是起动定时器定时的必要条件。8扩展的脉冲定时器10接通延时定时器12保持型接通延时定时器14断开延时定时器线圈3.4.2 计数器指令1计数器的存储器区每个计数器有一个16位的字和一个二进制位。计数器字的011位是计数值的BCD码,计数值的范围为0999。二进制格式的计数值只占用计数器字的09位。下面是图3-44中左边的电路对应的语句表: AI0.0 /在I0.0的上升沿CU C10 /加计数器C10的当前值加1BLD 101A I0.2 /在I0.2的上升沿L C#6 /计数器的预置值6被装入累加器的低字S C10 /将预置值装入计数器C10AI0.3 /如果I0.3为1R C10 /复位C10L C10 /将C10的二进制计数当前值装入累加器1T MW0/将累加器1的内容传送到MW0LC C10 /将C10的BCD计数当前值装入累加器1T MW8/将累加器1的内容传送到MW8A C10 /如果C10的当前值非0= Q 5.0 /Q 5.0为1状态设置计数值线圈SC(Set Counter Value)用来设置计数值,在RLO的上升沿预置值被送入指定的计数器。CU的线圈为加计数器线圈。在I0.0的上升沿,如果计数值小于999,计数值加1。复位输入I0.3为1时,计数器被复位,计数值被清0。计数值大于0时计数器位(即输出Q)为1;计数值为0时,计数器位亦为0。在减计数输入信号CD的上升沿,如果计数值大于0,计数值减1。
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 大学资料


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!