數(shù)字圖像處理課程設(shè)計(jì)報(bào)告---直方圖均衡化_第1頁
已閱讀1頁,還剩8頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、<p>  設(shè)計(jì)題目:直方圖均衡化</p><p>  1、直方圖的理論基礎(chǔ):</p><p>  (1)直方圖概念:灰度直方圖表示圖像中每種灰度出現(xiàn)的頻率。</p><p>  (2)直方圖的作用: 反映一幅圖像的灰度分布特性</p><p> ?。?)直方圖的計(jì)算:</p><p>  式中:nk為圖像中

2、出現(xiàn)rk級灰度的像素?cái)?shù),n是圖像像素總數(shù),而nk/n即為頻數(shù)。</p><p>  2、設(shè)計(jì)目的: 產(chǎn)生一幅灰度級分布具有均勻概率密度的圖像,擴(kuò)展像素取值的動態(tài)范圍,達(dá)到了圖象增強(qiáng)的目的。</p><p>  3、直方圖均衡化的效果 : </p><p>  1)變換后直方圖趨向平坦,灰級減少,灰度合并。 </p><p>  2)原始象含

3、有象素?cái)?shù)多的幾個(gè)灰級間隔被拉大了,壓縮的只是象素?cái)?shù)少的幾個(gè)灰度級,實(shí)際視覺能夠接收的信息量大大地增強(qiáng)了,增加了圖象的反差。同時(shí),也增加了圖象的可視粒度。 </p><p>  4、離散情況下的直方圖均衡化的算法:</p><p>  A、列出原始圖像的灰度級 </p><p>  B、統(tǒng)計(jì)各灰度級的像素?cái)?shù)目</p><p>  C、計(jì)

4、算原始圖像直方圖各灰度級的頻數(shù)</p><p>  D、計(jì)算累積分布函數(shù)</p><p>  F、應(yīng)用以下公式計(jì)算映射后的輸出圖像的灰度級,P為輸出圖像灰度級的個(gè)數(shù),其中INT為取整符號:</p><p>  G、用的映射關(guān)系修改原始圖像的灰度級,從而獲得直方圖近似為均勻分布的輸出圖像。</p><p><b>  3、源程序代碼&

5、lt;/b></p><p>  // cqxhistView.cpp : implementation of the CCqxhistView class</p><p>  #include "stdafx.h"</p><p>  #include "cqxhist.h"</p><p> 

6、 #include "cqxhistDoc.h"</p><p>  #include "cqxhistView.h"</p><p>  #ifdef _DEBUG</p><p>  #define new DEBUG_NEW</p><p>  #undef THIS_FILE</p>

7、<p>  static char THIS_FILE[] = __FILE__;</p><p><b>  #endif</b></p><p>  /////////////////////////////////////////////////////////////////////////////</p><p>  /

8、/ CCqxhistView</p><p>  IMPLEMENT_DYNCREATE(CCqxhistView, CView)</p><p>  BEGIN_MESSAGE_MAP(CCqxhistView, CView)</p><p>  //{{AFX_MSG_MAP(CCqxhistView)</p><p>  ON_COMM

9、AND(ID_OPEN_IMAGE, OnOpenImage)</p><p>  ON_COMMAND(ID_HIST_IMAGE, OnHistImage)</p><p>  //}}AFX_MSG_MAP</p><p>  // Standard printing commands</p><p>  ON_COMMAND(ID_F

10、ILE_PRINT, CView::OnFilePrint)</p><p>  ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)</p><p>  ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)</p><p>  END_MESSA

11、GE_MAP()</p><p>  /////////////////////////////////////////////////////////////////////////////</p><p>  // CCqxhistView construction/destruction</p><p>  CCqxhistView::CCqxhistView

12、()</p><p><b>  {</b></p><p>  // TODO: add construction code here</p><p><b>  }</b></p><p>  CCqxhistView::~CCqxhistView()</p><p>&

13、lt;b>  {</b></p><p><b>  }</b></p><p>  BOOL CCqxhistView::PreCreateWindow(CREATESTRUCT& cs)</p><p><b>  {</b></p><p>  // TODO: Mo

14、dify the Window class or styles here by modifying</p><p>  // the CREATESTRUCT cs</p><p>  return CView::PreCreateWindow(cs);</p><p><b>  }</b></p><p>  //

15、///////////////////////////////////////////////////////////////////////////</p><p>  // CCqxhistView drawing</p><p>  void CCqxhistView::OnDraw(CDC* pDC)</p><p><b>  {</b&g

16、t;</p><p>  CCqxhistDoc* pDoc = GetDocument();</p><p>  ASSERT_VALID(pDoc);</p><p>  // TODO: add draw code for native data here</p><p>  if(m_dib.m_bLoaded==true) //判

17、斷是否加載圖像</p><p><b>  {</b></p><p><b>  //獲取圖像寬和高</b></p><p>  int nw=m_dib.GetDIBWidth();</p><p>  int nh=m_dib.GetDIBHeight();</p><p&

18、gt;  // 顯示圖像(具體的參數(shù)見CDIB類的該函數(shù)說明)</p><p>  m_dib.ShowDIB(pDC,10,10,nw,nh,m_dib.m_pDIBData,m_dib.m_pBMI);</p><p>  m_dib.ShowDIB(pDC,400,10,nw,nh,m_dib.m_pDumpDIBData,m_dib.m_pBMI);</p><

19、p><b>  }</b></p><p>  if(m_bHist==true)</p><p><b>  {</b></p><p>  //繪制原圖像的直方圖</p><p>  CString str;</p><p>  int nh=m_dib.GetDI

20、BHeight();</p><p><b>  int i;</b></p><p><b>  //畫坐標(biāo)軸</b></p><p><b>  // 繪制坐標(biāo)軸</b></p><p>  pDC->MoveTo(410,nh+20); //(410,nh+20

21、 )是直方圖的左上角坐標(biāo) </p><p><b>  // 垂直軸</b></p><p>  pDC->LineTo(410,nh+200);//(410,nh+200 )是直方圖的左下角坐標(biāo) </p><p><b>  // 水平軸</b></p><p>  pDC->Line

22、To(710,nh+200);//(710,nh+200 )是直方圖的右下角坐標(biāo) </p><p><b>  // 寫X軸刻度值</b></p><p>  str.Format("0");</p><p>  pDC->TextOut(410, nh+200+10, str);</p><p&g

23、t;  str.Format("50");</p><p>  pDC->TextOut(460, nh+200+10, str);</p><p>  str.Format("100");</p><p>  pDC->TextOut(510, nh+200+10, str);</p><p&

24、gt;  str.Format("150");</p><p>  pDC->TextOut(560, nh+200+10, str);</p><p>  str.Format("200");</p><p>  pDC->TextOut(610, nh+200+10, str);</p><

25、p>  str.Format("255");</p><p>  pDC->TextOut(665, nh+200+10, str);</p><p><b>  // 繪制X軸刻度</b></p><p>  for ( i = 0; i < 256; i += 25)</p><p&

26、gt;<b>  {</b></p><p>  if ((i & 1) == 0)</p><p><b>  {</b></p><p><b>  // 10的倍數(shù)</b></p><p>  pDC->MoveTo(i + 10, nh+200-2);&l

27、t;/p><p>  pDC->LineTo(i + 10, nh+200+2);</p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p><b>  //

28、 10的倍數(shù)</b></p><p>  pDC->MoveTo(i + 10, nh+200-2);</p><p>  pDC->LineTo(i + 10, nh+200+2);</p><p><b>  }</b></p><p><b>  }</b></p

29、><p><b>  // 繪制X軸箭頭</b></p><p>  pDC->MoveTo(705,nh+200-5);</p><p>  pDC->LineTo(710,nh+200);</p><p>  pDC->LineTo(705,nh+200+5);</p><p>

30、<b>  // 繪制y軸箭頭</b></p><p>  pDC->MoveTo(410,nh+20);</p><p>  pDC->LineTo(405,nh+20+5);</p><p>  pDC->MoveTo(410,nh+20);</p><p>  pDC->LineTo(415

31、,nh+20+5);</p><p>  int max=0;</p><p>  for(i=0;i<256;i++)</p><p>  if(m_yuan[i]>max)</p><p>  max=m_yuan[i];</p><p>  for(i=0;i<256;i++)</p&

32、gt;<p><b>  {</b></p><p>  pDC->MoveTo(410+i,nh+200);</p><p>  pDC->LineTo(410+i,nh+200-(m_yuan[i]*160/max));</p><p><b>  }</b></p><p

33、><b>  }</b></p><p>  if(m_bHist==true)</p><p><b>  {</b></p><p><b>  //繪畫直方圖</b></p><p>  CString str;</p><p>  int

34、nh=m_dib.GetDIBHeight();</p><p><b>  int i;</b></p><p><b>  //畫坐標(biāo)軸</b></p><p><b>  // 繪制坐標(biāo)軸</b></p><p>  pDC->MoveTo(10,nh+20);

35、 //(10,nh+20 )是直方圖的左上角坐標(biāo) </p><p><b>  // 垂直軸</b></p><p>  pDC->LineTo(10,nh+200);//(10,nh+200 )是直方圖的左下角坐標(biāo) </p><p><b>  // 水平軸</b></p><p>  pD

36、C->LineTo(310,nh+200);//(310,nh+200 )是直方圖的右下角坐標(biāo) </p><p><b>  // 寫X軸刻度值</b></p><p>  str.Format("0");</p><p>  pDC->TextOut(10, nh+200+10, str);</p>

37、<p>  str.Format("50");</p><p>  pDC->TextOut(60, nh+200+10, str);</p><p>  str.Format("100");</p><p>  pDC->TextOut(110, nh+200+10, str);</p>

38、<p>  str.Format("150");</p><p>  pDC->TextOut(160, nh+200+10, str);</p><p>  str.Format("200");</p><p>  pDC->TextOut(210, nh+200+10, str);</p&g

39、t;<p>  str.Format("255");</p><p>  pDC->TextOut(265, nh+200+10, str);</p><p><b>  // 繪制X軸刻度</b></p><p>  for ( i = 0; i < 256; i += 25)</p>

40、<p><b>  {</b></p><p>  if ((i & 1) == 0)</p><p><b>  {</b></p><p><b>  // 10的倍數(shù)</b></p><p>  pDC->MoveTo(i + 10, nh+2

41、00-2);</p><p>  pDC->LineTo(i + 10, nh+200+2);</p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p><b

42、>  // 10的倍數(shù)</b></p><p>  pDC->MoveTo(i + 10, nh+200-2);</p><p>  pDC->LineTo(i + 10, nh+200+2);</p><p><b>  }</b></p><p><b>  }</b&g

43、t;</p><p><b>  // 繪制X軸箭頭</b></p><p>  pDC->MoveTo(305,nh+200-5);</p><p>  pDC->LineTo(310,nh+200);</p><p>  pDC->LineTo(305,nh+200+5);</p>&

44、lt;p><b>  // 繪制y軸箭頭</b></p><p>  pDC->MoveTo(10,nh+20);</p><p>  pDC->LineTo(5,nh+20+5);</p><p>  pDC->MoveTo(10,nh+20);</p><p>  pDC->LineTo

45、(15,nh+20+5);</p><p>  int max=0;</p><p>  for(i=0;i<256;i++)</p><p>  if(m_hist[i]>max)</p><p>  max=m_hist[i];</p><p>  for(i=0;i<256;i++)<

46、/p><p><b>  {</b></p><p>  pDC->MoveTo(10+i,nh+200);</p><p>  pDC->LineTo(10+i,nh+200-(m_hist[i]*160/max));</p><p><b>  }</b></p><

47、p><b>  }</b></p><p><b>  }</b></p><p>  /////////////////////////////////////////////////////////////////////////////</p><p>  // CCqxhistView printing<

48、;/p><p>  BOOL CCqxhistView::OnPreparePrinting(CPrintInfo* pInfo)</p><p><b>  {</b></p><p>  // default preparation</p><p>  return DoPreparePrinting(pInfo);&l

49、t;/p><p><b>  }</b></p><p>  void CCqxhistView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)</p><p><b>  {</b></p><p>  // TODO: add extra

50、initialization before printing</p><p><b>  }</b></p><p>  void CCqxhistView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)</p><p><b>  {</b></p>

51、<p>  // TODO: add cleanup after printing</p><p><b>  }</b></p><p>  /////////////////////////////////////////////////////////////////////////////</p><p>  // CCqxh

52、istView diagnostics</p><p>  #ifdef _DEBUG</p><p>  void CCqxhistView::AssertValid() const</p><p><b>  {</b></p><p>  CView::AssertValid();</p><p

53、><b>  }</b></p><p>  void CCqxhistView::Dump(CDumpContext& dc) const</p><p><b>  {</b></p><p>  CView::Dump(dc);</p><p><b>  }</

54、b></p><p>  CCqxhistDoc* CCqxhistView::GetDocument() // non-debug version is inline</p><p><b>  {</b></p><p>  ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CCqxhistD

55、oc)));</p><p>  return (CCqxhistDoc*)m_pDocument;</p><p><b>  }</b></p><p>  #endif //_DEBUG</p><p>  //////////////////////////////////////////////////////

56、///////////////////////</p><p>  // CCqxhistView message handlers</p><p>  void CCqxhistView::OnOpenImage() </p><p><b>  {</b></p><p>  // TODO: Add your co

57、mmand handler code here</p><p>  // TODO: Add your command handler code here</p><p>  static char szFilter[]="BMP文件(*.bmp)|*.bmp||"; //定義過濾文件的類型</p><p>  CFileDialog dlg(

58、TRUE,"bmp",NULL,</p><p>  OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,szFilter);//定義文件對話框?qū)ο?lt;/p><p>  CString filename;</p><p>  int ret=dlg.DoModal(); //運(yùn)行打開文件對方框</p><

59、;p>  if(ret==IDOK)</p><p><b>  {</b></p><p>  filename=dlg.GetFileName(); //獲取所選擇圖像的路徑</p><p>  m_dib.LoadFromFile(filename); //加載圖像</p><p>  if(!m

60、_dib.m_bLoaded) //判斷是否加載圖像成功</p><p><b>  {</b></p><p>  AfxMessageBox("圖像打不開");</p><p><b>  return;</b></p><p><b>  }

61、</b></p><p>  for(int i=0;i<256;i++) //初始化直方圖數(shù)組</p><p>  { m_hist[i]=0;</p><p>  m_yuan[i]=0;</p><p><b>  }</b></p><p>  m_bHist=f

62、alse;</p><p><b>  }</b></p><p><b>  {</b></p><p>  int nw=m_dib.GetDIBWidth();</p><p>  int nh=m_dib.GetDIBHeight();</p><p>  for(i

63、nt j=0;j<nh;j++)</p><p>  for(int i=0;i<nw;i++)</p><p><b>  {</b></p><p>  BYTE temp=m_dib.m_pdata[j*nw+i];</p><p>  m_yuan[temp]++;</p><p&

64、gt;<b>  }</b></p><p><b>  }</b></p><p>  Invalidate(1);//刷新屏幕</p><p><b>  }</b></p><p>  void CCqxhistView::OnHistImage() </p>

65、;<p><b>  {</b></p><p>  // TODO: Add your command handler code here</p><p>  //功能:實(shí)現(xiàn)直方圖均衡化</p><p>  //////////////////////////</p><p>  //判斷圖像是否打開,沒

66、打開,則彈出提示框并退出函數(shù)</p><p>  if(!m_dib.m_bLoaded) </p><p><b>  {</b></p><p>  AfxMessageBox("圖像還打開,請先打開圖像!");</p><p><b>  return;</b></

67、p><p><b>  }</b></p><p><b>  //獲取圖像寬和高</b></p><p>  int nw=m_dib.GetDIBWidth();</p><p>  int nh=m_dib.GetDIBHeight();</p><p>  int i,j

68、,k;</p><p>  int count[256]={0};//定義一個(gè)數(shù)組,用于存放灰度級個(gè)數(shù)</p><p>  float p[256];//定義一個(gè)數(shù)組,用于存放灰度級出現(xiàn)頻率</p><p>  //對圖像進(jìn)行直方圖均衡化處理</p><p>  for(i=0;i<nh;i++)</p><p>

69、;  for(j=0;j<nw;j++)</p><p><b>  {</b></p><p>  k=m_dib.m_pdata[i*nw+j];//計(jì)算灰度級個(gè)數(shù)</p><p>  count[k]++;</p><p><b>  }</b></p><p>

70、  for(k=0;k<256;k++)</p><p>  p[k]=count[k]/(nw*nh*1.0f);</p><p>  float c[256]={0};</p><p>  float sum=0.0;</p><p>  int ngray[256];//新的灰度級</p><p>  fo

71、r(k=0;k<256;k++)//計(jì)算累積頻率</p><p><b>  {</b></p><p>  sum+=p[k];</p><p><b>  c[k]=sum;</b></p><p>  ngray[k]=(int)(255.0*c[k]+0.5);</p>

72、<p><b>  }</b></p><p>  for(i=0;i<nh;i++)</p><p>  for(j=0;j<nw;j++)</p><p><b>  {</b></p><p>  k=m_dib.m_pdata[i*nw+j];</p>&

73、lt;p>  m_dib.m_pdata[i*nw+j]=ngray[k];</p><p><b>  }</b></p><p><b>  {</b></p><p>  int nw=m_dib.GetDIBWidth();</p><p>  int nh=m_dib.GetDIBH

74、eight();</p><p>  for(int j=0;j<nh;j++)</p><p>  for(int i=0;i<nw;i++)</p><p><b>  {</b></p><p>  BYTE temp=m_dib.m_pdata[j*nw+i];</p><p>

75、;  m_hist[temp]++;</p><p><b>  }</b></p><p><b>  }</b></p><p>  //將修改的m_pdata的數(shù)據(jù)賦值給m_pDIBData,以顯示修改的結(jié)果</p><p>  m_dib.UpdateData();</p>&

76、lt;p>  m_bHist=true;</p><p>  //將修改的m_pdata的數(shù)據(jù)賦值給m_pDIBData,以顯示修改的結(jié)果</p><p>  m_dib.UpdateData();</p><p><b>  //刷新屏幕</b></p><p>  Invalidate(); </p>

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論