【c++|opencv】二、灰度变换和空间滤波---3.均值滤波

every blog every motto: You can do more than you think.
https://blog.csdn.net/weixin_39190382?type=blog

0. 前言

均值滤波

1. 均值滤波

cpp 复制代码
#include <iostream>
#include <opencv2/opencv.hpp>
#include"Salt.h"

using namespace cv;
using namespace std;

// 定义盒式滤波器
void myfilter(int filter_size,Mat& img_input,Mat& img_output);

int main(){
    Mat img,img_gray,img_output,img_output2;
    img = imread("/home/v/home.png");

    if (img.empty()){
        cout<<"can not load image"<<endl;
        return -1;
    }

    cvtColor(img,img_gray,COLOR_BGR2GRAY);
    Salt(img_gray,5000);  
    imshow("img_gray",img_gray);

    // 自定义滤波
    int filter_size = 7;
    myfilter(filter_size,img_gray,img_output);

    // opencv 自带滤波
    blur(img_gray,img_output2,Size(filter_size,filter_size));

    imshow("img out 1",img_output);
    imshow("img out 2",img_output2);

    waitKey(0);
    return 0;
}

// 盒式滤波
void myfilter(int filter_size,Mat& img_input,Mat& img_output){
    img_output = img_input.clone();

    int k = (filter_size - 1)/2;
    for (int i = k;i<(img_input.rows - k);i++){
        for (int j = k;j<(img_input.cols - k);j++){
            int sum = 0;
            for (int m = -k;m<k+1;m++){
                for (int n=-k;n<k+1;n++)
                {
                    sum += img_input.at<uchar>(i+m,j+n);
                }
            }
            img_output.at<uchar>(i,j) = sum/(filter_size*filter_size);
        }
    }
}
相关推荐
还没想好取啥名1 小时前
C++11新特性(一)——原始字面量
开发语言·c++
天赐学c语言1 小时前
12.6 - K个一组翻转链表 && C 编译到执行的4个阶段
数据结构·c++·链表·c编译
询问QQ:180809511 小时前
基于出行链的电动汽车空间负荷预测,MATLAB,有注释,方便初学者理解上手,此程序用来计算节点...
opencv
爪哇部落算法小助手2 小时前
每日两题day65
数据结构·c++·算法
橘颂TA2 小时前
【剑斩OFFER】算法的暴力美学——颜色分类
数据结构·c++·算法·动态规划
fish_xk3 小时前
c++基础扩展
开发语言·c++
阿沁QWQ3 小时前
C++继承
开发语言·c++
啊吧怪不啊吧3 小时前
C++之基于正倒排索引的Boost搜索引擎项目searcher部分代码及详解
c++·搜索引擎·项目
无限进步_3 小时前
C语言实现贪吃蛇游戏详解
c语言·开发语言·数据结构·c++·后端·算法·游戏
CHANG_THE_WORLD3 小时前
C++ vs Python 参数传递方式对比
java·c++·python