美女网站一区二区_在线观看日韩毛片_成人在线视频首页_欧美精品一区二区三区久久久_国产精品亚洲一区二区三区在线_日本免费新一区视频_日本美女一区二区三区_精品亚洲成a人_久久不见久久见免费视频1_91首页免费视频_欧美一区二区在线看_91精品91久久久中77777_天堂蜜桃一区二区三区_av在线一区二区_欧美不卡一区二区_欧美影视一区二区三区

產(chǎn)品分類

當(dāng)前位置: 首頁 > 工業(yè)電氣產(chǎn)品 > 高低壓電器 > 工業(yè)濾波器

類型分類:
科普知識(shí)
數(shù)據(jù)分類:
工業(yè)濾波器

高斯濾波器的原理及實(shí)現(xiàn)過程

發(fā)布日期:2022-10-09 點(diǎn)擊率:85

【導(dǎo)讀】高斯濾波器是一種線性濾波器,能夠有效的抑制噪聲,平滑圖像。其作用原理和均值濾波器類似,都是取濾波器窗口內(nèi)的像素的均值作為輸出。本文主要介紹了高斯濾波器的原理及其實(shí)現(xiàn)過程。

 

其窗口模板的系數(shù)和均值濾波器不同,均值濾波器的模板系數(shù)都是相同的為1;而高斯濾波器的模板系數(shù),則隨著距離模板中心的增大而系數(shù)減小。所以,高斯濾波器相比于均值濾波器對(duì)圖像個(gè)模糊程度較小。

 

什么是高斯濾波器

 

既然名稱為高斯濾波器,那么其和高斯分布(正態(tài)分布)是有一定的關(guān)系的。一個(gè)二維的高斯函數(shù)如下:

 

 

其中(x,y)(x,y)為點(diǎn)坐標(biāo),在圖像處理中可認(rèn)為是整數(shù);σσ是標(biāo)準(zhǔn)差。要想得到一個(gè)高斯濾波器的模板,可以對(duì)高斯函數(shù)進(jìn)行離散化,得到的高斯函數(shù)值作為模板的系數(shù)。例如:要產(chǎn)生一個(gè)3×33×3的高斯濾波器模板,以模板的中心位置為坐標(biāo)原點(diǎn)進(jìn)行取樣。模板在各個(gè)位置的坐標(biāo),如下所示(x軸水平向右,y軸豎直向下)

 

 

這樣,將各個(gè)位置的坐標(biāo)帶入到高斯函數(shù)中,得到的值就是模板的系數(shù)。

對(duì)于窗口模板的大小為(2k+1)×(2k+1),模板中各個(gè)元素值的計(jì)算公式如下:

 

 

這樣計(jì)算出來的模板有兩種形式:小數(shù)和整數(shù)。

小數(shù)形式的模板,就是直接計(jì)算得到的值,沒有經(jīng)過任何的處理;

 

整數(shù)形式的,則需要進(jìn)行歸一化處理,將模板左上角的值歸一化為1,下面會(huì)具體介紹。使用整數(shù)的模板時(shí),需要在模板的前面加一個(gè)系數(shù),系數(shù)為

也就是模板系數(shù)和的倒數(shù)。

 

高斯模板的生成

 

知道模板生成的原理,實(shí)現(xiàn)起來也就不困難了

 

void generateGaussianTemplate(double window[][11], int ksize, double sigma)

{

    static const double pi = 3.1415926;

    int center = ksize / 2; // 模板的中心位置,也就是坐標(biāo)的原點(diǎn)

    double x2, y2;

    for (int i = 0; i < ksize; i++)

    {

        x2 = pow(i - center, 2);

        for (int j = 0; j < ksize; j++)

        {

            y2 = pow(j - center, 2);

            double g = exp(-(x2 + y2) / (2 * sigma * sigma));

            g /= 2 * pi * sigma;

            window[i][j] = g;

        }

    }

    double k = 1 / window[0][0]; // 將左上角的系數(shù)歸一化為1

    for (int i = 0; i < ksize; i++)

    {

        for (int j = 0; j < ksize; j++)

        {

            window[i][j] *= k;

        }

    }

}

 

 

需要一個(gè)二維數(shù)組,存放生成的系數(shù)(這里假設(shè)模板的最大尺寸不會(huì)超過11);第二個(gè)參數(shù)是模板的大小(不要超過11);第三個(gè)參數(shù)就比較重要了,是高斯分布的標(biāo)準(zhǔn)差。

 

生成的過程,首先根據(jù)模板的大小,找到模板的中心位置ksize/2。然后就是遍歷,根據(jù)高斯分布的函數(shù),計(jì)算模板中每個(gè)系數(shù)的值。

 

需要注意的是,最后歸一化的過程,使用模板左上角的系數(shù)的倒數(shù)作為歸一化的系數(shù)(左上角的系數(shù)值被歸一化為1),模板中的每個(gè)系數(shù)都乘以該值(左上角系數(shù)的倒數(shù)),然后將得到的值取整,就得到了整數(shù)型的高斯濾波器模板。

 

下面截圖生成的是,大小為3×3,σ=0.83×3,σ=0.8的模板

 

 

對(duì)上述解結(jié)果取整后得到如下模板:

 

 

這個(gè)模板就比較熟悉了,其就是根據(jù)σ=0.8的高斯函數(shù)生成的模板。

至于小數(shù)形式的生成也比較簡(jiǎn)單,去掉歸一化的過程,并且在求解過程后,模板的每個(gè)系數(shù)要除以所有系數(shù)的和。具體代碼如下:

void generateGaussianTemplate(double window[][11], int ksize, double sigma)

{

    static const double pi = 3.1415926;

    int center = ksize / 2; // 模板的中心位置,也就是坐標(biāo)的原點(diǎn)

    double x2, y2;

    double sum = 0;

    for (int i = 0; i < ksize; i++)

    {

        x2 = pow(i - center, 2);

        for (int j = 0; j < ksize; j++)

        {

            y2 = pow(j - center, 2);

            double g = exp(-(x2 + y2) / (2 * sigma * sigma));

            g /= 2 * pi * sigma;

            sum += g;

            window[i][j] = g;

        }

    }

    //double k = 1 / window[0][0]; // 將左上角的系數(shù)歸一化為1

    for (int i = 0; i < ksize; i++)

    {

        for (int j = 0; j < ksize; j++)

        {

            window[i][j] /= sum;

        }

    }

}

 

3×3,σ=0.8的小數(shù)型模板。

 

 

σσ值的意義及選取

 

通過上述的實(shí)現(xiàn)過程,不難發(fā)現(xiàn),高斯濾波器模板的生成最重要的參數(shù)就是高斯分布的標(biāo)準(zhǔn)差σσ。標(biāo)準(zhǔn)差代表著數(shù)據(jù)的離散程度,如果σσ較小,那么生成的模板的中心系數(shù)較大,而周圍的系數(shù)較小,這樣對(duì)圖像的平滑效果就不是很明顯;反之,σσ較大,則生成的模板的各個(gè)系數(shù)相差就不是很大,比較類似均值模板,對(duì)圖像的平滑效果比較明顯。

 

來看下一維高斯分布的概率分布密度圖:

 

 

橫軸表示可能得取值x,豎軸表示概率分布密度F(x),那么不難理解這樣一個(gè)曲線與x軸圍成的圖形面積為1。σσ(標(biāo)準(zhǔn)差)決定了這個(gè)圖形的寬度,可以得出這樣的結(jié)論:σσ越大,則圖形越寬,尖峰越小,圖形較為平緩;σσ越小,則圖形越窄,越集中,中間部分也就越尖,圖形變化比較劇烈。這其實(shí)很好理解,如果sigma也就是標(biāo)準(zhǔn)差越大,則表示該密度分布一定比較分散,由于面積為1,于是尖峰部分減小,寬度越寬(分布越分散);同理,當(dāng)σσ越小時(shí),說明密度分布較為集中,于是尖峰越尖,寬度越窄!

 

于是可以得到如下結(jié)論:

σσ越大,分布越分散,各部分比重差別不大,于是生成的模板各元素值差別不大,類似于平均模板;

σσ越小,分布越集中,中間部分所占比重遠(yuǎn)遠(yuǎn)高于其他部分,反映到高斯模板上就是中心元素值遠(yuǎn)遠(yuǎn)大于其他元素值,于是自然而然就相當(dāng)于中間值得點(diǎn)運(yùn)算。

 

基于OpenCV的實(shí)現(xiàn)

 

在生成高斯模板好,其簡(jiǎn)單的實(shí)現(xiàn)和其他的空間濾波器沒有區(qū)別,具體代碼如下:

void GaussianFilter(const Mat &src, Mat &dst, int ksize, double sigma)

{

    CV_Assert(src.channels() || src.channels() == 3); // 只處理單通道或者三通道圖像

    const static double pi = 3.1415926;

    // 根據(jù)窗口大小和sigma生成高斯濾波器模板

    // 申請(qǐng)一個(gè)二維數(shù)組,存放生成的高斯模板矩陣

    double **templateMatrix = new double*[ksize];

    for (int i = 0; i < ksize; i++)

        templateMatrix[i] = new double[ksize];

    int origin = ksize / 2; // 以模板的中心為原點(diǎn)

    double x2, y2;

    double sum = 0;

    for (int i = 0; i < ksize; i++)

    {

        x2 = pow(i - origin, 2);

        for (int j = 0; j < ksize; j++)

        {

            y2 = pow(j - origin, 2);

            // 高斯函數(shù)前的常數(shù)可以不用計(jì)算,會(huì)在歸一化的過程中給消去

            double g = exp(-(x2 + y2) / (2 * sigma * sigma));

            sum += g;

            templateMatrix[i][j] = g;

        }

    }

    for (int i = 0; i < ksize; i++)

    {

        for (int j = 0; j < ksize; j++)

        {

            templateMatrix[i][j] /= sum;

            cout << templateMatrix[i][j] << " ";

        }

        cout << endl;

    }

    // 將模板應(yīng)用到圖像中

    int border = ksize / 2;

    copyMakeBorder(src, dst, border, border, border, border, BorderTypes::BORDER_REFLECT);

    int channels = dst.channels();

    int rows = dst.rows - border;

    int cols = dst.cols - border;

    for (int i = border; i < rows; i++)

    {

        for (int j = border; j < cols; j++)

        {

            double sum[3] = { 0 };

            for (int a = -border; a <= border; a++)

            {

                for (int b = -border; b <= border; b++)

                {

                    if (channels == 1)

                    {

                        sum[0] += templateMatrix[border + a][border + b] * dst.at

                    }

                    else if (channels == 3)

                    {

                        Vec3b rgb = dst.at

                        auto k = templateMatrix[border + a][border + b];

                        sum[0] += k * rgb[0];

                        sum[1] += k * rgb[1];

                        sum[2] += k * rgb[2];

                    }

                }

            }

            for (int k = 0; k < channels; k++)

            {

                if (sum[k] < 0)

                    sum[k] = 0;

                else if (sum[k] > 255)

                    sum[k] = 255;

            }

            if (channels == 1)

                dst.at

            else if (channels == 3)

            {

                Vec3b rgb = { static_cast

                dst.at

            }

        }

    }

    // 釋放模板數(shù)組

    for (int i = 0; i < ksize; i++)

        delete[] templateMatrix[i];

    delete[] templateMatrix;

}

 

只處理單通道或者三通道圖像,模板生成后,其濾波(卷積過程)就比較簡(jiǎn)單了。不過,這樣的高斯濾波過程,其循環(huán)運(yùn)算次數(shù)為m×n×ksize2,其中m,n為圖像的尺寸;ksize為高斯濾波器的尺寸。這樣其時(shí)間復(fù)雜度為O(ksize2),隨濾波器的模板的尺寸呈平方增長(zhǎng),當(dāng)高斯濾波器的尺寸較大時(shí),其運(yùn)算效率是極低的。為了,提高濾波的運(yùn)算速度,可以將二維的高斯濾波過程分解開來。

 

分離實(shí)現(xiàn)高斯濾波

 

由于高斯函數(shù)的可分離性,尺寸較大的高斯濾波器可以分成兩步進(jìn)行:首先將圖像在水平(豎直)方向與一維高斯函數(shù)進(jìn)行卷積;然后將卷積后的結(jié)果在豎直(水平)方向使用相同的一維高斯函數(shù)得到的模板進(jìn)行卷積運(yùn)算。具體實(shí)現(xiàn)代碼如下:

 

// 分離的計(jì)算

void separateGaussianFilter(const Mat &src, Mat &dst, int ksize, double sigma)

{

    CV_Assert(src.channels()==1 || src.channels() == 3); // 只處理單通道或者三通道圖像

    // 生成一維的高斯濾波模板

    double *matrix = new double[ksize];

    double sum = 0;

    int origin = ksize / 2;

    for (int i = 0; i < ksize; i++)

    {

        // 高斯函數(shù)前的常數(shù)可以不用計(jì)算,會(huì)在歸一化的過程中給消去

        double g = exp(-(i - origin) * (i - origin) / (2 * sigma * sigma));

        sum += g;

        matrix[i] = g;

    }

    // 歸一化

    for (int i = 0; i < ksize; i++)

        matrix[i] /= sum;

    // 將模板應(yīng)用到圖像中

    int border = ksize / 2;

    copyMakeBorder(src, dst, border, border, border, border, BorderTypes::BORDER_REFLECT);

    int channels = dst.channels();

    int rows = dst.rows - border;

    int cols = dst.cols - border;

    // 水平方向

    for (int i = border; i < rows; i++)

    {

        for (int j = border; j < cols; j++)

        {

            double sum[3] = { 0 };

            for (int k = -border; k <= border; k++)

            {

                if (channels == 1)

                {

                    sum[0] += matrix[border + k] * dst.at

                }

                else if (channels == 3)

                {

                    Vec3b rgb = dst.at

                    sum[0] += matrix[border + k] * rgb[0];

                    sum[1] += matrix[border + k] * rgb[1];

                    sum[2] += matrix[border + k] * rgb[2];

                }

            }

            for (int k = 0; k < channels; k++)

            {

                if (sum[k] < 0)

                    sum[k] = 0;

                else if (sum[k] > 255)

                    sum[k] = 255;

            }

            if (channels == 1)

                dst.at

            else if (channels == 3)

            {

                Vec3b rgb = { static_cast

                dst.at

            }

        }

    }

    // 豎直方向

    for (int i = border; i < rows; i++)

    {

        for (int j = border; j < cols; j++)

        {

            double sum[3] = { 0 };

            for (int k = -border; k <= border; k++)

            {

                if (channels == 1)

                {

                    sum[0] += matrix[border + k] * dst.at

                }

                else if (channels == 3)

                {

                    Vec3b rgb = dst.at

                    sum[0] += matrix[border + k] * rgb[0];

                    sum[1] += matrix[border + k] * rgb[1];

                    sum[2] += matrix[border + k] * rgb[2];

                }

            }

            for (int k = 0; k < channels; k++)

            {

                if (sum[k] < 0)

                    sum[k] = 0;

                else if (sum[k] > 255)

                    sum[k] = 255;

            }

            if (channels == 1)

                dst.at

            else if (channels == 3)

            {

                Vec3b rgb = { static_cast

                dst.at

            }

        }

    }

    delete[] matrix;

}

 

代碼沒有重構(gòu)較長(zhǎng),不過其實(shí)現(xiàn)原理是比較簡(jiǎn)單的。首先得到一維高斯函數(shù)的模板,在卷積(濾波)的過程中,保持行不變,列變化,在水平方向上做卷積運(yùn)算;接著在上述得到的結(jié)果上,保持列不邊,行變化,在豎直方向上做卷積運(yùn)算。這樣分解開來,算法的時(shí)間復(fù)雜度為O(ksize)O(ksize),運(yùn)算量和濾波器的模板尺寸呈線性增長(zhǎng)。

在OpenCV也有對(duì)高斯濾波器的封裝GaussianBlur,其聲明如下:

CV_EXPORTS_W void GaussianBlur( InputArray src, OutputArray dst, Size ksize,

                                double sigmaX, double sigmaY = 0,

                                int borderType = BORDER_DEFAULT );

 

二維高斯函數(shù)的標(biāo)準(zhǔn)差在x和y方向上應(yīng)該分別有一個(gè)標(biāo)準(zhǔn)差,在上面的代碼中一直設(shè)其在x和y方向的標(biāo)準(zhǔn)是相等的,在OpenCV中的高斯濾波器中,可以在x和y方向上設(shè)置不同的標(biāo)準(zhǔn)差。

 

下圖是自己實(shí)現(xiàn)的高斯濾波器和OpenCV中的GaussianBlur的結(jié)果對(duì)比

 

 

上圖是5×5,σ=0.8的高斯濾波器,可以看出兩個(gè)實(shí)現(xiàn)得到的結(jié)果沒有很大的區(qū)別。

 

總結(jié)

高斯濾波器是一種線性平滑濾波器,其濾波器的模板是對(duì)二維高斯函數(shù)離散得到。由于高斯模板的中心值最大,四周逐漸減小,其濾波后的結(jié)果相對(duì)于均值濾波器來說更好。

 

高斯濾波器最重要的參數(shù)就是高斯分布的標(biāo)準(zhǔn)差σσ,標(biāo)準(zhǔn)差和高斯濾波器的平滑能力有很大的能力,σσ越大,高斯濾波器的頻帶就較寬,對(duì)圖像的平滑程度就越好。通過調(diào)節(jié)σσ參數(shù),可以平衡對(duì)圖像的噪聲的抑制和對(duì)圖像的模糊。

下一篇: PLC、DCS、FCS三大控

上一篇: MATLAB和Simulink在航

推薦產(chǎn)品

更多
美女网站一区二区_在线观看日韩毛片_成人在线视频首页_欧美精品一区二区三区久久久_国产精品亚洲一区二区三区在线_日本免费新一区视频_日本美女一区二区三区_精品亚洲成a人_久久不见久久见免费视频1_91首页免费视频_欧美一区二区在线看_91精品91久久久中77777_天堂蜜桃一区二区三区_av在线一区二区_欧美不卡一区二区_欧美影视一区二区三区


        成人av影院在线| 亚洲一区二区三区爽爽爽爽爽| 亚洲一区二区精品在线观看| 久久riav二区三区| 蜜桃欧美视频| 天天好比中文综合网| 亚洲一区精品视频| 欧美日韩在线一区二区| 91精品国产综合久久小美女 | 色屁屁一区二区| 欧美视频在线一区| 91精品国产91久久久久久一区二区 | 欧美日韩国产在线观看| 制服丝袜成人动漫| 久久久久久久综合日本| 中文字幕在线一区二区三区| 午夜免费久久看| 国产成人综合亚洲91猫咪| 91丨porny丨中文| 欧美日韩另类丝袜其他| 欧美性高清videossexo| 久久婷婷一区二区三区| 一区二区在线观看免费视频播放| 日本va欧美va精品| 91亚洲午夜精品久久久久久| 日韩av电影在线观看| 欧美女孩性生活视频| 国产亚洲视频系列| 亚洲成av人在线观看| 国产精品一区二区果冻传媒| 成人91免费视频| 在线观看国产91| 日本一区二区三区久久久久久久久不 | 亚洲国产精品久久久久婷婷884| 激情综合网天天干| 国产精品初高中精品久久 | 亚洲精品一区二区三区精华液| 中文字幕亚洲在| 久久激情五月婷婷| 99re在线观看| 日本精品免费观看高清观看| 久久欧美一区二区| 青青青爽久久午夜综合久久午夜| 91原创在线视频| 色噜噜久久综合| 国产精品伦一区| 国产一区二区91| 日韩三级在线播放| 久久久久久久久久久久久久久99 | 午夜欧美性电影| 欧美一区二区三区免费大片 | 欧美精品v日韩精品v国产精品| 日本欧洲一区二区| 成人免费毛片高清视频| 久久婷婷人人澡人人喊人人爽| 欧美性三三影院| 综合婷婷亚洲小说| 高清不卡在线观看av| 图片区小说区区亚洲五月| 精品国产3级a| 乱中年女人伦av一区二区| 成人av影院在线| 亚洲草草视频| 亚洲日本一区二区| 欧美大片在线观看一区| 一个色在线综合| 成人国产精品免费| 这里只有精品66| 亚洲视频一区二区免费在线观看| 国产成人午夜99999| 亚洲va韩国va欧美va精四季| 久久精品欧美日韩精品| 中文字幕在线一区| 粉嫩av一区二区三区在线播放| 亚洲美女网站18| 亚洲人成人一区二区在线观看| 成人免费av在线| 欧美日韩一区 二区 三区 久久精品 | 久久草.com| 久久先锋影音av鲁色资源| 精品亚洲国产成人av制服丝袜 | 久久久一区二区三区捆绑**| 久久精工是国产品牌吗| 亚洲午夜久久久影院伊人| 亚洲日本一区二区三区| 99精彩视频在线观看免费| 日韩欧美一区二区免费| 国产精品影视网| 欧美日韩国产综合一区二区三区| 亚洲主播在线观看| 97免费资源站| 99国产欧美另类久久久精品| 欧美日韩亚洲一区二区三区在线观看| 精品久久五月天| 成人av在线影院| 日韩欧美的一区二区| 国产成人av电影在线播放| 欧美日韩久久久久久| 九九视频精品免费| 欧美日韩在线播| 国产一区二区影院| 在线观看91精品国产麻豆| 国产麻豆成人精品| 欧美一区二区三区在| 成人一区二区在线观看| 欧美va亚洲va在线观看蝴蝶网| 岛国精品在线观看| 久久综合资源网| 国产精品三区四区| 日韩理论片中文av| 日本成人黄色| 日韩国产精品大片| 欧美三级电影网| 国产揄拍国内精品对白| 日韩欧美在线网站| 91精品综合久久| 亚洲色图制服诱惑 | 久久成人久久爱| 日韩一区二区视频在线观看| 成人免费毛片a| 中文字幕免费一区| 日本精品一区二区| 蜜桃视频在线观看一区| 欧美一级欧美三级| 成人影片在线播放| 亚洲午夜视频在线| 欧美日韩一级二级| 91亚洲永久精品| 亚洲激情一二三区| 欧美又粗又大又爽| 波多野结衣中文一区| 成人免费在线播放视频| 一本色道久久综合亚洲精品按摩 | 久久青青草综合| 日产精品久久久久久久性色| 欧美一级久久久久久久大片| 国产精品免费一区二区三区在线观看 | 国产二区国产一区在线观看| 久久免费国产精品| 日韩免费中文专区| 国产麻豆日韩欧美久久| 中文字幕国产精品一区二区| 污视频在线免费观看一区二区三区| 国内精品视频666| 亚洲国产高清在线| 色拍拍在线精品视频8848| av综合在线播放| 亚洲一区二区黄色| 日韩欧美一区二区免费| 欧美一级片免费观看| 国产不卡在线视频| 一区二区三区四区高清精品免费观看| 欧美三级电影网| 久久久久网址| 国产91露脸合集magnet| 一区二区三区国产豹纹内裤在线| 欧美日韩成人一区| 久久久久久高清| 国产jizzjizz一区二区| 亚洲一区二区高清| 久久久精品综合| 精品视频一区三区九区| 久久精品一区二区三区不卡免费视频| 国内不卡的二区三区中文字幕| 综合欧美亚洲日本| 欧美一级黄色录像| 日韩欧美99| 97人人干人人| 麻豆精品久久久| 亚洲人快播电影网| 精品久久久久久久久久久久久久久 | 日韩欧美国产精品| 亚洲日本欧美在线| 成人av片网址| 国产高清不卡二三区| 亚洲线精品一区二区三区八戒| 欧美tk丨vk视频| 色综合久久66| 青青成人在线| 狠狠色综合网站久久久久久久| 国产成人精品一区二区三区四区| 亚洲123区在线观看| 亚洲欧洲av另类| 久久综合色一综合色88| 欧美日韩成人在线一区| 一区二区三区四区国产| 国产在线精品日韩| www.日韩精品| 国产成人亚洲综合色影视| 热久久国产精品| 亚洲妇女屁股眼交7| 自拍偷拍欧美激情| 欧美国产日韩a欧美在线观看 | 欧美精品一区二| 欧美喷水一区二区| 欧美综合一区二区| 一区二区三区国| 亚洲精品成人a8198a| 久久av一区二区三区亚洲| 99在线高清视频在线播放|