# Order Statistic Filter Class

This class implements order-statistic image processing filters.

Controller: **stevehs17**

## Interface

C++

## Class Filt

Order-statistic filters are used for eliminating or reducing noise in images. Like other spatial filters, these filters assign to each pixel in an image a value based on the values of the pixels in the neighborhood or window surrounding (and including) the pixel. What characterizes order-statistic filters is that the replacement value is based on an ordering or ranking, from smallest to largest, of the values of the pixels in the window. The max filter assigns to each pixel the maximum value of the pixels in the window, the min filter the minimum value, the median filter the median value, and the midpoint filter the mean of the minimum and maximum values. The alpha-trimmed mean filter ignores the lowest and highest values of the pixels in the window, and finds the mean of the remaining values; the number of values ignored is determined by the trim value, with the trim/2 lowest and highest values ignored. In the limiting case of trim = 0, the filter becomes an averaging (mean) filter. In the other limiting case of M*N - 1, where M is the length of the window and N is the width of the window, the filter becomes a median filter.(Note that in this implementation the trim/2 value is truncated as an integer.) Different order-statistic filters are suited for removing or reducing different kinds of noise. The median filter removes impulse or salt-and-pepper noise -- that is, small, scattered areas of low- and high-value pixels -- while preserving the edges of objects in the image. The min filter enhances areas of images with low-value pixels and removes salt noise. The max filter enhances areas of images with high-value pixels and removes pepper noise. The mid-point filter reduces noise that takes on a range of values, such as noise with a Gaussian or uniform distribution of values. The alpha-trimmed mean filter is useful where there are different kinds of noise, such as a combination of impulse and Gaussian noise. The actual filtering of the image occurs in filt(). The selfunc parameter is the function that selects the values to be assigned to each pixel in the image by operating on the values of the pixels in the window after the values have been ordered. The particular function passed as an argument to filt() depends on the filter being applied. This is reflected in the naming scheme, with maxval() passed for the max filter, minval() passed for the min filter, and so on. There are various ways to deal with the pixels on the border. In this implementation, the pixels are assigned the value of the nearest interior pixel. This is done in fillborder(). The selection functions (i.e. the *val() functions) are static so they can be passed as arguments to filt() with a much simpler syntax than if they were not static. fcmp() must be static so it can be passed as an argument to the qsort() function.### Authors

*Steve Simon (April 2009)*

##### Source Code

Source code is available when you agree to a GP Licence.

Not a member, then Register with CodeCogs. Already a Member, then Login.

## Class Filt::alpha

#### Filt::alpha

float*Filt::alpha( | float* | out | |

const float* | in | ||

int | nx | ||

int | ny | ||

int | trim | ) |

out output image in input image nx number of columns ny number of rows trim ignore trim/2 lowest and highest values when finding mean of pixel values in filter window

### Returns

- pointer to output image

### Authors

*Steve Simon (April 2009)*

### References

- Gonzalez, R. and Woods, R. "Digital Image Processing," 3rd ed., pp. 156-157 and 325-330.

## Class Filt::max

#### Filt::max

float*Filt::max( | float* | out | |

const float* | in | ||

int | nx | ||

int | ny | ) |

out output image in input image nx number of columns ny number of rows

### Returns

- pointer to output image

### Authors

*Steve Simon (April 2009)*

## Class Filt::median

#### Filt::median

float*Filt::median( | float* | out | |

const float* | in | ||

int | nx | ||

int | ny | ) |

out output image in input image nx number of columns ny number of rows

### Returns

- pointer to output image

### Authors

*Steve Simon (April 2009)*

## Class Filt::midpoint

#### Filt::midpoint

float*Filt::midpoint( | float* | out | |

const float* | in | ||

int | nx | ||

int | ny | ) |

out output image in input image nx number of columns ny number of rows

### Returns

- pointer to output image

### Authors

*Steve Simon (April 2009)*

## Class Filt::min

#### Filt::min

float*Filt::min( | float* | out | |

const float* | in | ||

int | nx | ||

int | ny | ) |

out output image in input image nx number of columns ny number of rows

### Returns

- pointer to output image

### Authors

*Steve Simon (April 2009)*

## Class Filt::alphaval

#### Filt::alphaval

floatFilt::alphaval( | windat* | w | ) |

w Structure containing information about current filtering window.

### Returns

- The mean value of the pixels in the window ignoring the trim/2 lowest and highest.

### Authors

*Steve Simon (April 2009)*

## Class Filt::minval

#### Filt::minval

floatFilt::minval( | windat* | w | ) |

w Information about the current filter window.

### Returns

- The minimum value of the pixels in the window.

### Authors

*Steve Simon (April 2009)*

## Class Filt::maxval

#### Filt::maxval

floatFilt::maxval( | windat* | w | ) |

w Information about the current filter window.

### Returns

- The maximum value of the pixels in the window.

### Authors

*Steve Simon (April 2009)*

## Class Filt::medval

#### Filt::medval

floatFilt::medval( | windat* | w | ) |

w Information about the current filter window.

### Returns

- The median value of the pixels in the window.

### Authors

*Steve Simon (April 2009)*

## Class Filt::midval

#### Filt::midval

floatFilt::midval( | windat* | w | ) |

w Information about the current filter window.

### Returns

- The midpoint of the values of the pixels in the window.

### Authors

*Steve Simon (April 2009)*

## Class Filt::filt

#### Filt::filt

float*Filt::filt( | float* | out | |

const float* | in | ||

int | nx | ||

int | ny | ||

selfunc | pf | ||

int | trim | ) |

out output image in input image nx number of columns ny number or rows pf pointer to a function for selecting a value in the filter window trim specifies which pixel values to ignore (ignore the trim/2 lowest and highest)

### Returns

- output image

### Authors

*Steve Simon (April 2009)*

## Class Filt::fillborder

#### Filt::fillborder

float*Filt::fillborder( | float* | img | |

int | nx | ||

int | ny | ) |

img image to operate on nx number of columns of image ny number of rows of image

### Returns

- image operated on

### Authors

*Steve Simon (April 2009)*

## Class Filt::fcmp

#### Filt::fcmp

intFilt::fcmp( | const void* | p1 | |

const void* | p2 | ) |

p1 first floating point number to compare p2 second floating point number to compare

### Returns

- result of comparison (-1 if p1 < p2, 0 if p1 == p2, 1 otherwise)

### Authors

*Steve Simon (April 2009)*

### References

- Kernighan, B. and Pike, R. "The Practice of Programming." Section 2.3.

Last Modified: 28 Apr 09 @ 00:46 Page Rendered: 2022-03-14 17:35:51