[OpenCV+VS2015]中值滤波、快速中值滤波和OpenCV中API中值滤波
上课老师没有详细讲,自己查阅了一下然后做了点程序验证一下
中值滤波
简单来说就是用一个nn的框框(n为奇数)去框一个图像,框选中的nn个像素点中取中值,然后用中值取代替框框中间的那个点的像素
哎说起来简单,代码有点烧脑,直接撸上来
void MF(Mat& image_input, Mat& image_output, int diameter)
{
int radius = (diameter - 1) / 2;//向下取整
int i, j, p, q, t,sum = 0,median;
uchar val;
int Hist[256] = {
0 };
int Threshold = (diameter*diameter + 1) / 2;
for (i = 0; i < image_input.rows; i++)
{
for (j = 0; j <radius; j++)
{
image_output.at<uchar>(i, j) = image_input.at<uchar>(i, j);
image_output.at<uchar>(i, (image_input.cols - j - 1)) = image_input.at<uchar>(i, (image_input.cols - j - 1));
}
}
for (j = 0; j < image_input.cols; j++)
{
for (i = 0; i < radius; i++)
{
image_output.at<uchar>(i, j) = image_input.at<uchar>(i, j);
image_output.at<uchar>((image_input.rows - i -