FP_MOVE_INVERT

数据的反转及移动

如果触发器ENTRUE,则此FP指令将按照逻辑反转由s指定的数据或等效常量并将其传输至由d指定的数据区域中。

参数

输入

s (WORD, DWORD)

将被反转的源数据

输出

d (WORD, DWORD)

目标数据

标注

变量sd必须为相同的数据类型。

错误标志

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

示例

POU头

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

	VAR
		bStart: BOOL:=FALSE;
			(*activates the function*)
		wInput_value: DWORD:=16#00001234;
			(*this value will be 
inverted*)
		wOutput_value: DWORD:=0;
			(*result after a 0->1 leading
edge from start:
16#FFFFEDCB*)
	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 := 5 ;
        NETWORK_BODY
B(B_F,FP_MOVE_INVERT!,,17,0,27,4,,?DEN?D@'s'?AENO?Cd);
B(B_CONTACT,,bStart,6,1,8,3,);
B(B_VARIN,,wInput_value,15,2,17,4,);
B(B_VAROUT,,wOutput_value,27,2,29,4,);
L(8,2,17,2);
L(1,2,6,2);
L(1,0,1,5);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST本体

IF (bStart) then
    FP_MOVE_INVERT(s := wInput_value, d => wOutput_value);
END_IF;

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