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

C語(yǔ)言數(shù)字圖像處理之直方圖均衡化

 更新時(shí)間:2021年10月26日 09:30:22   作者:ZhaoDongyu_AK47  
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言數(shù)字圖像處理之直方圖均衡化,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C語(yǔ)言直方圖均衡化的具體代碼,供大家參考,具體內(nèi)容如下

原理

直方圖均衡化(Histogram Equalization) 又稱(chēng)直方圖平坦化,實(shí)質(zhì)上是對(duì)圖像進(jìn)行非線性拉伸,重新分配圖像象元值,使一定灰度范圍內(nèi)象元值的數(shù)量大致相等。這樣,原來(lái)直方圖中間的峰頂部分對(duì)比度得到增強(qiáng),而兩側(cè)的谷底部分對(duì)比度降低,輸出圖像的直方圖是一個(gè)較平的分段直方圖:如果輸出數(shù)據(jù)分段值較小的話,會(huì)產(chǎn)生粗略分類(lèi)的視覺(jué)效果。

直方圖是表示數(shù)字圖像中每一灰度出現(xiàn)頻率的統(tǒng)計(jì)關(guān)系。直方圖能給出圖像灰度范圍、每個(gè)灰度的頻度和灰度的分布、整幅圖像的平均明暗和對(duì)比度等概貌性描述?;叶戎狈綀D是灰度級(jí)的函數(shù), 反映的是圖像中具有該灰度級(jí)像素的個(gè)數(shù), 其橫坐標(biāo)是灰度級(jí)r, 縱坐標(biāo)是該灰度級(jí)出現(xiàn)的頻率( 即像素的個(gè)數(shù)) pr( r) , 整個(gè)坐標(biāo)系描述的是圖像灰度級(jí)的分布情況, 由此可以看出圖像的灰度分布特性, 即若大部分像素集中在低灰度區(qū)域, 圖像呈現(xiàn)暗的特性; 若像素集中在高灰度區(qū)域, 圖像呈現(xiàn)亮的特性?;叶葦?shù)字圖像是每個(gè)像素只有一個(gè)采樣顏色的圖像。這類(lèi)圖像通常顯示為從最暗黑色到最亮的白色的灰度。灰度圖像與黑白圖像不同,在計(jì)算機(jī)圖像領(lǐng)域中黑白圖像只有黑白

實(shí)現(xiàn)

流程:

1)統(tǒng)計(jì)每個(gè)灰度級(jí)像素點(diǎn)的個(gè)數(shù)
2)計(jì)算灰度分布密度
3)計(jì)算累計(jì)直方圖分布
4)累計(jì)分布取整,保存計(jì)算出來(lái)的灰度映射關(guān)系
處理圖片規(guī)格800*600 8位灰度單通道

原圖

直方圖均衡化

分析:本次實(shí)驗(yàn)中,我故意把原圖調(diào)暗,進(jìn)行直方圖均衡化后可以明顯感受到整幅圖像亮度增大了,而且某些細(xì)節(jié)方面更加突出。

出現(xiàn)問(wèn)題

最初進(jìn)行直方圖均衡化時(shí),輸出結(jié)果如下:

經(jīng)分析,是沒(méi)有對(duì)數(shù)組初始化置零導(dǎo)致的。Hist數(shù)組是進(jìn)行一個(gè)統(tǒng)計(jì)像素點(diǎn)個(gè)數(shù)的數(shù)組,最初倘若不置零,結(jié)果必然毫無(wú)意義。

故而添加數(shù)組內(nèi)存置零的操作:

經(jīng)測(cè)試,問(wèn)題解決。

附代碼

#include <stdio.h>  
#include <stdlib.h>  
#include <memory.h>
#define height  600  
#define width   800
typedef unsigned char  BYTE;    // 定義BYTE類(lèi)型,占1個(gè)字節(jié)

int main(void)
{
    FILE *fp = NULL;
    //BYTE Pic[height][width];
    BYTE *ptr;
    BYTE **Pic = new BYTE *[height];
    for (int i = 0; i != height; ++i)
    {
        Pic[i] = new BYTE[width];
    }
    fp = fopen("weiminglake_huidu.raw", "rb");       
    ptr = (BYTE*)malloc(width * height * sizeof(BYTE));//創(chuàng)建內(nèi)存
    for (int i = 0; i < height; i++)
    {
        for (int j = 0; j < width; j++)
        {
            fread(ptr, 1, 1, fp);
            Pic[i][j] = *ptr;  // 把圖像輸入到2維數(shù)組中,變成矩陣型式  
            ptr++;
        }
    }
    fclose(fp);
    
    int hist[256];
    float  fpHist[256];
    float eqHistTemp[256];
    int eqHist[256];
    int size = height *width;
    int i, j;
    memset(&hist, 0x00, sizeof(int) * 256);
    memset(&fpHist, 0x00, sizeof(float) * 256);
    memset(&eqHistTemp, 0x00, sizeof(float) * 256);
    
    for (i = 0; i < height; i++) //計(jì)算差分矩陣直方圖  直方圖  統(tǒng)計(jì)每個(gè)灰度級(jí)像素點(diǎn)的個(gè)數(shù)
    {
        for (j = 0; j < width; j++)
        {
            unsigned char GrayIndex = Pic[i][j];
            hist[GrayIndex] ++;
        }
    }
    for (i = 0; i< 256; i++)  // 計(jì)算灰度分布密度
    {
        fpHist[i] = (float)hist[i] / (float)size;
    }
    for (i = 0; i< 256; i++)  // 計(jì)算累計(jì)直方圖分布
    {
        if (i == 0)
        {
            eqHistTemp[i] = fpHist[i];
        }
        else
        {
            eqHistTemp[i] = eqHistTemp[i - 1] + fpHist[i];
        }
    }
    //累計(jì)分布取整,保存計(jì)算出來(lái)的灰度映射關(guān)系
    for (i = 0; i< 256; i++)
    {
        eqHist[i] = (int)(255.0 * eqHistTemp[i] + 0.5);
    }
    for (i = 0; i < height; i++) //進(jìn)行灰度映射均衡化
    {
        for (j = 0; j < width; j++)
        {
            unsigned char GrayIndex = Pic[i][j];
            Pic[i][j] = eqHist[GrayIndex];
        }
    }
    fp = fopen("output.raw", "wb");
    for (i = 0; i < height; i++)
    {
        for (j = 0; j < width; j++)
        {
            fwrite(&Pic[i][j], 1, 1, fp);
        }
    }
    fclose(fp);
    return 0;
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • operator new在C++中的各種寫(xiě)法總結(jié)

    operator new在C++中的各種寫(xiě)法總結(jié)

    這篇文章并不是一個(gè)綜合的手冊(cè),而是一個(gè)C++中各種內(nèi)存分配方法的概述。它面向已經(jīng)很熟悉C++語(yǔ)言的讀者
    2013-09-09
  • 聊聊Qt+OpenCV聯(lián)合開(kāi)發(fā)之圖像的創(chuàng)建與賦值問(wèn)題

    聊聊Qt+OpenCV聯(lián)合開(kāi)發(fā)之圖像的創(chuàng)建與賦值問(wèn)題

    這篇文章主要介紹了Qt+OpenCV聯(lián)合開(kāi)發(fā)之圖像的創(chuàng)建與賦值問(wèn)題,給大家介紹了圖像的克隆及拷貝問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-01-01
  • C++實(shí)現(xiàn)鄰接表頂點(diǎn)的刪除

    C++實(shí)現(xiàn)鄰接表頂點(diǎn)的刪除

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)鄰接表頂點(diǎn)的刪除,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • C++進(jìn)程共享數(shù)據(jù)封裝成類(lèi)實(shí)例

    C++進(jìn)程共享數(shù)據(jù)封裝成類(lèi)實(shí)例

    這篇文章主要介紹了C++進(jìn)程共享數(shù)據(jù)封裝成類(lèi)的方法,以實(shí)例形式講述了其封裝代碼與具體用法,具有一定的實(shí)用價(jià)值,需要的朋友可以參考下
    2014-10-10
  • C++實(shí)現(xiàn)高性能轉(zhuǎn)換大小寫(xiě)算法示例

    C++實(shí)現(xiàn)高性能轉(zhuǎn)換大小寫(xiě)算法示例

    大小寫(xiě)轉(zhuǎn)換是我們作為一名程序員經(jīng)常會(huì)遇到,也必須要會(huì)的一個(gè)功能,下面這篇文章主要給大家介紹了關(guān)于C++實(shí)現(xiàn)高性能轉(zhuǎn)換大小寫(xiě)算法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2018-01-01
  • C語(yǔ)言獲取文件長(zhǎng)度的方法

    C語(yǔ)言獲取文件長(zhǎng)度的方法

    這篇文章主要介紹了C語(yǔ)言獲取文件長(zhǎng)度的相關(guān)知識(shí),包括使用標(biāo)準(zhǔn)庫(kù)方法和使用Linux系統(tǒng)調(diào)用,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • C++實(shí)現(xiàn)本地TCP通訊的示例代碼

    C++實(shí)現(xiàn)本地TCP通訊的示例代碼

    這篇文章主要為大家詳細(xì)介紹了C++如何利用TCP技術(shù),實(shí)現(xiàn)本地ROS1和ROS2的通訊,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-02-02
  • visual?studio?將編譯后的dll等文件自動(dòng)復(fù)制到指定目錄的方法

    visual?studio?將編譯后的dll等文件自動(dòng)復(fù)制到指定目錄的方法

    這篇文章主要介紹了visual?studio?將編譯后的dll等文件自動(dòng)復(fù)制到指定目錄,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-03-03
  • C語(yǔ)言深入回顧講解結(jié)構(gòu)體對(duì)齊

    C語(yǔ)言深入回顧講解結(jié)構(gòu)體對(duì)齊

    C 數(shù)組允許定義可存儲(chǔ)相同類(lèi)型數(shù)據(jù)項(xiàng)的變量,結(jié)構(gòu)是 C 編程中另一種用戶(hù)自定義的可用的數(shù)據(jù)類(lèi)型,它允許你存儲(chǔ)不同類(lèi)型的數(shù)據(jù)項(xiàng),本篇讓我們來(lái)了解C 的結(jié)構(gòu)體內(nèi)存對(duì)齊
    2022-06-06
  • C語(yǔ)言中查詢(xún)進(jìn)程信號(hào)是否被遮罩或擱置的簡(jiǎn)單方法

    C語(yǔ)言中查詢(xún)進(jìn)程信號(hào)是否被遮罩或擱置的簡(jiǎn)單方法

    這篇文章主要介紹了C語(yǔ)言中查詢(xún)進(jìn)程信號(hào)是否被遮罩或擱置的簡(jiǎn)單方法,包括sigprocmask函數(shù)和sigpending函數(shù)的簡(jiǎn)介,需要的朋友可以參考下
    2015-09-09

最新評(píng)論