离散REAL值的线性插补
此函数执行实数数据表的缩放(线性化)并对输入值(X)渲染输出(Y)。
输入
输入值 X
将用户自定义DUT的第一个元素(即xy值的数量)应用到此输入。请参阅以下DUT结构的描述。
输出
输出值Y
建议使用相应的FP7指令,来代替使用此F型指令:FP_SCALE 执行离散值的线性插补
有关详细描述,请参阅指令:F282_SCAL 离散INT值的线性插补和F283_DSCAL 离散DINT值的线性插补.
如果使用索引寄存器指定的地址超出限制。
如果非实数值被输入'x'。
如果数值数量(DUT的第一个元素)< 2 或 > 99。
如果非实数值被指定为'xy_data'中指定的实数值(xt, yt)。
如果'xy_data'的线性表未以x顺序的升序注册。
如果'xy_data'的线性表超出区域。
如果在缩放操作期间出现溢出(操作不稳定)。
如果使用索引寄存器指定的地址超出限制。
如果非实数值被输入'x'。
如果数值数量(DUT的第一个元素)< 2 或 > 99。
如果非实数值被指定为'xy_data'中指定的实数值(xt, yt)。
如果'xy_data'的线性表未以x顺序的升序注册。
如果'xy_data'的线性表超出区域。
如果在缩放操作期间出现溢出(操作不稳定)。
在DUT池中创建数据单元型。
所有用于编程此函数的输入和输出变量已在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
当变量CalculateY设置为TRUE时,执行此函数。
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
IF start then
F354_FSCAL(x := X_value, xy_data := XY_values.Number, y => Y_value);
END_IF;