F108_BITR

右移位16位数据范围的多位

此函数将以输出d1d2指定开始和结束的特定数据范围的位向右迁移。数据范围要向右迁移的位数由输入n处分配的值指定。数值可以在0到16之间。由于迁移而清除的位变为0。当输入n = 0时,不发生移位。当输入n = 16时,发生单字迁移,即发生与函数F110_WHSL相同的过程。

参数

输入

n (INT)

要迁移的位数

输出

d1_Start (WORD, INT, UINT)

起始16位区域

d2_End (WORD, INT, UINT)

结束16位区域

标注

  • 建议使用相应的FP7指令,来代替使用此F型指令:

  • 输入d1_Startd2_End处的变量地址必须为相同的地址类型。

  1.  (1) 指定数据范围
  2.  (2) 开始:ON
  3.  (3) n位被移出
  4.  (4) n位

错误标志

sys_bIsOperationErrorHold(变为TRUE并保持为TRUE)

如果输出处的变量地址d1_Start > d2_End或输入处的值为n³ 16。

sys_bIsOperationErrorNonHold(对于一次扫描变为TRUE)

如果输出处的变量地址d1_Start > d2_End或输入处的值为n³ 16。

示例

POU头

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

	VAR
		start: BOOL:=FALSE;
			(*activates the function*)
		data_array: ARRAY [0..2] OF WORD:=[16#1234,16#5678,16#9012];
			(*result after a 0->1 leading edge
from start:
[16#8123,16#0567,16#9012]*)
	END_VAR

在此例中,声明了输入变量number_bits。但是,可以直接在函数的输入触点处写入常量。

POU本体

当变量startFALSE变为TRUE时,执行此函数。

它向右移出4位(对应于十六进制表示中的一个位置)。data_field[2]中由迁移产生的4位用零填充。

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_VARIN,,number_bits,5,2,7,4,);
B(B_VAROUT,,data field[0],16,2,18,4,);
B(B_VAROUT,,data field[2],16,3,18,5,);
B(B_F,F108_BITR,,7,0,16,5,,?DEN?Dn?AENO?Cd1?Cd2);
B(B_CONTACT,,output,3,1,5,3,R);
L(1,0,1,5);
L(1,2,3,2);
L(5,2,7,2);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST本体

IF DF(start) then
    F108_BITR( n:=number_bits,
         d1_Start=> data_field[0],
         d2_End=> data_field[2]);
END_IF;

IL本体

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