【c++|opencv】二、灰度变换和空间滤波---4.高斯滤波

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 std;
using namespace cv;

// 定义高斯滤波函数
void myfilter(int filter_size,Mat& img_input,Mat& img_output);


int main(){
    Mat img,img_gray,img_out,img_out2;
    img = imread("/home/v/home.png");
    if (img.empty()){
        cout<<"can't open the image"<<endl;
        return -1;
    }
    imshow("img",img);
    cvtColor(img,img_gray,COLOR_BGR2GRAY);
    Salt(img_gray,1000);
    imshow("img_gray",img_gray);

    // Opencv 自带的滤波
    int a= 7;
    GaussianBlur(img_gray,img_out,Size(a,a),2,2);
    imshow("GaussianBlur",img_out);

    // 自定义高斯滤波
    myfilter(a,img_gray,img_out2);
    imshow("myfilter",img_out2);
    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++){
            double sum = 0.0;
            double sum1 = 0.0;
            double sigma = 7;
            double g;

            for (int m = -k; m <= k; m++){
                for (int n = -k; n <= k; n++){
                    g = exp(-(m*m+n*n)/(2*sigma*sigma));
                    sum += g*img_input.at<uchar>(i+m,j+n);
                    sum1 += g;
                }
            }
            img_output.at<uchar>(i,j) = (int)(sum/sum1);
        }
   }


}
相关推荐
zhangjw3414 小时前
Java基础语法:变量、数据类型与运算符,从原理到实战
java·开发语言
yaoxin52112317 小时前
384. Java IO API - Java 文件复制工具:Copy 示例完整解析
java·开发语言·python
WBluuue18 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌
c++·算法
NotFound48618 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
木子墨51618 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性
数据结构·c++·算法·leetcode
Ava的硅谷新视界19 小时前
用了一天 Claude Opus 4.7,聊几点真实感受
开发语言·后端·编程
rabbit_pro19 小时前
Python调用onnx模型
开发语言·python
王老师青少年编程19 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌
c++·算法·编程·贪心·csp·信奥赛·均分纸牌
weixin_5134499619 小时前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结
c++·人工智能·学习·算法·机器人
浪客川19 小时前
【百例RUST - 010】字符串
开发语言·后端·rust