0

假设我有 1000 个数组,仅由值 0、1、2、3 组成。我想要做的是删除其他值的海洋中的奇数值,例如。0,0,0,0,0,1,0,0,0,0 --> 0,0,0,0,0,0,0,0,0,0。一个简单的移动平均线并没有真正起作用,因为我总是必须返回值 0,1,2,3,所以在 0,3,0 --> 1 上取平均值,这是错误的。我想出了这个似乎可以完成这项工作的方法,但我想知道是否有一种方法可以更有效、更好地完成这项工作。这是一个 ImageJ 宏。

r = 7; //window length
for(j=r; j<lengthOf(armsPosition)-r;j++){
    count0 = 0; count1 = 0; count2=0;count3 = 0;
    for(m = j - r/2; m <= j + r/2; m++){
        if(armsPosition[m] == 0)
            count0++;
        else if(armsPosition[m] == 1)
            count1++;
        else if(armsPosition[m] == 2)
            count2++;
        else
            count3++;

    }

    if(count0 >= count1 && count0 >= count2 && count0 >= count3)
        armsPositionA[j]=0;
    else if(count1 > count0 && count1 > count2 && count1 > count3)
        armsPositionA[j]=1;
    else if(count2 > count0 && count2 > count1 && count2 > count3)
        armsPositionA[j]=2;
    else 
        armsPositionA[j]=3;
}

谢谢,

4

1 回答 1

0

如果您不限于 ImageJ 的宏语言,而是可以使用任何受支持的脚本语言,您可以使用StatUtils.mode(double[] sample, int begin, int length)Apache commons-math 中的方法。

以下 Groovy 脚本说明了这一点:

import org.apache.commons.math3.stat.StatUtils

a = [1,3,4,21,3,2,21,21,21,21,21,21,4,3,5,2,2,1,1,1,1]

println StatUtils.mode((double[])a, 0, 7)

希望有帮助。

于 2017-05-30T07:39:55.373 回答