對圖像進行均值濾波課程設計_第1頁
已閱讀1頁,還剩9頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、<p><b>  圖形圖像處理與應用</b></p><p>  題 目 對圖像進行均值濾波 </p><p><b>  院(系)專業(yè)級班</b></p><p>  學 號 </p>&l

2、t;p>  姓 名 </p><p>  指導教師 </p><p>  成 績 </p><p>  完成時間 2012 年 06 月</p><p><b>  均 值 濾 波</b></p>

3、<p><b>  均值濾波的原理</b></p><p>  均值濾波是典型的線性濾波算法,它是指在圖像上對目標像素給一個模板,該模板包括了其周圍的臨近像素(以目標象素為中心的周圍8個象素,構成一個濾波模板,即去掉目標象素本身)。再用模板中的全體像素的平均值來代替原來像素值。</p><p>  均值濾波也稱為線性濾波,其采用的主要方法為鄰域平均法。線

4、性濾波的基本原理是用均值代替原圖像中的各個像素值,即對待處理的當前像素點(x,y),選擇一個模板,該模板由其近鄰的若干像素組成,求模板中所有像素的均值,再把該均值賦予當前像素點(x,y),作為處理后圖像在該點上的灰度個g(x,y),即個g(x,y)=1/m ∑f(x,y) m為該模板中包含當前像素在內(nèi)的像素總個數(shù)。</p><p><b>  均值濾波的實現(xiàn)算法</b></p>

5、<p>  均值濾波將每個像素點的灰度值設置為以該點為中心的鄰域窗口內(nèi)的所有像素灰度值的平均值,以實現(xiàn)像素的平滑,達到圖像去噪的目的。設輸入圖像信號為f(x,y),去噪處理后的輸出圖像為g(x,y),則有g(x,y)= | f(x,y)- ¬u (x,y)| 。 </p><p>  通過上式可以達到消除信號噪聲的目的,但對于其中的每一個灰度值來說,都需要按照式求取以該點中心的鄰域窗口內(nèi)所有

6、像素的平均值,對長度為(2n+1)的信號來說,需要進行(2n+1)次加法、一次乘法、一次除法。所以說,均值計算占用了均值濾波處理的大量時間費用。</p><p><b>  均值濾波應用</b></p><p>  均值濾波就是在一定的時間內(nèi)對輸入信號進行連續(xù)的采樣然后求出幾次采樣值的平均值。設x0...xi是采樣值,yk是對采樣進行平均值濾波的輸出值,其關系如下:&

7、lt;/p><p>  在工程應用中,均值濾波對于周期性的干擾有很好的抑制作用,另外,均值濾波對于熱噪聲產(chǎn)生的干擾也有很好的抑制作用。</p><p>  n的取值取決n系統(tǒng)的參數(shù),如果系統(tǒng)對輸入的靈敏度要求很高,則n的取值應比較小,如果系統(tǒng)的輸入變化速度不快,系統(tǒng)對輸入的靈敏性要求也不是很高,為了抑制干擾,提高輸入的精度,可以將n取得比較大。</p><p><

8、b>  均值濾波器</b></p><p>  均值濾波器也是平滑線性濾波器,常用于模糊處理和減小噪聲,模糊處理</p><p>  經(jīng)常用于預處理。例如,在提取大的目標之前除去信號中的一些瑣碎細節(jié)、橋接直線或曲線的縫隙。通過線性濾波器和非線性濾波器可以減小噪聲。</p><p><b>  程序設計:</b></p&g

9、t;<p><b>  具體代碼如下:</b></p><p>  // MyDIPView.cpp : implementation of the CMyDIPView class</p><p><b>  //</b></p><p>  #include "stdafx.h"<

10、;/p><p>  #include "MyDIP.h"</p><p>  #include "MyDIPDoc.h"</p><p>  #include "MyDIPView.h"</p><p>  #include "math.h"</p>&

11、lt;p>  #ifdef _DEBUG</p><p>  #define new DEBUG_NEW</p><p>  #undef THIS_FILE</p><p>  static char THIS_FILE[] = __FILE__;</p><p><b>  #endif</b></p&g

12、t;<p>  /*****************************************************</p><p><b>  * </b></p><p><b>  * 函數(shù)名稱:</b></p><p>  * Template:</p><p

13、><b>  *</b></p><p><b>  * 參數(shù):</b></p><p>  * HDIB hDIB -圖像的句柄</p><p>  * double *tem -指向模板的指針</p><p>  *

14、int tem_w -模板的寬度</p><p>  * int tem_h -模板的高度</p><p>  * double xishu -模板的系數(shù)</p><p>  * </p><p><b>  * 功能:</b

15、></p><p>  * 對圖像進行模板操作</p><p><b>  *</b></p><p><b>  * 說明:</b></p><p>  * 為處理方便起見,模板的寬度和高度都應為奇數(shù)</p><p>  **************

16、*****************************************/</p><p>  HDIB Template(HDIB hDIB,double * tem ,int tem_w,int tem_h,double xishu)</p><p><b>  {</b></p><p><b>  //統(tǒng)計中間值&l

17、t;/b></p><p>  double sum;</p><p>  //指向圖像起始位置的指針</p><p>  BYTE *lpDIB=(BYTE*)::GlobalLock((HGLOBAL) hDIB);</p><p>  //指向象素起始位置的指針</p><p>  BYTE *pScrBu

18、ff =(BYTE*)::FindDIBBits((char*)lpDIB);</p><p>  //獲取圖像的顏色信息</p><p>  int numColors=(int) ::DIBNumColors((char *)lpDIB);</p><p>  //如果圖像不是256色返回</p><p>  if (numColors!

19、=256) </p><p><b>  { </b></p><p><b>  //解除鎖定</b></p><p>  ::GlobalUnlock((HGLOBAL) hDIB);</p><p><b>  //返回</b></p><p>

20、;  return(hDIB);</p><p><b>  }</b></p><p>  //將指向圖像象素起始位置的指針,賦值給指針變量</p><p>  BYTE* oldbuf = pScrBuff;</p><p><b>  //循環(huán)變量</b></p><p&g

21、t;  int i,j,m,n;</p><p>  int w, h, dw;</p><p><b>  //獲取圖像的寬度</b></p><p>  w = (int) ::DIBWidth((char *)lpDIB);</p><p><b>  //獲取圖像的高度</b></p&

22、gt;<p>  h = (int) ::DIBHeight((char *)lpDIB);</p><p>  //計算圖像每行的字節(jié)數(shù)</p><p>  dw = (w+3)/4*4; </p><p>  //建立一個和原圖像大小相同的25色灰度位圖</p><p>  HDIB newhDIB=NewDIB(

23、w,h,8); </p><p>  //指向新的位圖的指針</p><p>  BYTE *newlpDIB=(BYTE*)::GlobalLock((HGLOBAL) newhDIB);</p><p>  //指向新的位圖的象素起始位置的指針 </p><p>  BYTE *destBuf = (BYTE*)FindDIBBits(

24、(char *)newlpDIB);</p><p>  //將指向新圖像象素起始位置的指針,賦值給指針變量</p><p>  BYTE *newbuf=destBuf; </p><p><b>  //對圖像進行掃描</b></p><p><b>  //行 </b></p>

25、<p>  for(i=0;i<h;i++)</p><p><b>  { </b></p><p><b>  //列</b></p><p>  for(j=0;j<w;j++)</p><p><b>  { </b></p>

26、<p>  //為統(tǒng)計變量賦初始值</p><p><b>  sum=0;</b></p><p>  //對于圖像的4個邊框的象素保持原灰度不變</p><p>  if( j<((tem_w-1)/2) || j>(w-(tem_w+1)/2) || i<((tem_h-1)/2) || i>(h-(te

27、m_h+1)/2) )</p><p>  *(newbuf+i*dw+j)=*(oldbuf+i*dw+j);</p><p>  //對于其他的象素進行模板操作</p><p><b>  else </b></p><p><b>  { </b></p><p>  

28、//將點(i,j)點作為模板的中心</p><p>  for(m=i-((tem_h-1)/2);m<=i+((tem_h-1)/2);m++)</p><p><b>  {</b></p><p>  for(n=j-((tem_w-1)/2);n<=j+((tem_w-1)/2);n++)</p><p&

29、gt;  //將以點(i,j)為中心,與模板大小相同的范圍內(nèi)的象素與模板對用位置的系數(shù)</p><p>  //進行相乘并線形疊加</p><p>  sum+=*(oldbuf+m*dw+n)* tem[(m-i+((tem_h-1)/2))*tem_w+n-j+((tem_w-1)/2)];</p><p><b>  }</b></

30、p><p>  //將結果乘上總的模板系數(shù)</p><p>  sum=(int)sum*xishu;</p><p><b>  //計算絕對值</b></p><p>  sum = fabs(sum);</p><p>  //如果小于0,強制賦值為0</p><p> 

31、 if(sum<0) </p><p><b>  sum=0;</b></p><p>  //如果大于255,強制賦值為255</p><p>  if(sum>255)</p><p><b>  sum=255;</b></p><p>  //將

32、計算的結果放到新的位圖的相應位置</p><p>  *(newbuf+i*dw+j)=sum;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  } </b></p><p><b>

33、  //解除鎖定</b></p><p>  ::GlobalUnlock((HGLOBAL)hDIB);</p><p>  //返回新的位圖的句柄</p><p>  return(newhDIB);</p><p><b>  }</b></p><p>  //////////

34、///////////////////////////////////////////////////////////////////</p><p>  // CMyDIPView</p><p>  IMPLEMENT_DYNCREATE(CMyDIPView, CScrollView)</p><p>  BEGIN_MESSAGE_MAP(CMyDIPVie

35、w, CScrollView)</p><p>  //{{AFX_MSG_MAP(CMyDIPView)</p><p>  ON_COMMAND(ID_MENUITEM32778, OnMenuitem32778)</p><p>  //}}AFX_MSG_MAP</p><p>  // Standard printing comma

36、nds</p><p>  ON_COMMAND(ID_FILE_PRINT, CScrollView::OnFilePrint)</p><p>  ON_COMMAND(ID_FILE_PRINT_DIRECT, CScrollView::OnFilePrint)</p><p>  ON_COMMAND(ID_FILE_PRINT_PREVIEW, CScro

37、llView::OnFilePrintPreview)</p><p>  END_MESSAGE_MAP()</p><p>  /////////////////////////////////////////////////////////////////////////////</p><p>  // CMyDIPView construction/des

38、truction</p><p>  CMyDIPView::CMyDIPView()</p><p><b>  {</b></p><p>  // TODO: add construction code here</p><p><b>  }</b></p><p>

39、  CMyDIPView::~CMyDIPView()</p><p><b>  {</b></p><p><b>  }</b></p><p>  BOOL CMyDIPView::PreCreateWindow(CREATESTRUCT& cs)</p><p><b>

40、  {</b></p><p>  // TODO: Modify the Window class or styles here by modifying</p><p>  // the CREATESTRUCT cs</p><p>  return CScrollView::PreCreateWindow(cs);</p><

41、;p><b>  }</b></p><p>  /////////////////////////////////////////////////////////////////////////////</p><p>  // CMyDIPView drawing</p><p>  void CMyDIPView::OnDraw(C

42、DC* pDC)</p><p><b>  { </b></p><p>  CMyDIPDoc* pDoc = GetDocument();</p><p>  ASSERT_VALID(pDoc);</p><p>  if(pDoc->m_hDIB == NULL)</p><p&g

43、t;<b>  return ;</b></p><p>  // TODO: add draw code for native data here</p><p><b>  int i,j;</b></p><p>  unsigned char *lpSrc;</p><p>  LPSTR

44、lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->m_hDIB);</p><p>  int cxDIB = (int) ::DIBWidth(lpDIB); // Size of DIB - x</p><p>  int cyDIB = (int) ::DIBHeight(lpDIB); // Size of

45、 DIB - y</p><p>  LPSTR lpDIBBits=::FindDIBBits (lpDIB);</p><p>  // 計算圖像每行的字節(jié)數(shù)</p><p>  long lLineBytes = WIDTHBYTES(cxDIB * 8);</p><p><b>  // 每行</b></

46、p><p>  for(i = 0; i < cyDIB; i++)</p><p><b>  {</b></p><p><b>  // 每列</b></p><p>  for(j = 0; j < cxDIB; j++)</p><p><b> 

47、 {</b></p><p>  // 指向DIB第i行,第j個象素的指針</p><p>  lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (cyDIB - 1 - i) + j;</p><p>  // 計算新的灰度值</p><p>  //*(lpSrc) = BYTE

48、(255-*lpSrc);</p><p><b>  }</b></p><p><b>  }</b></p><p>  ::GlobalUnlock((HGLOBAL) pDoc->m_hDIB);</p><p>  CRect rect(0,0,cxDIB,cyDIB), rcDI

49、B(0,0,cxDIB,cyDIB);</p><p>  ::PaintDIB(pDC->m_hDC, &rect, pDoc->m_hDIB, &rcDIB, pDoc->m_palDIB);</p><p><b>  }</b></p><p>  ///////////////////////////

50、//////////////////////////////////////////////////</p><p>  // CMyDIPView printing</p><p>  BOOL CMyDIPView::OnPreparePrinting(CPrintInfo* pInfo)</p><p><b>  {</b></p

51、><p>  // default preparation</p><p>  return DoPreparePrinting(pInfo);</p><p><b>  }</b></p><p>  void CMyDIPView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /

52、*pInfo*/)</p><p><b>  {</b></p><p>  // TODO: add extra initialization before printing</p><p><b>  }</b></p><p>  void CMyDIPView::OnEndPrinting

53、(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)</p><p><b>  {</b></p><p>  // TODO: add cleanup after printing</p><p><b>  }</b></p><p>  ////////////////

54、/////////////////////////////////////////////////////////////</p><p>  // CMyDIPView diagnostics</p><p>  #ifdef _DEBUG</p><p>  void CMyDIPView::AssertValid() const</p><

55、p><b>  {</b></p><p>  CScrollView::AssertValid();</p><p><b>  }</b></p><p>  void CMyDIPView::Dump(CDumpContext& dc) const</p><p><b&g

56、t;  {</b></p><p>  CScrollView::Dump(dc);</p><p><b>  }</b></p><p>  CMyDIPDoc* CMyDIPView::GetDocument() // non-debug version is inline</p><p><b&

57、gt;  {</b></p><p>  ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CMyDIPDoc)));</p><p>  return (CMyDIPDoc*)m_pDocument;</p><p><b>  }</b></p><p>  #e

58、ndif //_DEBUG</p><p>  /////////////////////////////////////////////////////////////////////////////</p><p>  // CMyDIPView message handlers</p><p>  void CMyDIPView::OnSize(UINT nT

59、ype, int cx, int cy)</p><p><b>  {</b></p><p>  CScrollView::OnSize(nType, cx, cy);</p><p><b>  }</b></p><p>  void CMyDIPView::OnInitialUpdate(

60、)</p><p><b>  {</b></p><p>  CScrollView::OnInitialUpdate();</p><p>  SetScrollSizes(MM_TEXT, GetDocument()->m_sizeDoc);</p><p><b>  }</b><

61、;/p><p><b>  //對比度拉伸</b></p><p>  //DEL void CMyDIPView::OnMenuitem32777() </p><p><b>  //DEL {</b></p><p><b>  //DEL </b></p>

62、<p>  //DEL // 獲取文檔</p><p>  //DEL CMyDIPDoc* pDoc = GetDocument();</p><p>  //DEL int i,j;</p><p>  //DEL int r1=60,r2=200;</p><p>  //DEL double k=1.5;</

63、p><p>  //DEL unsigned char *lpSrc;</p><p>  //DEL ASSERT_VALID(pDoc);</p><p>  //DEL if(pDoc->m_hDIB == NULL)</p><p>  //DEL return ;</p><p>  //

64、DEL LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->m_hDIB);</p><p>  //DEL LPSTR lpDIBBits=::FindDIBBits (lpDIB);</p><p>  //DEL int cxDIB = (int) ::DIBWidth(lpDIB); // Size of

65、 DIB - x</p><p>  //DEL int cyDIB = (int) ::DIBHeight(lpDIB); // Size of DIB - y</p><p>  //DEL long lLineBytes = WIDTHBYTES(cxDIB * 8); // 計算圖像每行的字節(jié)數(shù)</p><p>  //DEL /

66、/ 每行</p><p>  //DEL for(i = 0; i < cyDIB; i++)</p><p><b>  //DEL {</b></p><p>  //DEL // 每列</p><p>  //DEL for(j = 0; j < cxDIB; j++)</p>

67、<p><b>  //DEL {</b></p><p>  //DEL // 指向DIB第i行,第j個象素的指針</p><p>  //DEL lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (cyDIB - 1 - i) + j;</p><p>  //DE

68、L // 計算新的灰度值</p><p>  //DEL if(*lpSrc<r1) *lpSrc=BYTE(*lpSrc/k);</p><p>  //DEL else if(*lpSrc<r2) *lpSrc= BYTE((*lpSrc-r1)*k+r1/k);</p><p>  //DEL else *lpSrc=BYT

69、E((*lpSrc-r2)/k+255-(255-r2)/k);</p><p><b>  //DEL }</b></p><p><b>  //DEL }</b></p><p>  //DEL ::GlobalUnlock((HGLOBAL) pDoc->m_hDIB);</p><

溫馨提示

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

評論

0/150

提交評論