plc的主要数据类型有字节型、整数型、双整数型和实数型,数据的编码类型主要有二进制、十进制、十六进制、bcd码和ascii码等。在编程时,指令对操作数类型有一定的要求,如字节型与字型数据不能直接进行相加运算。为了让指令能对不同类型数据进行处理,要先对数据的类型进行转换。 转换指令是一种转换不同类型数据的指令。转换指令可分为标准转换指令、ascii码转换指令、字符串转换指令和编码与解码指令。
标准转换指令
标准转换指令可分为数字转换指令、四舍五入取整指令和段译码指令。
1.数字转换指令
数字转换指令有字节与整数间的转换指令、整数与双整数间的转换指令、bcd码与整数间的转换指令和双整数转实数指令。 bcd码是一种用4位二进制数组合来表示十进制数的编码。bcd码的0000~1001分别对应十进制数的0~9。一位十进制数的二进制编码和bcd码是相同的,例如6的二进制编码为0110,bcd码也为0110;但多位十进制数两种编码是不同的,例如64的8位二进制编码为0100 0000,bcd码则为0110 0100。由于bcd码采用4位二进制数来表示1位十进制数,故16位bcd码能表示十进制数的范围是0000~9999。
1)指令说明
数字转换指令说明如表6-29所示。
表6-29 数字转换指令说明
2)指令使用举例
数字转换指令的使用如图6-14所示,当i0.0触点闭合时,执行i_di指令,将c10中的整数转换成双整数,然后存入ac1中。当i0.1触点闭合时,执行bcd_i指令,将ac0中的bcd码转换成整数。例如,指令执行前ac0中的bcd码为0000 0001 0010 0110(即126),执行bcd_i指令后,ac0中的bcd码被转换成整数0000000001111110。
图6-14 数字转换指令的使用
2.四舍五入取整指令
1)指令说明
四舍五入取整指令说明如表6-30所示。
表6-30 四舍五入取整指令说明
2)指令使用举例
四舍五入取整指令的使用如图6-15所示,当i0.0触点闭合时,执行round指令,将vd8中的实数采用四舍五入取整的方式转换成双整数,然后存入vd12中。
图6-15 四舍五入取整指令的使用
3.段译码指令
段译码指令的功能是将in端指定单元中的低4位数转换成能驱动七段数码显示器显示相应字符的七段码。
1)七段数码显示器与七段码
七段数码显示器是一种采用七段发光体来显示十进制数0~9的显示装置,其结构和外形如图6-16所示。当某段加有高电平“1”时,该段发光。例如,要显示十进制数“5”,可让gfedcba=1101101,这里的1101101为七段码,七段码只有七位,通常在最高位补0组成8位(一个字节)。段译码指令in端指定单元中的低4位实际上是十进制数的二进制编码值,经指令转换后变成七段码存入out端指定的单元中。十进制数、二进制数、七段码及显示字符的对应关系见表6-31。
图6-16 七段数码显示器
表6-31 十进制数、二进制数、七段码及显示字符的对应关系
2)指令说明
段译码指令说明如表6-32所示。
表6-32 段译码指令说明
3)指令使用举例
图6-17 段译码指令的使用
段译码指令的使用如图6-17所示,当i0.0触点闭合时,执行seg指令,将vb40中的低4位数转换成七段码,然后存入ac0中。例如,vb40中的数据为00000110,执行seg指令后,低4位0110转换成七段码01111101,存入ac0中。
ascii码转换指令
ascii码转换指令包括整数、双整数、实数转ascii码指令和十六进制数与ascii码转换指令。
1.关于ascii码知识 ascii码意为美国标准信息交换码,是一种使用7位或8位二进制数编码的方案,最多可以对256个字符(包括字母、数字、标点符号、控制字符及其他符号)进行编码。ascii编码表见表6-33。计算机等很多数字设备的字符采用ascii编码方式,例如,当按下键盘上的“8”键时,键盘盘内的编码电路就将该键编码成011 1000,再送入计算机处理。如果在7位ascii码最高位加0就是8位ascii码。
表6-33 ascii编码表
2.整数转ascii码指令
1)指令说明
整数转ascii码指令说明如表6-34所示。
表6-34 整数转ascii码指令说明
在ita指令中,in端为整数型操作数,fmt端指定字节单元中的数据用来定义ascii码字符串在out存储区的存放格式,out存储区是指out端指定首地址的8个连续字节单元,又称输出存储区。fmt端单元中的数据定义如下。
2)指令使用举例
整数转ascii码指令的使用如图6-18所示,当i0.0触点闭合时,执行ita指令,将in端vw10中的整数转换成ascii码字符串,保存在out端指定首地址的8个连续单元(vb12~vb19)构成的存储区中,ascii码字符串在存储区的存放形式由fmt端vb0单元中的数据低4位规定。
图6-18 整数转ascii码指令的使用
例如,vw10中整数为12,vb0中的数据为3(即00000011),执行ita指令后,vb12~vb19单元中存储的ascii码字符串为“0.012”,各单元具体存储的ascii码见表6-35,其中vb19单元存储“2”的ascii码“00110010”。
输出存储区的ascii码字符串格式有以下规律:
①正数值写入输出存储区时没有符号位。
②负数值写入输出存储区时以负号(-)开头。
③除小数点左侧最靠近的0外,其他左侧0去掉。
④输出存储区中的数值是右对齐的。
表6-35 fmt单元取不同值时存储区中ascii码的存储形式
3.双整数转ascii码指令
1)指令说明
双整数转ascii码指令说明如表6-36所示。
表6-36 双整数转ascii码指令说明
在dta指令中,in端为双整数型操作数,fmt端字节单元中的数据用来指定ascii码字符串在out存储区的存放格式,out存储区是指out端指定首地址的12个连续字节单元。fmt端单元中的数据定义与整数转ascii码指令相同。
2)指令使用举例
双整数转ascii码指令的使用如图6-19所示,当i0.0触点闭合时,执行dta指令,将in端vd10中的双整数转换成ascii码字符串,保存在out端指定首地址的8个连续单元(vb14~vb21)构成的存储区中,ascii码字符串在存储区的存放形式由vb0单元(fmt端指定)中的低4位数据规定。
图6-19 双整数转ascii码指令的使用
例如,vd10中双整数为3456789,vb0中的数据为3(即00000011),执行dta指令后,vb14~vb21中存储的ascii码字符串为“3456.789”。
输出存储区的ascii码字符串格式有以下规律。
①正数值写入输出存储区时没有符号位。
②负数值写入输出存储区时以负号(-)开头。
③除小数点左侧最靠近的0外,其他左侧0去掉。
④输出存储区中的数值是右对齐的。
4.实数转ascii码指令
1)指令说明
实数转ascii码指令说明如表6-37所示。
表6-37 实数转ascii码指令说明
在rta指令中,in端为实数型操作数,fmt端指定单元中的数据用来定义out存储区的长度和ascii码字符串在out存储区的存放形式。fmt端单元中的数据定义如下。
2)指令使用举例
实数转ascii码指令的使用如图6-20所示,当i0.0触点闭合时,执行rta指令,将in端vd10中的实数转换成ascii码字符串,保存在out端指定首地址的存储区中,存储区的长度由fmt端vb0单元中的数据高4位规定,ascii码字符串在存储区的存放形式由fmt端vb0单元中的低4位数据规定。
图6-20 实数转ascii码指令的使用
例如,vd10中实数为1234.5,vb0中的数据为97(即01100001),执行rta指指令后,vb14~vb19中存储的ascii码字符串为“1234.5”。fmt单元取不同值时存储区中ascii码的存储格式见表6-38。
表6-38 fmt单元取不同值时存储区中ascii码的存储格式
输出存储区的ascii码字符串格式有以下规律。正数值写入输出存储区时没有符号位。负数值写入输出存储区时以负号(-)开头。除小数点左侧最靠近的0外,其他左侧0去掉。若小数点右侧数据超过规定位数,会按四舍五入去掉低位以满足位数要求。输出存储区的大小应至少比小数点右侧的数字位数多3字节。输出存储区中的数值是右对齐的。
5.ascii码转十六进制数指令
1)指令说明
ascii码转十六进制数指令说明如表6-39所示。
表6-39 ascii码转十六进制数指令说明
2)指令使用举例
ascii码转十六进制数指令的使用如图6-21所示,当i1.0触点闭合时,执行ath指令,将in端vb30为首地址的连续3个(len端指定)字节单元(vb30~vb32)中的ascii码字符串转换成十六进制数,保存在out端vb40为首地址的连续字节单元中。
图6-21 ascii码转十六进制数指令的使用
例如,vb30、vb31、vb32单元中的ascii码字符分别是3(00110011)、e(01000101)、a(01000001),执行ath指令后,vb30~vb32中的ascii码转换成十六进制数,并存入vb40、vb41单元,其中vb40存放十六进制数3e(即00111110),vb41存放ax(即1010xxxx),x表示vb41原先的数值不变。
6.十六进制数转ascii码指令
1)指令说明
十六进制数转ascii码指令说明如表6-40所示。
表6-40 十六进制数转ascii码指令说明
2)指令使用举例
十六进制数转ascii码指令的使用如图6-22所示,当i1.0触点闭合时,执行hta指令,将in端vb30为首地址的连续2个(len端指定)字节单元(vb30、vb31)中的十六进制数转换成ascii码字符,保存在out端vb40为首地址的连续字节单元中。
例如,vb30、vb31单元中的十六进制数分别是3e(0011 1110)、1a(00011010),执行hta指令后,vb30、vb31中的十六进制数转换成ascii码,并存入vb40~vb43单元中,其中vb40存放3的ascii码(00110011),vb41存放e的ascii码,vb42存放1的ascii码,vb43存放a的ascii码。
在ath、hta指令中,有效的ascii码字符为0~9、a~f,用二进制数表示为00110011~00111001、01000001~01000110,用十六进制数表示为33~39、41~46。另外,ath、hta指令可转换的ascii码和十六进制数的最大个数为255个。
图6-22 十六进制数转ascii码指令的使用
字符串转换指令
字符串转换指令包括整数、双整数、实数转字符串指令和字符串转整数、双整数、实数指令。
1. 整数、双整数、实数转字符串指令
1)指令说明
整数、双整数、实数转字符串指令说明如表6-41所示。
表6-41 整数、双整数、实数转字符串指令说明
整数、双整数、实数转字符串指令中fmt的定义与整数、双整数、实数转ascii码指令基本相同,两者的区别在于:字符串转换指令中out端指定的首地址单元用来存放字符串的长度,其后单元才存入转换后的字符串。对于整数、双整数转字符串指令,out首地址单元的字符串长度值分别固定为8、12;对于实数转字符串指令,out首地址单元的字符串长度值由fmt的高4位来决定。
2)指令使用举例
图6-23为实数转字符串指令的使用,当i0.0触点闭合时,执行r_s指令,将in端vd10中的实数转换成ascii码字符串,保存在out端指定首地址的存储区中,存储区的长度由fmt端vb0单元中的数据高4位规定,ascii码字符串在存储区的存放形式由fmt端vb0单元中的低4位数据规定。
图6-23 实数转字符串指令的使用
例如,vd10中实数为1234.5,vb0中的数据为97(即01100001),执行r_s指令后,vb14~vb20中存储的ascii码字符串为“61234.5”。fmt单元取不同值时存储区中ascii码字符串的存储形式见表6-42。
表6-42 fmt单元取不同值时存储区中ascii码字符串的存储形式
整数、双整数、实数转字符串指令中的输出存储区存放ascii码字符串格式与整数、双整数、实数转ascii码指令基本相同,主要区别在于前者的输出存储区首地址单元存放字符串长度,其后才存入字符串。
2. 字符串转整数、双整数、实数指令
1)指令说明
字符串转整数、双整数、实数指令说明如表6-43所示。
在字符串转整数、双整数、实数指令中,indx端用于设置开始转换单元相对首地址的偏移量,通常设置为1,即从首地址单元中的字符串开始转换。indx也可以被设置为其他值,可以用于避开转换非法字符(非0~9的字符)。例如,in端指定首地址为vb10,vb10~vb17单元存储的字符串为“key:1236”,如果将indx设为5,则转换从vb14单元开始,vb10~vb13单元中的字符串“key”不会被转换。
表6-43 字符串转整数、双整数、实数指令说明
字符串转实数指令不能用于转换以科学计数法或者指数形式表示实数的字符串,强行转换时,指令不会产生溢出错误(sm1.1=1),但会转换指数之前的字符串,然后停止转换。例如,转换字符串“1.234e6”时,转换后的实数值为1.234,并且没有错误提示。
指令在转换时,当到达字符串的结尾或者遇到第一个非法字符时,转换指令结束。当转换产生的整数值过大以致输出值无法表示时,溢出标志(sm1.1)会置位。
2)指令使用举例
字符串转整数、双整数、实数指令的使用如图6-24所示,当i0.0触点闭合时,依次执行s_i、s_di、s_r指令。s_i指令将相对vb0偏移量为7的vb6及后续单元中的字符串转换成整数,并保存在vw100单元中;s_di指令将相对vb0偏移量为7的vb7及后续单元中的字符串转换成双整数,并保存在vd200单元中;s_r指令将相对vb0偏移量为7的vb7及后续单元中的字符串转换成实数,并保存在vd300单元中。
图6-24 字符串转整数、双整数、实数指令的使用
如果vb0~vb11单元中存储的ascii码字符串为 “11、t、e、m、p、空格、空格、9、8、.、6、f”,执行s_i、s_di、s_r指令后,则在vw100单元中得到整数98,在vd200单元中得到双整数98,在vd300单元中得到实数98.6。
编码与解码指令
1.指令说明
编码与解码指令说明如表6-44所示。
表6-44 编码与解码指令说明
2.指令使用举例
编码与解码指令的使用如图6-25所示,当i0.0触点闭合时,执行enco和deco指令,在执行enco(编码)指令时,将ac3中最低有效位1的位号“9”写入vb50单元的低4位;在执行deco指令时,根据ac2中低半字节表示的位号“3”将vw40中的第3位置1,其他位全部清0。
图6-25 编码与解码指令的使用
BERT是一种用于自然语言处理的先进神经网络方法
为什么要重视vocs的监测
ccfl冷阴极萤光灯管背光灯和lcd背光灯有区别吗
汽车智能座舱反季节测试
浅谈FeRAM存储器市场情况
一文详解PLC转换指令
强人工智能时代有什么不一样的地方
三相异步电动机结构图及原理说明
RS-232接口实现串口数据传输的点对点通信设计
华为Mate40和苹果iPhone 12,谁更厉害?
多级LC放大器中的单级电路
苹果发布修正版iTunes 12.6:移除无用选项
DapuStor推出Haishen3 E1.S form factor 企业级SSD
拜登上位 科技公司悲喜交加 对中国科技企业态度如何?
旋转编码器的分类简述
荣耀9X系列,29天国内销售突破300万台!感谢信任
比较器的传播延迟规范与测量参数介绍
微雪电子SOT6 SOT-23测试座简介
使用Modulus OV平台和AI构建科学精确的数字孪生
使用英特尔数据分析加速库在Spark 集群上构建应用程序