FP_MOVE_BLOCK

ブロック転送

このFP命令は、実行条件ENTRUEのとき、s1_Starts2_Endで指定したデータエリアのデータブロックを、d_Startによって指定したデータエリアから始まるブロックに転送します。

パラメータ

入力

s1_Start (INT, UINT, WORD, DINT, UDINT, DWORD, REAL, DATE, TOD, DT)

転送元データエリアの先頭アドレス

s2_End (INT, UINT, WORD, DINT, UDINT, DWORD, REAL, DATE, TOD, DT)

転送元データエリアの最終アドレス

出力

d_Start (INT, UINT, WORD, DINT, UDINT, DWORD, REAL, DATE, TOD, DT)

コピー先データエリアの先頭アドレス

解説

  • 以下の条件が適用されます:

    • 入力変数と出力変数は同じデータ型を使用してください。

    • オペランドs1_Starts2_Endが同じメモリエリアにある必要があります。例: DT、WR、FL、LD ...

    • s1_Start£s2_End

  • s1_Starts2_End、およびd_Startが同じデータエリアの場合の動作:

    • s1_Start=d_Start: 命令は実行されません。

エラーフラグ

sys_bIsOperationErrorHold (TRUEになり、TRUEを保持)
  • インデックス修飾時にエリアを超えたとき
  • s1_Start > s2_Endのとき

  • 転送先範囲が指定可能範囲から外れたとき

sys_bIsOperationErrorNonHold (1回のスキャンに対してTRUE)
  • インデックス修飾時にエリアを超えたとき
  • s1_Start > s2_Endのとき

  • 転送先範囲が指定可能範囲から外れたとき

POUヘッダ

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

POUボディ

変数bStartTRUEにセットされると、このファンクションが実行されます。

LDボディ

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

STボディ

If (bStart) then
    FP_MOVE_BLOCK(s1_Start := aiSource_Array[0], s2_End := aiSource_Array[3], d_Start => aiTarget_Array[0]);
End_if;

最終修正日: 2020-02-12このページに関するフィードバックお問い合わせ窓口