FP_BITCOLUMN_TO_WORD

ビット列 -> ビット行変換

このFP命令は、入力s_Startを先頭とするアドレス範囲からのビット列を変換し、各ビットはビット行で出力dに格納されます。ビット位置は、入力n_Posで指定されます(範囲0~15)。この命令は、FP_WORD_TO_BITCOLUMN命令を逆にしたものです。

パラメータ

入力

s_Start (WORD)

ビット列の先頭アドレス

n_Pos (WORD, INT, UINT)

ビット位置(範囲0~15)

出力

d (WORD)

結果:

エラーフラグ

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

  • 0 ³ n_Pos > 15

  • s_Startが範囲外であるとき

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

  • 0 ³ n_Pos > 15

  • s_Startが範囲外であるとき

POUヘッダ

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

	VAR
		bStart: BOOL:=FALSE;
			(*activates the function*)
		iPosition: INT:=10;
			(*specifies the position
of the column*)
		wBit_combination: WORD:=16#0;
			(*result after a 0->1 leading
edge from start:
2#1100011110111000*)
	END_VAR

POUボディ

変数bStartTRUEにセットされると、このファンクションが実行されます。DT10を先頭とするデータのビット位置10のビット列が、出力dにおいて0101 0001 1101 1001として出力されます。

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_BITCOLUMN_TO_WORD!,,13,1,26,6,,?DEN?Ds_Start?Dn_Pos?AENO?Cd);
B(B_CONTACT,,bStart,6,2,8,4,);
B(B_VARIN,,DT10,11,3,13,5,);
B(B_VARIN,,iPosition,11,4,13,6,);
B(B_VAROUT,,wBit_combination,26,3,28,5,);
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_BITCOLUMN_TO_WORD(s_Start := DT10, n_Pos := iPosition, d => wBit_combination);
END_IF;

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