中文字幕第二一区_久久久久在线视频_精品国产自在现线看久久_亚洲精品一区二区三区电影网

產品分類

當前位置: 首頁 > 工業電氣產品 > 高低壓電器 > 工業濾波器

類型分類:
科普知識
數據分類:
工業濾波器

高斯濾波器的原理及實現過程

發布日期:2022-10-09 點擊率:90

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

 

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

 

什么是高斯濾波器

 

既然名稱為高斯濾波器,那么其和高斯分布(正態分布)是有一定的關系的。一個二維的高斯函數如下:

 

 

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

 

 

這樣,將各個位置的坐標帶入到高斯函數中,得到的值就是模板的系數。

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

 

 

這樣計算出來的模板有兩種形式:小數和整數。

小數形式的模板,就是直接計算得到的值,沒有經過任何的處理;

 

整數形式的,則需要進行歸一化處理,將模板左上角的值歸一化為1,下面會具體介紹。使用整數的模板時,需要在模板的前面加一個系數,系數為

也就是模板系數和的倒數。

 

高斯模板的生成

 

知道模板生成的原理,實現起來也就不困難了

 

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

{

    static const double pi = 3.1415926;

    int center = ksize / 2; // 模板的中心位置,也就是坐標的原點

    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]; // 將左上角的系數歸一化為1

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

    {

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

        {

            window[i][j] *= k;

        }

    }

}

 

 

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

 

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

 

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

 

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

 

 

對上述解結果取整后得到如下模板:

 

 

這個模板就比較熟悉了,其就是根據σ=0.8的高斯函數生成的模板。

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

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

{

    static const double pi = 3.1415926;

    int center = ksize / 2; // 模板的中心位置,也就是坐標的原點

    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]; // 將左上角的系數歸一化為1

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

    {

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

        {

            window[i][j] /= sum;

        }

    }

}

 

3×3,σ=0.8的小數型模板。

 

 

σσ值的意義及選取

 

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

 

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

 

 

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

 

于是可以得到如下結論:

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

σσ越小,分布越集中,中間部分所占比重遠遠高于其他部分,反映到高斯模板上就是中心元素值遠遠大于其他元素值,于是自然而然就相當于中間值得點運算。

 

基于OpenCV的實現

 

在生成高斯模板好,其簡單的實現和其他的空間濾波器沒有區別,具體代碼如下:

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

{

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

    const static double pi = 3.1415926;

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

    // 申請一個二維數組,存放生成的高斯模板矩陣

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

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

        templateMatrix[i] = new double[ksize];

    int origin = ksize / 2; // 以模板的中心為原點

    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);

            // 高斯函數前的常數可以不用計算,會在歸一化的過程中給消去

            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;

    }

    // 將模板應用到圖像中

    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

            }

        }

    }

    // 釋放模板數組

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

        delete[] templateMatrix[i];

    delete[] templateMatrix;

}

 

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

 

分離實現高斯濾波

 

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

 

// 分離的計算

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++)

    {

        // 高斯函數前的常數可以不用計算,會在歸一化的過程中給消去

        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;

    // 將模板應用到圖像中

    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;

}

 

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

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

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

                                double sigmaX, double sigmaY = 0,

                                int borderType = BORDER_DEFAULT );

 

二維高斯函數的標準差在x和y方向上應該分別有一個標準差,在上面的代碼中一直設其在x和y方向的標準是相等的,在OpenCV中的高斯濾波器中,可以在x和y方向上設置不同的標準差。

 

下圖是自己實現的高斯濾波器和OpenCV中的GaussianBlur的結果對比

 

 

上圖是5×5,σ=0.8的高斯濾波器,可以看出兩個實現得到的結果沒有很大的區別。

 

總結

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

 

高斯濾波器最重要的參數就是高斯分布的標準差σσ,標準差和高斯濾波器的平滑能力有很大的能力,σσ越大,高斯濾波器的頻帶就較寬,對圖像的平滑程度就越好。通過調節σσ參數,可以平衡對圖像的噪聲的抑制和對圖像的模糊。

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

上一篇: MATLAB和Simulink在航

推薦產品

更多
中文字幕第二一区_久久久久在线视频_精品国产自在现线看久久_亚洲精品一区二区三区电影网

      9000px;">

          欧美mv日韩mv亚洲| 日韩一区二区三区四区五区六区| 久久国产精品无码网站| 亚洲综合色区另类av| 国产精品美女一区二区三区| 久久看人人爽人人| 久久午夜羞羞影院免费观看| 91麻豆精品国产91久久久久| 欧美系列亚洲系列| 在线电影一区二区三区| 欧美日韩视频一区二区| 在线观看日韩国产| 91九色02白丝porn| 8v天堂国产在线一区二区| 欧美一区二区三区四区五区 | 天堂va蜜桃一区二区三区漫画版 | 欧美一区二区三区公司| 欧美一级夜夜爽| www成人在线观看| 国产欧美一区视频| 1024亚洲合集| 亚洲动漫第一页| 男人操女人的视频在线观看欧美 | 久久久五月婷婷| 亚洲国产精品成人综合| 国产精品色哟哟网站| 亚洲欧美激情小说另类| 婷婷国产在线综合| 久热成人在线视频| 91在线视频网址| 欧美日产在线观看| 国产欧美日韩卡一| 亚洲午夜精品17c| 久久国产综合精品| 成人av免费观看| 欧美日韩一区 二区 三区 久久精品| 制服丝袜成人动漫| 日本一区二区在线不卡| 一区二区三区91| 日本成人在线不卡视频| 国产高清精品久久久久| 91久久精品一区二区三| 日韩女同互慰一区二区| 亚洲天堂成人网| 国产在线国偷精品产拍免费yy| av在线一区二区| 久久亚洲一区二区三区四区| 日韩理论片中文av| 日本特黄久久久高潮 | 亚洲在线中文字幕| 国产成人福利片| 欧美精品免费视频| 国产精品久久久久影院色老大| 午夜精品久久一牛影视| 成人一级片在线观看| 337p亚洲精品色噜噜狠狠| 最新不卡av在线| 国产一区欧美一区| 欧美一区二区三区系列电影| 一区二区三区在线免费观看 | 久久久久久久一区| 日本系列欧美系列| 色999日韩国产欧美一区二区| 国产亚洲婷婷免费| 另类小说色综合网站| 欧美日韩精品一区二区在线播放 | 亚洲尤物在线视频观看| av中文字幕亚洲| 国产精品婷婷午夜在线观看| 久久成人精品无人区| 在线电影院国产精品| 亚洲国产cao| 91麻豆国产福利精品| 欧美激情一区二区三区全黄| 极品少妇xxxx精品少妇| 日韩一区二区精品| 奇米影视在线99精品| 欧美日韩国产美| 亚洲图片欧美色图| 欧美伊人精品成人久久综合97| 中文字幕在线一区| 一本久久a久久精品亚洲| 综合久久给合久久狠狠狠97色| 成人自拍视频在线| 17c精品麻豆一区二区免费| 91在线小视频| 亚洲一区在线观看免费观看电影高清| 99久久久久免费精品国产| 成人免费一区二区三区在线观看| 成人性生交大片免费看中文网站| 欧美激情一区二区三区蜜桃视频| 国产成人av电影| 一区在线播放视频| 在线视频国内自拍亚洲视频| 亚洲在线观看免费| 欧美久久久久久久久中文字幕| 视频一区视频二区在线观看| 欧美成人一区二区三区| 国产精一品亚洲二区在线视频| 国产日韩v精品一区二区| 91麻豆免费观看| 亚洲国产一二三| 日韩一区二区三区四区五区六区| 久久精品久久综合| 亚洲欧洲精品一区二区三区| 欧美日韩一区二区欧美激情| 精品一区二区在线播放| 国产精品国产精品国产专区不蜜| 日本高清免费不卡视频| 精品影院一区二区久久久| 久久精品人人做人人综合| 91免费观看视频| 精东粉嫩av免费一区二区三区| 亚洲天堂a在线| 日韩女优视频免费观看| 91免费视频观看| 美女被吸乳得到大胸91| 18成人在线观看| 2020国产精品自拍| 色综合一区二区| 国产综合久久久久影院| 有码一区二区三区| 欧美变态口味重另类| 在线看日本不卡| 激情文学综合网| 亚洲福利一二三区| 国产亚洲午夜高清国产拍精品| 欧美日韩一区二区三区免费看| 国产一区二区在线视频| 婷婷六月综合网| 亚洲精品老司机| 久久尤物电影视频在线观看| 欧美日韩色综合| 99精品久久99久久久久| 国产一区二区三区四| 五月天欧美精品| 亚洲综合一区二区| 中文字幕久久午夜不卡| 精品国产网站在线观看| 欧美片网站yy| 欧洲国内综合视频| 91免费国产在线| 99免费精品在线观看| 国产成人在线免费| 国内精品免费在线观看| 久久av老司机精品网站导航| 亚洲自拍偷拍av| 亚洲国产精品久久一线不卡| 玉米视频成人免费看| 亚洲精品视频免费看| 国产精品水嫩水嫩| 国产欧美日韩综合| 国产午夜一区二区三区| 欧美经典三级视频一区二区三区| 久久夜色精品国产噜噜av| 精品国产乱码久久久久久免费| 日韩欧美国产麻豆| 精品国产百合女同互慰| 26uuu久久天堂性欧美| 欧美成人国产一区二区| 精品国精品国产| 欧美国产视频在线| 亚洲日本在线看| 一区二区三区.www| 亚洲成人自拍偷拍| 日韩av中文在线观看| 蓝色福利精品导航| 丁香啪啪综合成人亚洲小说| jlzzjlzz欧美大全| 在线观看亚洲一区| 欧美电视剧免费全集观看| 久久久蜜桃精品| 亚洲国产精品激情在线观看| 亚洲欧洲一区二区在线播放| 一区二区三区四区在线免费观看| 亚洲午夜在线视频| 老司机精品视频在线| 成人激情免费电影网址| 色88888久久久久久影院野外| 在线不卡中文字幕| 国产日韩欧美激情| 亚洲国产人成综合网站| 麻豆成人在线观看| 成人a区在线观看| 欧美日韩免费观看一区二区三区| 欧美一级在线观看| 国产精品久久久久久久久果冻传媒| 亚洲欧美日韩久久精品| 琪琪一区二区三区| 91免费视频网址| 欧美精品一区二区三区四区| 亚洲私人影院在线观看| 开心九九激情九九欧美日韩精美视频电影 | 韩国一区二区三区| 一本到一区二区三区| 欧美精品一区二区三区四区| 亚洲制服丝袜一区| 高清视频一区二区| 7777精品伊人久久久大香线蕉超级流畅 | 日韩一级黄色大片|