1D Guassian Filter

一維高斯函數(shù):

image.png

??高斯函數(shù)具有線性可分的性質(zhì)押框,即可以通過2個(gè)一維的高斯函數(shù)敢辩,分別對(duì)圖像進(jìn)行縱向和橫向進(jìn)行一次處理,就能得到和二維高斯函數(shù)一致的效果逛万。

??重點(diǎn)在于泳猬,一維高斯函數(shù)處理圖像的復(fù)雜度為 2xy2r,而二維高斯函數(shù)的復(fù)雜度達(dá)到了xy4r^2,一維比二維降低了指數(shù)級(jí)的復(fù)雜度宇植!

QT代碼:

void getWeights1D(double* weights,int r){

    //計(jì)算高斯核權(quán)重

    const float sigma = (r*2+1) / 2.0;

    const float exp = std::exp(1);

    const float sigma2 = sigma*sigma;

    const float dSigma2 = 2*sigma2;

    const float k = 1 / sqrt(2*3.1415926*sigma2);

    double sum = 0;

    for(int i = -r;i<=r;i++){

        int absI =abs(i);

        int it = i+r;

        weights[it] = k * std::pow(exp,-absI*absI / dSigma2);

        sum+= weights[it];

    }

    for(int i = 0;i<=r*2;++i)

        weights[i] /= sum;

}

void MainWindow::GuassianBlur1D(){

    int r = 10;

    double* weights = new double[r*2+1];

    getWeights1D(weights,r);

    int width = m_srcImg.width();

    int height = m_srcImg.height();

    QImage newImg(m_srcImg);

    auto startTime = clock();

    //橫向模糊

    for(int i = 0 ;i<width;++i){

        for(int j =0;j<height;++j){

            float sumR = 0;

            float sumG = 0;

            float sumB = 0;

            for(int x = -r;x<=r;++x){

                int pos = i+x;

                if(pos < 0 || pos >= width)

                   pos = i - x;

                QColor color = m_srcImg.pixel(pos,j);

                sumR += color.red()*weights[x+r];

                sumG += color.green()*weights[x+r];

                sumB += color.blue()*weights[x+r];

            }

            QColor finalColor;

            int r = std::round(sumR);

            int g = std::round(sumG);

            int b = std::round(sumB);

            finalColor.setRed(r);

            finalColor.setGreen(g);

            finalColor.setBlue(b);

            QPoint point(i,j);

            newImg.setPixelColor(point,finalColor);

        }

    }

    //縱向模糊

    for(int i = 0 ;i<width;++i){

        for(int j =0;j<height;++j){

            float sumR = 0;

            float sumG = 0;

            float sumB = 0;

            for(int x = -r;x<=r;++x){

                int pos = j + x;

                if(pos < 0 || pos >= height)

                    pos = j - x;

                QColor color = newImg.pixel(i,pos);

                sumR += color.red()*weights[x+r];

                sumG += color.green()*weights[x+r];

                sumB += color.blue()*weights[x+r];

            }

            QColor finalColor;

            int r = std::round(sumR);

            int g = std::round(sumG);

            int b = std::round(sumB);

            finalColor.setRed(r);

            finalColor.setGreen(g);

            finalColor.setBlue(b);

            QPoint point(i,j);

            newImg.setPixelColor(point,finalColor);

        }

    }

    auto endTime = clock();

    qDebug()<<"模糊耗時(shí)"<<endTime - startTime;

    newImg.save("D:/tag.jpg");

    qDebug()<<"done";

    delete [] weights;

}

void MainWindow::on_btnGaussBlur_clicked()

{

    //GuassianBlur2D();

    GuassianBlur1D();

}

運(yùn)行結(jié)果為:

模糊耗時(shí) 1457

done

比二維高斯函數(shù)快了近10倍得封!

原圖:

原圖

一維高斯模糊效果圖:

一維高斯模糊效果圖

二維高斯模糊效果圖
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌暖哨,老刑警劉巖贱案,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異彩库,居然都是意外死亡威蕉,警方通過查閱死者的電腦和手機(jī)玻粪,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門梗逮,熙熙樓的掌柜王于貴愁眉苦臉地迎上來项秉,“玉大人,你說我怎么就攤上這事慷彤÷Π” “怎么了?”我有些...
    開封第一講書人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵底哗,是天一觀的道長(zhǎng)贷屎。 經(jīng)常有香客問我,道長(zhǎng)艘虎,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任咒吐,我火速辦了婚禮野建,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘恬叹。我一直安慰自己候生,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開白布绽昼。 她就那樣靜靜地躺著唯鸭,像睡著了一般。 火紅的嫁衣襯著肌膚如雪硅确。 梳的紋絲不亂的頭發(fā)上目溉,一...
    開封第一講書人閱讀 49,185評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音菱农,去河邊找鬼缭付。 笑死,一個(gè)胖子當(dāng)著我的面吹牛循未,可吹牛的內(nèi)容都是我干的陷猫。 我是一名探鬼主播,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼的妖,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼绣檬!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起嫂粟,我...
    開封第一講書人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤娇未,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后星虹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體忘蟹,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡飒房,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了媚值。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片狠毯。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖褥芒,靈堂內(nèi)的尸體忽然破棺而出嚼松,到底是詐尸還是另有隱情,我是刑警寧澤锰扶,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布献酗,位于F島的核電站,受9級(jí)特大地震影響坷牛,放射性物質(zhì)發(fā)生泄漏罕偎。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一京闰、第九天 我趴在偏房一處隱蔽的房頂上張望颜及。 院中可真熱鬧,春花似錦蹂楣、人聲如沸俏站。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)肄扎。三九已至,卻和暖如春赁酝,著一層夾襖步出監(jiān)牢的瞬間犯祠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來泰國(guó)打工酌呆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留雷则,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓肪笋,卻偏偏與公主長(zhǎng)得像月劈,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子藤乙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344