欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實現(xiàn)中值濾波的示例代碼

 更新時間:2022年05月12日 11:39:02   作者:小魏612  
本文主要介紹了C++實現(xiàn)中值濾波的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

為了加深對中值濾波算法的理解以及方便以后更好的復(fù)習(xí),我將該算法的一些重點細節(jié)和實現(xiàn)過程踩過的坑記錄下來。

中值濾波器是一種非線性濾波器,或者叫統(tǒng)計排序濾波器。

適用對象:帶椒鹽噪聲的圖像

由于椒鹽噪聲像素值與原圖像素值沒有關(guān)聯(lián),隨機性較大,因此使用中值濾波可有效濾掉噪聲。

中值濾波需要對像素值進行排序,因此首先寫一個冒泡排序算法。

冒泡排序?qū)崿F(xiàn):

為提高效率加入標(biāo)志位flag,當(dāng)?shù)趇次尋找最大值時,如果相鄰兩個數(shù)均未發(fā)生互換,此時flag位為false,即說明此時數(shù)組已經(jīng)按照遞增排列,可提前終止。此處應(yīng)該注意flag=false所在位置,因為需要保證第i次尋找最大值過程中,遍歷到所有未參與排列的數(shù)據(jù),所以flag=false應(yīng)該放在循環(huán)條件for(int j=0; j<len-1-i; j++)的外部。

void bubble(std::vector<int> &arr, int len)
{
    bool flag = true;
    for (int i = 0; i < len-1; i++)
    {
        while (flag)
        {
            flag = false;
            for (int j = 0; j < len - i - 1; j++)
            {
                
                if (arr[j + 1] < arr[j])
                {
                    flag = true;  //只要發(fā)生一次交換就繼續(xù)判斷
                    int temp = arr[j + 1];
                    arr[j + 1] = arr[j];
                    arr[j] = temp;
                }
            }
        }
    }    
}

中值濾波的實現(xiàn):

需要注意的主要問題:

為了能夠遍歷到原圖的邊界,需要對原圖進行邊界擴充,擴充長度為(窗口的長度-1)/ 2。
注意利用窗口對擴充后的圖像遍歷時,起始的位置不是0,而是擴充的長度,因為這時對應(yīng)的才是原圖的第一個像素點,同理結(jié)束的位置也是原圖的最后一個像素點。
另外為了方便將窗口內(nèi)對應(yīng)的像素存到容器中,可以寫兩個循環(huán),循環(huán)長度為窗口的長度與寬度,依次將像素值存入容器中。
最后對容器內(nèi)的像素按照遞增排列后,取中值賦給目標(biāo)矩陣相應(yīng)的位置,而此時的位置也應(yīng)該用i-h,對應(yīng)擴充前的位置。
經(jīng)實踐證明我寫的這兩個算法可有效使用。

void medianFilter(cv::Mat& src, cv::Mat& dst, cv::Size width)
{
    //判斷窗口是否為奇數(shù)
    if (width.width % 2 == 0 || width.height % 2 == 0)
    {
        std::cout << "輸入窗口大小應(yīng)該為奇數(shù),請重新輸入" << endl;
        exit(-1);
    }
    else
    {
        //計算邊界擴充長度
        int h = (width.height - 1) / 2;
        int w = (width.width - 1) / 2;
 
        //對原圖邊界擴充
        cv::Mat src_border;
        cv::copyMakeBorder(src, src_border, h, h, w, w, cv::BORDER_REFLECT_101);
        for (int i = h; i < src.rows + h; i++)
        {
 
            for (int j = w; j < src.cols + w; j++)
            {
                //定義容器存放窗口對應(yīng)的像素
                std::vector <int> v;
                for (int ii = i - h; ii <= i + h; ii++)
                {
                    for (int jj = j - w; jj <= j + w; jj++)
                    {
 
                        v.push_back(src_border.at<uchar>(ii, jj));
                    }
                }
                //對容器內(nèi)存放的像素排序
                int len = width.area();
                bubble(v, len);
                //將中值賦給目標(biāo)圖像對應(yīng)位置
                dst.at<uchar>(i-h, j-w) = v[(len - 1) / 2];
                
            }
        }
        
    }
 
}

到此這篇關(guān)于C++實現(xiàn)中值濾波的示例代碼的文章就介紹到這了,更多相關(guān)C++ 中值濾波內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++單例模式的幾種實現(xiàn)方法詳解

    C++單例模式的幾種實現(xiàn)方法詳解

    這篇文章主要為大家詳細介紹了C++單例模式的幾種實現(xiàn)方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • C++容器適配器的概念與示例

    C++容器適配器的概念與示例

    C++?STL(標(biāo)準(zhǔn)模板庫)是一套功能強大的?C++?模板類,提供了通用的模板類和函數(shù),這些模板類和函數(shù)可以實現(xiàn)多種流行和常用的算法和數(shù)據(jù)結(jié)構(gòu),如向量、鏈表、隊列、棧,今天我們來探究一下stl容器適配器的使用吧
    2023-01-01
  • 詳解C語言中結(jié)構(gòu)體的使用

    詳解C語言中結(jié)構(gòu)體的使用

    結(jié)構(gòu)體是一些值的集合,這些值稱為成員變量,結(jié)構(gòu)體的每個成員可以是不同類型的變量。本文將通過示例為大家詳細講講C語言中結(jié)構(gòu)體的使用,需要的可以參考一下
    2022-07-07
  • C語言數(shù)據(jù)結(jié)構(gòu)之單鏈表與雙鏈表的增刪改查操作實現(xiàn)

    C語言數(shù)據(jù)結(jié)構(gòu)之單鏈表與雙鏈表的增刪改查操作實現(xiàn)

    這篇文章主要為大家詳細介紹了C語言數(shù)據(jù)結(jié)構(gòu)中單鏈表與雙鏈表的增刪改查操作的實現(xiàn),相信大家如果搞懂了本文內(nèi)容,應(yīng)對復(fù)雜的鏈表類的題也就能慢慢鉆研了
    2022-07-07
  • opencv實現(xiàn)讀取視頻保存視頻

    opencv實現(xiàn)讀取視頻保存視頻

    這篇文章主要為大家詳細介紹了opencv實現(xiàn)讀取視頻保存視頻,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • C語言掃雷詳細代碼分步實現(xiàn)流程

    C語言掃雷詳細代碼分步實現(xiàn)流程

    掃雷是電腦上很經(jīng)典的游戲,特意去網(wǎng)上玩了一會,幾次調(diào)試之后,發(fā)現(xiàn)這個比三子棋要復(fù)雜一些,尤其是空白展開算法上和堵截玩家有的一拼,與實際游戲差別較大,不能使用光標(biāo),下面來詳解每一步分析
    2022-02-02
  • C++編程中將引用類型作為函數(shù)參數(shù)的方法指南

    C++編程中將引用類型作為函數(shù)參數(shù)的方法指南

    這篇文章主要介紹了C++編程中將引用類型作為函數(shù)參數(shù)的方法指南,是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2015-09-09
  • C++實現(xiàn)聊天小程序

    C++實現(xiàn)聊天小程序

    這篇文章主要為大家詳細介紹了C++實現(xiàn)聊天小程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • Opencv實現(xiàn)最小外接矩形和圓

    Opencv實現(xiàn)最小外接矩形和圓

    這篇文章主要為大家詳細介紹了Opencv實現(xiàn)最小外接矩形和圓,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • 詳解C++實現(xiàn)拓撲排序算法

    詳解C++實現(xiàn)拓撲排序算法

    拓撲排序是對一個有向無環(huán)圖(Directed Acyclic Graph簡稱DAG)G進行拓撲排序,是將G中所有頂點排成一個線性序列,使得圖中任意一對頂點u和v,若邊(u,v)∈E(G),則u在線性序列中出現(xiàn)在v之前。本文將對其原理進行講解,并且用C++進行實現(xiàn)
    2021-06-06

最新評論