FP_DATA_WRITE_COMPRESS

移入并压缩数据

该FP指令将数据移入到指定数据表的最小地址,并将表中的数据压缩到更高地址。

参数

输入

s (WORD, INT, UINT)

要移入的数据

输出

d1_Start (WORD, INT, UINT)

压缩从s迁移数据的区域的开始地址

d2_End (WORD, INT, UINT)

数据压缩所在区域的结束地址

标注

  • d1_Startd2_End指定的表中的数据如下重新排列:

    • s指定的数据移入到由d1_Start指定的区域(开始地址)。

    • 非零数据按顺序朝指定范围内较高地址的方向迁移(压缩)。

  • 开始区域d1_Start和结束区域d2_End应为相同类型的操作数。

  • d1_Start必须为£d2_End

  • 如果s的内容为“0”,则只执行压缩迁移。

错误标志

sys_bIsOperationErrorHold(变为TRUE并保持为TRUE)
  • 如果使用索引寄存器指定的区域超出限制。

  • 如果输入处的变量地址s1_Start > s2_End

  • 如果s1_Starts2_End属于不同的数据区域。

sys_bIsOperationErrorNonHold(对于一次扫描变为TRUE)
  • 如果使用索引寄存器指定的区域超出限制。

  • 如果输入处的变量地址s1_Start > s2_End

  • 如果s1_Starts2_End属于不同的数据区域。

例如

POU头

所有用于编程此函数的输入和输出变量已在POU头中声明。所有编程语言使用相同的POU头。

	VAR
		bStart: BOOL:=FALSE;
		aiDataField: ARRAY [0..5] OF INT:=[555,444,0,11,0,10];
		iShiftinData: INT:=32;
	END_VAR

POU本体

当变量bStart设置为TRUE时,执行此函数。

LD本体

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 7 ;
        NETWORK_BODY
B(B_F,FP_DATA_WRITE_COMPRESS!,,9,1,23,6,,?DEN?D@'s'?AENO?Cd1_Start?Cd2_End);
B(B_CONTACT,,bStart,5,2,7,4,);
B(B_VARIN,,iShiftinData,7,3,9,5,);
B(B_VAROUT,,aiDataField[0],23,3,25,5,);
B(B_VAROUT,,aiDataField[5],23,4,25,6,);
L(1,3,5,3);
L(7,3,9,3);
L(1,0,1,7);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST本体

If (bStart) then
    FP_DATA_WRITE_COMPRESS(s := iShiftinData, 
                           d1_Start => aiDataField[0], 
                           d2_End => aiDataField[5]);
End_if;

最后更新日期: 此页面上的反馈松下热线