F353_FSORT

实数数据表(浮点数据表)数据排序

此函数将数据表中的值(带+/-号)以升序或降序排列。

参数

输入

s1_Start (REAL)

要存储的数据表的开始区域

s2_End (REAL)

要存储的数据表的结束区域

s3_Descending (INT)

指定排序顺序:

  • 0 = 升序

  • 1 = 降序

标注

  • 建议使用相应的FP7指令,来代替使用此F型指令:FP_DATA_SORT

  • 输入s1_Start可指定数据表的开始区域,s2_End可指定结束区域。可在s3_Descending确定排序顺序。

  • s3_Descending,可输入以下值:

    0

    升序,即以最小值开始

    1

    降序,即以最大值开始

  • 数据按照在输入s1中输入的值所指定的顺序,通过冒泡排序进行排列。由于字数比较与字数的平方成比例增加,所以当存在大量字时,排序过程可能需要一些时间。当输入处的值s1_Start=s2_End时,不进行排序。

错误标志

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
		CalculateY: BOOL:=FALSE;
		xValue: REAL:=4.0;
		yValue: REAL:=0.0;
		xyValues: XY_DUT;
	END_VAR
	VAR
		CalculateY: BOOL:=FALSE;
		xValue: REAL:=4.0;
		yValue: REAL:=0.0;
		xyValues: XY_DUT;
	END_VAR

在此例中,声明了输入变量sort_order。但是,可以直接在本体中函数的输入触点处写入常量(例如,1表示降序排序)。

POU本体

变量sort_order指定为数值1。

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

可按降序对数组data_field的元素进行排序。

LD本体

BODY
    WORKSPACE
        NETWORK_LIST_TYPE := NWTYPELD ;
        ACTIVE_NETWORK := 0 ;
    END_WORKSPACE
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 3 ;
        NETWORK_BODY
B(B_VAROUT,,sort_order,9,0,11,2,);
B(B_VARIN,,1,7,0,9,2,);
L(1,0,1,3);
        END_NETWORK_BODY
    END_NET_WORK
    NET_WORK
        NETWORK_TYPE := NWTYPELD ;
        NETWORK_LABEL :=  ;
        NETWORK_TITLE :=  ;
        NETWORK_HEIGHT := 9 ;
        NETWORK_BODY
B(B_VARIN,,output,8,1,10,3,);
B(B_F,F353_FSORT,,10,0,19,6,,?DEN?D@'s1'?Ds2?Ds3?AENO);
B(B_VARIN,,sort_order,8,4,10,6,);
B(B_VARIN,,data field[0],8,2,10,4,);
B(B_VARIN,,data field[4],8,3,10,5,);
B(B_COMMENT,,sorting order:ø^s3 = 0:ascending~ 1:descending,11,6,26,8,);
L(1,0,1,9);
        END_NETWORK_BODY
    END_NET_WORK
END_BODY

ST本体

sort_order:=1;
IF start then
    F353_FSORT( s1_Start:= data_field[0],
         s2_End:= data_field[4],
         s3_Descending:= sort_order);
END_IF;

IL本体

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