[OpenCV+VS2015]中值滤波、快速中值滤波和OpenCV中API中值滤波

[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 - 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值