FP_COPY

メモリブロックへのデータのコピー

このFP命令は、実行条件ENTRUEのとき、sで指定したデータまたは定数データを、d1_Startd2_Endで指定したメモリブロックにコピーします。

パラメータ

入力

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

コピー元の値

出力

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

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

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

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

解説

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

  • オペランドd1_Startd2_Endは、以下のように指定してください。

    • 同じメモリエリア、例) DT、WR、FL、LD ...

    • d1_Start £ d2_End

エラーフラグ

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

sys_bIsOperationErrorNonHold (1回のスキャンに対してTRUE)
  • d1_Start > d2_Endのとき

POUヘッダ

POUヘッダには、このプログラムで使用するすべての入力変数と出力変数を宣言します。 POUヘッダは全プログラム言語で使用できます。

	VAR
		bStart: BOOL:=FALSE;
			(*activates the function*)
		aiDataField: ARRAY [0..6] OF INT:=[1,3,5,7,9,11,13];
			(*result after a 0->1 leading
edge from start:
[1,3,5,11,11,11,13]*)
	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_F,FP_COPY!,,11,1,18,6,,?DEN?D@'s'?AENO?Cd1_Start?Cd2_End);
B(B_CONTACT,,bStart,3,2,5,4,);
B(B_VARIN,,11,9,3,11,5,);
B(B_VAROUT,,aiDataField[3],18,3,20,5,);
B(B_VAROUT,,aiDataField[5],18,4,20,6,);
L(1,3,3,3);
L(5,3,11,3);
L(1,0,1,6);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

STボディ

IF bStart then
    (* Copy the value 11 to aiDataField[3], *)
    (* aiDataField[4] and aiDataField[5] *)
    FP_COPY(s := 11, d1_Start => aiDataField[3], d2_End => aiDataField[5]);
END_IF;

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