F354_FSCAL

离散REAL值的线性插补

此函数执行实数数据表的缩放(线性化)并对输入值(X)渲染输出(Y)。

参数

输入

x (REAL)

输入值 X

xy_data(用户自定义DUT)

将用户自定义DUT的第一个元素(即xy值的数量)应用到此输入。请参阅以下DUT结构的描述。

输出

y (REAL)

输出值Y

标注

建议使用相应的FP7指令,来代替使用此F型指令:FP_SCALE 执行离散值的线性插补

有关详细描述,请参阅指令:F282_SCAL 离散INT值的线性插补F283_DSCAL 离散DINT值的线性插补.

错误标志

sys_bIsOperationErrorHold(变为TRUE并保持为TRUE)
  • 如果使用索引寄存器指定的地址超出限制。

  • 如果非实数值被输入'x'。

  • 如果数值数量(DUT的第一个元素)< 2 或 > 99。

  • 如果非实数值被指定为'xy_data'中指定的实数值(xt, yt)。

  • 如果'xy_data'的线性表未以x顺序的升序注册。

  • 如果'xy_data'的线性表超出区域。

  • 如果在缩放操作期间出现溢出(操作不稳定)。

sys_bIsOperationErrorNonHold(对于一次扫描变为TRUE)
  • 如果使用索引寄存器指定的地址超出限制。

  • 如果非实数值被输入'x'。

  • 如果数值数量(DUT的第一个元素)< 2 或 > 99。

  • 如果非实数值被指定为'xy_data'中指定的实数值(xt, yt)。

  • 如果'xy_data'的线性表未以x顺序的升序注册。

  • 如果'xy_data'的线性表超出区域。

  • 如果在缩放操作期间出现溢出(操作不稳定)。

示例

DUT

在DUT池中创建数据单元型。

POU头

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

所有编程语言使用相同的POU头。

VAR
		CalculateY: BOOL:=FALSE;
		X_value: REAL:=4.0;
		Y_value: REAL:=0.0;
		XY_values: XY_DUT;
		@'': @'';
	END_VAR
	VAR_EXTERNAL
		ProcessData: ProcessDataStructure;
	END_VAR
	VAR
		@'': @'';
	END_VAR

POU本体

当变量CalculateY设置为TRUE时,执行此函数。

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,,CalculateY,10,1,12,3,);
B(B_VARIN,,X_value,10,2,12,4,);
B(B_VARIN,,XY_values.Number,10,3,12,5,);
B(B_VAROUT,,Y_value,19,2,21,4,);
B(B_F,F354_FSCAL!,Instance,12,0,19,5,);
L(1,0,1,5);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST本体

IF start then
    F354_FSCAL(x := X_value, xy_data := XY_values.Number, y => Y_value);
END_IF;
相关主题

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