圖像直方圖與直方圖均衡化

圖像直方圖(英語:Image Histogram)是用以表示數(shù)字圖像中亮度分布的直方圖,標(biāo)繪了圖像中每個亮度值的像素數(shù)穆碎“伤拢可以借助觀察該直方圖了解需要如何調(diào)整亮度分布隅津。這種直方圖中,橫坐標(biāo)的左側(cè)為純黑绣溜、較暗的區(qū)域慷彤,而右側(cè)為較亮、純白的區(qū)域怖喻。因此底哗,一張較暗圖片的圖像直方圖中的數(shù)據(jù)多集中于左側(cè)和中間部分;而整體明亮锚沸、只有少量陰影的圖像則相反跋选。
很多數(shù)碼相機(jī)提供圖像直方圖功能,拍攝者可以通過觀察圖像直方圖了解到當(dāng)前圖像是否過分曝光或者曝光不足哗蜈。
計算機(jī)視覺領(lǐng)域常借助圖像直方圖來實現(xiàn)圖像的二值化.

圖像直方圖

1. 直方圖演示

圖像的直方圖用來表征該圖像像素值的分布情況前标。用一定數(shù)目的小區(qū)間(bin)來指定表征像素值的范圍,每個小區(qū)間會得到落入該小區(qū)間表示范圍的像素數(shù)目。

圖像直方圖圖形化顯示不同的像素值在不同的強(qiáng)度值上的出現(xiàn)頻率距潘,對于灰度圖像來說強(qiáng)度范圍為[0~255]之間炼列,對于RGB的彩色圖像可以獨立顯示三種顏色的圖像直方圖。

直方圖演示.png
        final Bitmap bitmap = BitmapFactory.decodeResource(res, R.drawable.test_hist2);
        image0.setImageBitmap(bitmap);

        CV4JImage cv4jImage = new CV4JImage(bitmap);
        image1.setImageBitmap(drawHist(cv4jImage.getProcessor(),new Paint()));

drawHist()用于展示圖像的直方圖音比,并把它轉(zhuǎn)換成bitmap唯鸭。

    private Bitmap drawHist(ImageProcessor imageProcessor, Paint paint) {

        CalcHistogram calcHistogram = new CalcHistogram();
        int bins = 127;
        int[][] hist = new int[imageProcessor.getChannels()][bins];
        calcHistogram.calcHist(imageProcessor,bins,hist,true);
        Bitmap bm = Bitmap.createBitmap(imageProcessor.getWidth(),imageProcessor.getHeight(), Bitmap.Config.ARGB_8888);
        Canvas canvas = new Canvas(bm);
        paint.setColor(Color.BLACK);
        paint.setStyle(Paint.Style.FILL_AND_STROKE);
        canvas.drawRect(0,0,imageProcessor.getWidth(),imageProcessor.getHeight(),paint);

        float step = imageProcessor.getWidth()/127;
        int xoffset;
        int yoffset;
        int channels = imageProcessor.getChannels();

        int h = imageProcessor.getHeight();
        int[] colors = new int[]{Color.argb(77,255,0,0),Color.argb(77,0,255,0),Color.argb(77,0,0,255)};
        for (int i=0;i<channels;i++) {

            paint.setColor(colors[i]);
            for (int j=0;j<bins;j++) {

                xoffset = (int)(j*step);
                yoffset = hist[i][j]*h/255;
                canvas.drawRect(xoffset,h-yoffset,xoffset+step,h,paint);
            }
        }

        return bm;
    }

如果對CalcHistogram感興趣,可以查看cv4j的具體實現(xiàn)硅确。

2. 直方圖均衡化

直方圖均衡化(histogram equalization)是一種借助直方圖變換實現(xiàn)灰度映射從而達(dá)到圖像增強(qiáng)目的的方法目溉。
直方圖均衡化通常是對圖像灰度值進(jìn)行歸一化的一個非常好的方法,并且可以增強(qiáng)圖像的對比度菱农。

基本思想:把原始圖的直方圖變換成為均勻分布的形式缭付,這樣,就增加了像素灰度值的動態(tài)范圍循未,從而達(dá)到增強(qiáng)圖像整體對比度的效果陷猫。

直方圖均衡化算法.png
直方圖均值化.png
        Resources res = getResources();
        final Bitmap bitmap = BitmapFactory.decodeResource(res, R.drawable.test_hist);
        image0.setImageBitmap(bitmap);

        CV4JImage cv4jImage0 = new CV4JImage(bitmap);
        ImageProcessor imageProcessor = cv4jImage0.convert2Gray().getProcessor();
        Paint paint = new Paint();
        calcImage0.setImageBitmap(drawHist(imageProcessor,paint));

        CV4JImage cv4jImage = new CV4JImage(bitmap);
        imageProcessor = cv4jImage.convert2Gray().getProcessor();
        if (imageProcessor instanceof ByteProcessor) {
            EqualHist equalHist = new EqualHist();
            equalHist.equalize((ByteProcessor) imageProcessor);
            image1.setImageBitmap(cv4jImage.getProcessor().getImage().toBitmap());
            paint = new Paint();
            calcImage1.setImageBitmap(drawHist(imageProcessor,paint));
        }
    private Bitmap drawHist(ImageProcessor imageProcessor,Paint paint) {

        CalcHistogram calcHistogram = new CalcHistogram();
        int bins = 127;
        int[][] hist = new int[imageProcessor.getChannels()][bins];
        calcHistogram.calcHist(imageProcessor,bins,hist,true);
        Bitmap bm = Bitmap.createBitmap(512,512, Bitmap.Config.ARGB_8888);
        Canvas canvas = new Canvas(bm);
        paint.setColor(Color.BLACK);
        paint.setStyle(Paint.Style.FILL_AND_STROKE);
        canvas.drawRect(0,0,512,512,paint);

        float step = 512.0f/127;
        int xoffset;
        int yoffset;
        int channels = imageProcessor.getChannels();

        int[] colors = new int[]{Color.argb(127,255,0,0),Color.argb(127,0,255,0),Color.argb(127,0,0,255)};
        for (int i=0;i<channels;i++) {

            paint.setColor(colors[i]);
            for (int j=0;j<bins;j++) {

                xoffset = (int)(j*step);
                yoffset = hist[i][j]*512/255;
                canvas.drawRect(xoffset,512-yoffset,xoffset+step,512,paint);
            }
        }

        return bm;
    }

同樣秫舌,如果對EqualHist感興趣,可以查看cv4j的具體實現(xiàn)绣檬。

它們能做什么足陨?

圖像是由像素構(gòu)成的,然而直方圖能夠反映像素的分布情況娇未,可以作為是圖像一個很重要的特征墨缘。在實際開發(fā)中,圖像直方圖在特征提取零抬、圖像匹配等方面都有很好的應(yīng)用镊讼。除此之外,直方圖還能做圖像的相似度匹配平夜。

直方圖均衡化則用于增強(qiáng)圖片蝶棋,利于人的視覺效果或便于機(jī)器識別。

總結(jié)

CalcHistogram 和 EqualHist 是cv4j中直方圖相關(guān)操作的類忽妒。

cv4jgloomyfish和我一起開發(fā)的圖像處理庫玩裙,純java實現(xiàn),目前還處于早期的版本段直。

cv4j.png

上周末我們開始做直方圖的相關(guān)操作烘挫,預(yù)計下周能做完這個模塊清酥。

另外蝇闭,在Google I/O之后溜在,我們第一時間便更新了cv4j中的rxcv4j模塊。該模塊顧名思義是對cv4j使用RxJava進(jìn)行封裝京闰,我們將該模塊用Kotlin重寫颜及,也算是趕了一回時髦:)。

該系列先前的文章:
模擬油畫和鉛筆畫的濾鏡效果
二值圖像分析之輪廓分析
基于邊緣保留濾波實現(xiàn)人臉磨皮的算法
二值圖像分析:案例實戰(zhàn)(文本分離+硬幣計數(shù))
Java實現(xiàn)高斯模糊和圖像的空間卷積
Java實現(xiàn)圖片濾鏡的高級玩法
Java實現(xiàn)圖片的濾鏡效果

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蹂楣,一起剝皮案震驚了整個濱河市俏站,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌痊土,老刑警劉巖肄扎,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異赁酝,居然都是意外死亡犯祠,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進(jìn)店門酌呆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來衡载,“玉大人,你說我怎么就攤上這事隙袁√涤椋” “怎么了弃榨?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長梨睁。 經(jīng)常有香客問我鲸睛,道長,這世上最難降的妖魔是什么坡贺? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任官辈,我火速辦了婚禮,結(jié)果婚禮上拴念,老公的妹妹穿的比我還像新娘钧萍。我一直安慰自己褐缠,他們只是感情好政鼠,可當(dāng)我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著队魏,像睡著了一般公般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上胡桨,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天官帘,我揣著相機(jī)與錄音,去河邊找鬼昧谊。 笑死刽虹,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的呢诬。 我是一名探鬼主播涌哲,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼尚镰!你這毒婦竟也來了阀圾?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤狗唉,失蹤者是張志新(化名)和其女友劉穎初烘,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體分俯,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡肾筐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了缸剪。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片局齿。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖橄登,靈堂內(nèi)的尸體忽然破棺而出抓歼,到底是詐尸還是另有隱情讥此,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布谣妻,位于F島的核電站萄喳,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏蹋半。R本人自食惡果不足惜他巨,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望减江。 院中可真熱鬧染突,春花似錦、人聲如沸辈灼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽巡莹。三九已至,卻和暖如春降宅,著一層夾襖步出監(jiān)牢的瞬間骂远,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工腰根, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留激才,地道東北人。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓额嘿,卻偏偏與公主長得像瘸恼,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子岩睁,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容