块校验字符计算
此FP指令根据s1_Control指定的计算方法计算块校验字符(BCC)。数据由起始地址s2_Start和字节数n_Bytes指定。 The BCC存储在d指定的16位区域中。
输入
计算方法
起始地址
字节数
输出
块校验字符
指定控制代码 s1_Control
0:加法(SYS_BCC_CALCULATION_METHOD_ADD)
1:减法(SYS_BCC_CALCULATION_METHOD_SUB)
2:异或(SYS_BCC_CALCULATION_METHOD_XOR)
16#A:CRC-16 (SYS_BCC_CALCULATION_METHOD_CRC16)
16#0–16#F
0:二进制数据(1个字节)
1:ASCII数据(2个字节)
如果使用索引寄存器指定的区域超出限制。
如果使用索引寄存器指定的区域超出限制。
所有用于编程此函数的输入和输出变量已在POU头中声明。所有编程语言使用相同的POU头。
VAR
bStart: BOOL:=FALSE;
(*activates the function*)
iBCC_Calc_Method: INT:=2;
sASCII_String: STRING[32]:='%01#RCSX0000';
(*specifies the operation:
0: addition
1: subtraction
2:XOR*)
wBCC: WORD:=0;
(*result after a 0->1 leading
edge from start: 10#172*)
END_VAR
当bStart变为TRUE时,将在sASCII_String上执行块校验字符计算。计算方法为异或。(当发送大量数据时,使用此方法)。
异或运算:
bvar_1 |
bvar_2 |
bvar_3 |
|
0 |
0 |
0 |
|
0 |
1 |
1 |
|
1 |
0 |
1 |
|
1 |
1 |
0 |
前两个字符的二进制代码相互比较,得出8字符异或运算结果。然后将此结果与下一个字符的二进制代码进行比较,以此类推,直到到达最后一个字符。最后一个异或结果为块校验字符。
使用异或运算的BCC计算:
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 11 ;
NETWORK_BODY
B(B_CONTACT,,bStart,3,2,5,4,);
B(B_VARIN,,iBCC_Calc_Method,24,3,26,5,);
B(B_F,Adr_Of_VarOffs_I!,,16,5,25,9,,?D@'Var'?DOffs?CAdr);
B(B_VAROUT,,wBCC,33,3,35,5,);
B(B_VARIN,,sASCII_String,11,4,13,6,);
B(B_VARIN,,2,14,7,16,9,);
B(B_F,LEN!,,16,8,21,11,,?DIN?C);
B(B_F,FP_BCC!,,26,1,33,7,,?DEN?Ds1_Control?Ds2_Start?Dn_Bytes?AENO?Cd);
L(16,5,16,7);
L(13,5,16,5);
L(13,5,13,10);
L(13,10,16,10);
L(25,5,25,7);
L(25,5,26,5);
L(26,6,26,10);
L(21,10,26,10);
L(5,3,26,3);
L(1,3,3,3);
L(1,0,1,11);
END_NETWORK_BODY
END_NET_WORK
END_BODY
在此例中,Adr_Of_VarOffs_I用于创建2个字的偏移量,以补偿字符串的起始符。通过使用LEN,在整个数据字符串上执行BCC计算。
IF bStart then
FP_BCC(s1_Control := iBCC_Calc_Method,
s2_Start := Adr_Of_VarOffs( Var:= sASCII_String, Offs:= 2),
n_Bytes := LEN( sASCII_String),
d => wBCC);
END_IF;