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

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

圖像直方圖

1. 直方圖演示

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

圖像直方圖圖形化顯示不同的像素值在不同的強度值上的出現(xiàn)頻率,對于灰度圖像來說強度范圍為[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)灰度映射從而達到圖像增強目的的方法。
直方圖均衡化通常是對圖像灰度值進行歸一化的一個非常好的方法,并且可以增強圖像的對比度。

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

直方圖均衡化算法.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)用。除此之外,直方圖還能做圖像的相似度匹配。

直方圖均衡化則用于增強圖片,利于人的視覺效果或便于機器識別。

總結(jié)

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

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

cv4j.png

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

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

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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,461評論 6 532
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,538評論 3 417
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,423評論 0 375
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,991評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 71,761評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,207評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,268評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,419評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,959評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,782評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,983評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,528評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,222評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,653評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,901評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,678評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 47,978評論 2 374

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