移动数据块
如果触发器EN为TRUE,此FP指令会将数据块从s1_Start和s2_End指定的数据区域移至从d_Start指定的数据区域开始的块中。
输入
源数据区域的起始地址
源数据区域的结束地址
输出
目标数据区域的起始地址
须满足以下条件:
输入和输出变量必须为相同的数据类型。
操作数s1_Start和s2_End必须在相同的内存区,例如DT、WR、FL、LD...
s1_Start£s2_End
每当s1_Start、s2_End和d_Start位于相同的数据区域时:
s1_Start=d_Start:将不会执行该指令。
如果s1_Start > s2_End
如果目标范围超出可用范围
如果s1_Start > s2_End
如果目标范围超出可用范围
相应的F型指令:F10_BKMV 冗余的指令
所有用于编程此函数的输入和输出变量已在POU头中声明。 所有编程语言使用相同的POU头。
VAR
bStart: BOOL:=FALSE;
(*activates the function*)
aiSource_Array: ARRAY [0..4] OF INT:=[1,2,3,4,5];
aiTarget_Array: ARRAY [0..2] OF INT:=[3(0)];
(*result after a 0->1 leading edge
from start: [2,3,4]*)
END_VAR
当变量bStart设置为TRUE时,执行此函数。
BODY
WORKSPACE
NETWORK_LIST_TYPE := NWTYPELD ;
ACTIVE_NETWORK := 0 ;
END_WORKSPACE
NET_WORK
NETWORK_TYPE := NWTYPELD ;
NETWORK_LABEL := ;
NETWORK_TITLE := ;
NETWORK_HEIGHT := 6 ;
NETWORK_BODY
B(B_CONTACT,,bStart,6,2,8,4,);
B(B_VARIN,,aiSource_Array[1],11,3,13,5,);
B(B_VARIN,,aiSource_Array[3],11,4,13,6,);
B(B_VAROUT,,aiTarget_Array[0],23,3,25,5,);
B(B_F,FP_MOVE_BLOCK!,,13,1,23,6,,?DEN?Ds1_Start?Ds2_End?AENO?Cd_Start);
L(1,3,6,3);
L(8,3,13,3);
L(1,0,1,6);
END_NETWORK_BODY
END_NET_WORK
END_BODY
If (bStart) then
FP_MOVE_BLOCK(s1_Start := aiSource_Array[0], s2_End := aiSource_Array[3], d_Start => aiTarget_Array[0]);
End_if;