FP_DATA_MEAN_SUM_REAL

在REAL数字数据表中计算总数和平均数

该FP指令可计算由s1_Starts2_End指定的数据表中,正负REAL数的总和与算术均数。数据表中所有元素的总和返回到输出d1_Sum,数据表中所有元素的算术均数返回到输出d2_Mean。算术均数如果不是整数,会进行四舍五入。

参数

输入

s1_Start (ANY_REAL)

数据表的开头

s2_End (ANY_REAL)

数据表的结尾

输出

d1_Sum (ANY_REAL)

指定的数据表区域中所有元素的总和

d2_Mean (ANY_REAL)

指定的数据表区域中所有元素的平均数

错误标志

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

  • 如果s1_Start>s2_End

  • 如果s1_Starts2_End属于不同的数据区域。

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

  • 如果s1_Start>s2_End

  • 如果s1_Starts2_End属于不同的数据区域。

例如

POU头

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

	VAR
		bStart: BOOL:=FALSE;
			(*activates the function*)
		arDataField: ARRAY [0..4] OF REAL:=[2.102,3.33,6.61,2.02,-4.14];
		rSum: REAL:=0;
			(*the sum of all elements of 
data_array; here: 9,922*)
		rMean: REAL:=0;
			(*the arithmetic mean of all
elements of data_array;
here: 1,984*)
	END_VAR

POU本体

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

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_CONTACT,,bStart,6,2,8,4,);
B(B_VARIN,,arDataField[0],9,3,11,5,);
B(B_VARIN,,arDataField[4],9,4,11,6,);
B(B_VAROUT,,rSum,25,3,27,5,);
B(B_VAROUT,,rMean,25,4,27,6,);
B(B_F,FP_DATA_MEAN_SUM_REAL!,,11,1,25,6,,?DEN?Ds1_Start?Ds2_End?AENO?Cd1_Sum?Cd2_Mean);
L(1,3,6,3);
L(8,3,11,3);
L(1,0,1,6);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST本体

IF bStart then
    FP_DATA_MEAN_SUM_REAL(s1_Start := arDataField[0], 
                         s2_End := arDataField[4], 
                         d1_Sum => rSum, 
                         d2_Mean => rMean);
END_IF;

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