FP_DATA_READ_COMPRESS

データのシフトアウトと圧縮

このFP命令は、指定された範囲から最上位アドレスのデータを読み出し、上位方向に圧縮します。

パラメータ

出力

d1_Start (WORD, INT, UINT)

圧縮するデータの先頭アドレス(最下位)

d2_End (WORD, INT, UINT)

圧縮するデータエリアの終端(最上位)アドレス(d2_Endのデータ)がシフトアウトされます。

d3 (WORD, INT, UINT)

d2_Endからシフトアウトされたデータを受信します。

解説

  • d1_Startd2_Endで指定したテーブル内のデータは、以下のように再配置されます。

    • d2_End(最上位アドレス)の内容が、d3で指定したエリアにシフトアウトされます。

    • 0でないデータのみを、指定範囲の上位アドレス方向に順次シフトします。

  • 先頭エリアd1_Startと終端エリアd2_Endは、同じ種類のオペランドを指定してください。

  • d1_Startは、£d2_Endである必要があります。

エラーフラグ

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

  • 入力変数のアドレスがs1_Start > s2_Endのとき

  • s1_Starts2_Endが別々のデータエリアに存在するとき。

sys_bIsOperationErrorNonHold (1回のスキャンに対して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];
		iShiftoutData: INT:=10;
	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 := 7 ;
        NETWORK_BODY
B(B_F,FP_DATA_READ_COMPRESS!,,10,1,24,7,,?DEN?AENO?Cd1_Start?Cd2_End?Cd3);
B(B_CONTACT,,bStart,5,2,7,4,);
B(B_VAROUT,,aiDataField[0],24,3,26,5,);
B(B_VAROUT,,aiDataField[5],24,4,26,6,);
B(B_VAROUT,,iShiftoutData,24,5,26,7,);
L(1,3,5,3);
L(7,3,10,3);
L(1,0,1,7);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

STボディ

If (bStart) then
    FP_DATA_READ_COMPRESS(d1_Start => aiDataField[0], 
                          d2_End => aiDataField[5], 
                          d3 => iShiftoutData);
End_if;

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