The present invention relates to a device for determining the rank of a particular one of a given set of digital samples. The invention also relates to an apparatus for determining the rank of each one of the samples in the set, and to a median filter for filtering the set of samples that incorporates such an apparatus. Self-threshold decomposition is utilized so that the median filter can be realized in a feasible manner.
Linear filters have been widely used in many industrial applications due to their simple mathematical operation and simple H/W (hardware) structures. In order to overcome some drawbacks of linear filters that arise in many areas, much attention has been directed towards developing nonlinear digital filters that utilize rank- and order-statistics. It is well known that linear filters perform poorly in the presence of outliers. For example, when an image is degraded by an impulsive noise, or a noise with a heavy-tailed distribution, applying a Wiener filter, which is the optimal linear filter under the mean squared estimation error (MSE) criterion, tends to blur the image since it smears out an important visual cue such as an edge of the image while it suppresses the impulsive noise.
To deal with this poor performance of a linear filter in the presence of outliers, filters that are based on rank- and order-statistics and that have theoretical backgrounds based in statistics have been studied for the last decades. Median filtering is the simplest and probably the most well-known example of rank-order filtering, which can suppress the outliers effectively while preserving image detail.
As a second example, equalizers are indispensable in digital TV receiving systems to reduce the degradation of a system due to multi-path transmission or inter-symbol interference. However, an equalizer that is based on a combination of linear-type filters loses its performance when an impulsive noise is present in a channel. Error correction coding schemes are typically used to recover a symbol error or an alphabet error. This method, however, is limited in its use simply because of the H/W growth of the error correction system with respect to the number of symbols, or the number of alphabets that can be corrected. An impulsive type noise can be easily dealt with if we use a filter that is based on rank- and order-statistics and this has been verified in much literature on the topic. Thus, the combination of an impulse remover and an equalizer will increase the performance of a digital communication system remarkably in terms of the bit error rate or symbol error rate.
In spite of the successful development of a class of filters that is based on rank- and order-statistics in theory, they have rarely been used in real industrial applications because of the high complexity of the associated H/W. In order to realize those filters, sorting and ranking of the input samples are fundamental.
It is accordingly an object of the invention to provide a device for determining the rank of a particular one of a given set of digital sample values. It is also an object of the invention to provide an apparatus that incorporates a plurality of such rank-determining devices so that the ranks of each one of the sample values in the set can be determined. Additionally, it is an object of the invention to provide the ith rank ordered filter for filtering the set of sample values. The ith rank ordered filter incorporates the rank-determining apparatus.
The rank-determining device determines the rank of a particular one of the sample values by utilizing two different thresholders that are implemented by comparators. The rank of the sample is decomposed by thresholding the sample value with all of the sample values in the set of digital sample values, and in this manner eliminates the necessity of a sorting operation. This decomposition of the rank will be described in more detail below and will be referred to as self-threshold decomposition. A plurality of these rank-determining devices can be combined to form a rank determining apparatus in order to find the rank of each one of the digital samples in the set of digital samples. Because the rank-determining apparatus implements self-threshold decomposition, rank- and order-statistic based filters, such as the median filter, can be realized in a feasible manner.
With the foregoing and other objects in view there is provided, in accordance with the invention, a device for determining the rank of one of a plurality of sample values. The rank-determining device includes an adder having an output providing a result that indicates the rank of a particular one of the plurality of the sample values. The rank-determining device includes at least one comparator of a first type having a first input and a second input. The second input receives the particular one of the plurality of the sample values. The first input receives another one of the plurality of the sample values. The comparator of the first type has an output that provides an output signal representing a logic one if the other one of the plurality of the sample values is not greater than the particular one of the plurality of the sample values. The output signal represents a logic zero otherwise. The rank-determining device also includes at least one comparator of a second type. The comparator of the second type has a first input and a second input. The second input of the comparator of the second type receives the particular one of the plurality of the sample values. The first input of the comparator of the second type receives yet another one of the plurality of the sample values. The comparator of the second type has an output that provides an output signal representing a logic one if the yet another one of the plurality of the sample values is less than the particular one of the plurality of the sample values. The output signal that is provided by the output of the comparator of the second type represents a logic zero otherwise. The adder adds together a logic one, the output signal from the output of the comparator of the first type, and the output signal from the output of the comparator of the second type to obtain the result that indicates the rank of the particular one of the plurality of the sample values. The output of the adder provides the result.
In accordance with an added feature of the invention, there is provided, a further comparator of the first type that has a first input and a second input. The second input of the further comparator receives the particular one of the plurality of the sample values. The first input of the further comparator receives a further one of the plurality of the sample values. The further comparator has an output providing an output signal representing a logic one if the further one of the plurality of the sample values is not greater than the particular one of the plurality of the sample values. The output signal of the further comparator represents a logic zero otherwise. The adder adds the output signal from the output of the further comparator to the result that indicates the rank of the particular one of the plurality of the sample values.
In accordance with an additional feature of the invention, there is provided, a further comparator of the second type that has a first input and a second input. The second input of the further comparator receives the particular one of the plurality of the sample values. The first input of the further comparator receives a further one of the plurality of the sample values. The further comparator has an output that provides an output signal representing a logic one if the further one of the plurality of the sample values is less than the particular one of the plurality of the sample values. The output signal of the further comparator represents a logic zero otherwise. The adder adds the output signal from the output of the further comparator to the result that indicates the rank of the particular one of the plurality of the sample values.
In accordance with another feature of the invention, the rank-determining device is configured in combination with a plurality of analog to digital converters that are configured to sample a plurality of signals at a particular instant of time to obtain the plurality of the sample values.
In accordance with a further feature of the invention, the rank-determining device is configured in combination with a memory that has stored the plurality of the sample values.
The structure of the rank-determining device will depend upon the total number of sample values (n sample values) and upon the particular one of the sample values for which the rank is to be determined. The rank-determining device receives n sample values and determines the rank of the ith one of the n sample values.
The rank-determining device, therefore, includes an adder having an output providing a result indicating the rank of the ith one of the n sample values. The rank-determining device also includes a number of comparators of a first type. Each one of the comparators of the first type has a first input that receives a respective sample value that is selected from the group consisting of sample values beginning with a first one of the n sample values and ending with the i−1th one of the n sample values. Each one of the comparators of the first type has a second input that receives the ith one of the n sample values. Each one of the comparators of the first type has an output that provids an output signal representing a logic one if the respective sample value at the first input is not greater than the ith one of the n sample values and representing a logic zero otherwise.
The rank-determining device also includes a number of comparators of a second type. Each one of the comparators of the second type has a first input that receives a respective sample value that is selected from the group consisting of sample values beginning with the i+1th one of the n sample values and ending with the nth one of the n sample values. Each one of the comparators of the second type has a second input receiving the ith one of the n sample values. Each one of the comparators of the second type has an output providing an output signal representing a logic one if the respective sample value at the first input is less than the ith one of the n sample values and representing a logic zero otherwise.
The adder adds together a logic one, the output signal from the output of each one of the comparators of the first type, and the output signal from the output of each one of the comparators of the second type to obtain the result that indicates the rank of the ith one of the n sample values. The output of the adder provides the result that indicates the rank of the ith one of the n sample values.
The number of the comparators of the first type is equal to i−1 and will equal zero when the ith one of the n sample values is the first one of the n sample values. The number of the comparators of the second type is equal to n−i and will equal zero when the ith one of the n sample values is the nth one of the n sample values.
With the foregoing and other objects in view there is also provided, in accordance with the invention, an apparatus for receiving n sample values and for determining the rank of each one of the n sample values. The rank-determining apparatus includes a plurality of rank-determining devices. Each one of the plurality of the rank-determining devices utilizes self-threshold decomposition to determine the rank of a respective one of the n sample values.
With the foregoing and other objects in view there is also provided, in accordance with the invention, the ith rank ordered filter that includes a rank-determining device utilizing self-threshold decomposition to find the ranks of a plurality of sample values. The ith rank ordered filter also includes a weighting device having an input for receiving an integer value. The weighting device has inputs that are connected to the rank-determining device for receiving the ranks of the plurality of the sample values. The weighting device has inputs for receiving the plurality of the sample values. The weighting device also has an output providing a value that is equal to one of the plurality of the sample values which has a rank that is equal to the integer value.
In accordance with a concomitant feature of the invention, the weighting device weights only one of the ranks of the plurality of the sample values with a non-zero integer value so that the one of the plurality of the sample values which has a rank equal to the integer value will be provided at the output.
The invention is based upon developing a method for computing the rank of a particular digital sample by using a combination of two different thresholders such that a sorting operation is not necessary. This method is then taken into account when constructing a device for determining the rank of the sample. As a prelude to developing the method, information relating to the ranking process will now be described.
Sorting and ranking processes are intended to sort and rank given input samples according to their values. The present disclosure relates to a ranking process which ranks given input samples in ascending order of their sample values. As an example of the sorting and ranking processes, let us consider that three samples {5, −6, 2} have been obtained which are to be sorted and ranked. If we rearrange the samples in ascending order, we obtain {−6, 2, 5}. Based on this sorted data, the samples 5, −6, and 2 are ranked as 3, 1, and 2, respectively, which implies that 5 is the largest sample, −6 is the smallest sample, and 2 is the second smallest sample among {5, −6, 2}. Thus, the sorting implies an operation which rearranges {5, −6, 2} as {−6, 2, 5} whereas the ranking implies an operation which ranks {5, −6, 2} as {3, 1, 2} based on their sample values.
To describe the ranking process mathematically, let (X1(k), X2(k), . . . , Xn(k)) denote the given input samples at the kth time interval, and let (Y1(k), Y2(k), . . . , Yn(k)), denote the sorted version of those input samples in ascending order. Based on this notation, the sorting process can be expressed as the mapping:
where the sorted samples satisfy:
Y1(k)≦Y2(k)≦ . . . ≦Yn(k) (2)
in which Yi(k), for i=1, 2, . . . , n, is the ith smallest sample of (X1(k), X2(k), . . . , Xn(k)). Yi(k) is typically known as the ith order statistic. Based on the sorting described in (1), the rank of Xi(k), denoted by ri, is defined as:
ri(k)=j, if Xi(k)=Yj(k) (3).
As can be seen from (2), the rank ri(k) basically indicates the number of samples in (X1(k), X2(k), . . . , Xn(k)) that are smaller than or equal to Xi(k).
It should be noted here that, however, that there are some cases in which the determination of the rank of a sample defined by (2) and (3) is ambiguous. In other words, when some samples in (X1(k), X2(k), . . . , Xn(k)) are tied, or, equally valued, the way of assigning rank to each sample is not unique. For instance, consider that two samples Xa(k) and Xb(k) in (X1(k), X2(k), . . . , Xn(k)) are valued equally, i.e., Xa(k)=Xb(k) where a≠b. According to the sorting that is defined in (1) and (2), we can sort these samples either as Xa(k)≦Xb(k), or as Xb(k)≦Xa(k), and the subsequent ranks of those samples are different. In the case of sorting them as Xa(k)≦Xb(k), the rank of Xb(k) is greater than the rank of Xa(k) by one, by definition. On the contrary, the rank of Xa(k) is greater than the rank of Xb(k) by one if we sort them as Xb(k)≦Xa(k). As a consequence, it is not unique to determine the ranks of those samples in this example. This kind of ambiguity increases as the number of equal valued samples in (X1(k), X2(k), . . . , Xn(k)) increases. The reason for such an ambiguity is due to the fact that the ordering of two equal valued samples is not uniquely defined in (2).
Such an ambiguity can be avoided by introducing a method called stable sorting in which the sequential ordering of equal-valued samples is also preserved when the samples are arranged in accordance with (1) and (2). That is, the samples that are equally valued can be sorted in a unique fashion by further considering their order of appearance in (X1(k), X2(k), . . . , Xn(k)). In order to formulate the ranking process based on the stable sorting systematically, we define the ordering relation “<<” between two samples Xj(k) and Xi(k) as:
(Xj(k)<<Xi(k))(Xj(k)<Xi(k), or, j≦i if Xj(k)=Xi(k)) (4)
which is equivalent to:
or, equivalent to:
Note that Xj(k)<<Xj(k) by definition.
Using the ordering relation that is defined in (4), (5), or in (6), the stable sorting operation can be expressed as the mapping:
where the sorted samples now satisfy:
Y1(k)<<Y2(k)<< . . . <<Yn(k) (8)
Note that the arrangement of the samples X1(k), X2(k), . . . , Xn(k) according to the stable sorting in (8) is unique.
Based on the stable sorting defined above, the rank of Xi(k), ri(k), is now re-defined as:
ri(k)=j, if Xi(k)=Yj(k) (9).
Hence, in stable sorting, when Xa(k)=Xb(k), Xb(k) is ranked higher than Xa(k) if a<b, and Xa(k) is ranked higher than Xa(k) if b<a.
For a better understanding of stable sorting, let us consider the example addressed above again. That is, suppose we have (X1, X2, X3, X4, X5)=(5, 32, 7, 4, 35) where 32 denotes the sample valued 3 at the second position and 35 denotes the sample valued 3 at the fifth position. If we do stable sorting for those samples based on (8), we obtain (Y1, Y2, Y3, Y4, Y5)=(X2, X5, X4, X1, X3)=(32, 35, 4, 5, 7) since 32<<35<<4<<5<<7. Thus, the ranks of X1, X2, X3, X4, X5 are given as 4, 1, 5, 3, 2, respectively.
It should be noted that the rank ri(k) defined in (9) substantially represents the number of samples Xj(k)ε{X1(k), X2(k), . . . , Xn(k)} that satisfy Xj(k)<<Xi(k). In order to express such a rank of Xi(k), we define the function ƒ(a, b), which compares b with a based on the ordering relation “<<”, as:
Then the rank ri(k) can be simply expressed as
The sample Xi(k) by Xj(k)<<Xi(k) is as stated above. By using the relation given in (6) the term in (11) becomes:
Thus, ri(k) can be written as:
where ƒu(Xj(k), Xi(k)) and ƒ1(Xj(k), Xi(k)) are defined as:
If we use the fact that ƒu(Xi(k), Xi(k))=1 by definition, the rank ri(k) that was derived in (15) can be expressed as:
The expression we have derived in (18) when combined with (16) and (17) indicates a method of computing the rank of a sample, which is among a number of given data samples n, through a combination of two different thresholders without utilizing a sorting operation. The relation given in (15) indicates that the rank ri(k) can be decomposed by thresholding the sample Xi(k) with all of the samples to be ranked. For this reason, the decomposition of a rank utilizing the thresholding operations in (15) will be referred to as the self-threshold decomposition.
Let us now develop a device for determining the rank of a digital sample Xi(k) that is one of a set or group of n digital samples X1(k) through Xn(k). The n digital samples could be obtained, for example, by sampling a plurality (n) of analog input signals Xi(t) at a given instant of time as shown in
Referring to
As previously mentioned, the actual number of the first type of comparators 18 and the actual number of the second type of comparators 20 will vary depending upon the total number of the n digital samples and upon the particular one Xi(k) of the n digital samples for which the rank ri(k) is to be determined. The number of the first type of comparators 18 is equal to i−1 and equals zero when the ith one of the n digital samples is the first one of the n digital samples. The number of the second type of comparators 20 is equal to n−i and equals zero when the ith one of the n digital samples is the last one of the n digital samples.
For example, let us consider the case when there are are three digital samples and it is desired to find the rank r2(k) of the second digital sample. In this case, there will be one of the first type of comparators 18 and one of the second type of comparators 20. The adder 24 will provide a result, which indicates the rank r2(k) of the second digital sample, by adding together: a logic one, the output from the one of the first type of comparators 18 and the output from the one of the second type of comparators 20.
Let us now consider the case when there are are three digital samples and it is desired to find the rank r3(k) of the third digital sample. In this case, there will be two of the first type of comparators 18 and none of the second type of comparators 20. The adder 24 will provide a result, which indicates the rank r3(k) of the third digital sample, by adding together: a logic one and the outputs from the two comparators 20 of the second type.
Let us also consider the case when there are are three digital samples and it is desired to find the rank r1(k) of the first digital sample. In this case, there will be two of the second type of comparators 20 and none of the first type of comparators 18. The adder 24 will provide a result, which indicates the rank r1(k) of the first digital sample, by adding together: a logic one and the and the outputs from the two comparators 18 of the first type.
It should be understood that the rank-determining device 22 could be provided for each one of n digital samples so that the rank ri(k) of each one of the n digital samples will be obtained.
An apparatus 26 for determining the ranks ri(k) of n digital samples can be used to implement an Order-Statistic. There are several kinds of non-linear filters that are based on Order-Statistic Filters. Such non-linear filters have many applications that are well known. Perhaps the most common kind of Order-Statistic Filter is the median filter whose output is the median of the input digital samples. In fact, the median filter is a special case of the ith rank ordered filter that can be expressed as
Fi(k)=Yi(k):
where i can be 1, 2, and so on up to n.
If i=1, Fi(k) becomes the Min filter, if i=n, Fi(k) becomes the Max filter, and if
Fi(k) becomes the Median filter where we assume that n is an odd number.
The output of adder 38 is expressed as:
Thus, the output of the adder 38 basically tells which one Xi(k) of the n input digital samples has the rank of i. Note that only one element of (ei(k), ee(k), . . . , en(k)) has a value of 1 and the others are all zeros. The location of the nonzero valued element is the location of the input sample whose rank is i. So, it can be shown that:
The ith rank ordered filter 36 includes comparator units 40 that output a logic one when the values at each of its inputs are equal. In this manner, the comparator units 40 are used to implement the function:
One input of each one of the comparator units 40 receives the value i, and the other input receives a respective one of the ranks ri(k) that have been determined by the rank determining apparatus 26. A respective multiplier 42 is used to multiply the output of each comparator unit 40 with the value of the respective one Xi(k) of the n digital samples. The outputs of all of the multipliers 42 are summed by the adder 38 to provide the value of the sample having the desired rank i. The only comparator unit 40 to output a logic one is the one for which the input rank ri(k) equals the input integer i. Therefore, the only sample contributing a non-zero value to the summation that is performed by the adder 38 is the sample having the rank of i.
This application is a Continuation Patent Application under 35 USC §120 of U.S. patent application Ser. No. 10/954,553 filed Sep. 30, 2004, now U.S. Pat. No. 7,072,928 issued Jul. 4, 2006, which in turn claims priority, as does this application from U.S. patent application Ser. No. 10/011,877 filed Dec. 3, 2001, now U.S. Pat. No. 7,072,921 issued Jul. 4, 2006, which in turn, as does this application, claims priority under 35 USC §119(e) from U.S. Provisional Patent Application Ser. No. 60/257,363 filed Dec. 20, 2000. Applicant claims the benefit of U.S. Provisional Application No. 60/257,363 entitled “Method and Apparatus For Data Ranking Based on Threshold Decomposition,” filed Dec. 20, 2000, which application is incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
3927391 | Cantrell | Dec 1975 | A |
4441165 | Coleman et al. | Apr 1984 | A |
4567572 | Morris et al. | Jan 1986 | A |
4958141 | Engelsman | Sep 1990 | A |
5315171 | Blauer et al. | May 1994 | A |
5408675 | Florentino et al. | Apr 1995 | A |
5532948 | Kohno et al. | Jul 1996 | A |
5737251 | Kohno et al. | Apr 1998 | A |
6208764 | Archer et al. | Mar 2001 | B1 |
6331859 | Crinon | Dec 2001 | B1 |
6446101 | Braun | Sep 2002 | B1 |
Number | Date | Country |
---|---|---|
2 274 366 | Jul 1994 | GB |
06-215129 | Aug 1994 | JP |
2 230 360 | Jun 2004 | RU |
Number | Date | Country | |
---|---|---|---|
20060112156 A1 | May 2006 | US |
Number | Date | Country | |
---|---|---|---|
60257363 | Dec 2000 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 10954553 | Sep 2004 | US |
Child | 11289189 | US | |
Parent | 10011877 | Dec 2001 | US |
Child | 10954553 | US |