數(shù)字圖像處理課程設計--最大值、最小值濾波圖像增強_第1頁
已閱讀1頁,還剩13頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p>  數(shù)字圖像處理課程設計</p><p>  ——最大值、最小值濾波圖像增強</p><p>  實驗目的:熟悉了解、學習C、C++語言;</p><p>  學習VC++在圖像處理中的應用;</p><p>  深入了解圖像的增強處理;</p><p>  深入了解用最大值濾波、最小值濾波增強處理圖

2、像的基本知識;</p><p>  掌握圖像處理的基本方法掌握最大值、最小值濾波的程序編寫及其它圖像增強處理的程序編寫的了解。</p><p><b>  實驗儀器:</b></p><p>  TestVC軟件,計算機,photoshop軟件。</p><p><b>  實驗原理:</b><

3、;/p><p>  圖像增強就是采用某些技術把質量低的圖像進行計算機處理, 有選擇地加強或抑制圖像中的某些信息, 改善圖像質量, 提高人或機器對圖像的分析與判讀能力。</p><p>  圖像的增強處理方法一共有兩種,分別是空間域方法和頻域方法??臻g域方法主要是運用空間濾波對圖像增強進行處理,所謂濾波,就是過濾掉圖像中的一些“成分”,對數(shù)字圖像的直接濾波就是空間濾波(相對于頻率域濾波)??臻g濾

4、波主要包括平均濾波、中值濾波、最大值濾波、最小值濾波等。空間濾波是通過空間濾波器實現(xiàn)。空間濾波器就是在一個鄰域(如包圍該像素的一個小矩形區(qū)域)里,對該鄰域包圍的像素的進行操作??臻g濾波器包括線性濾波器如:線性操作,如加、減、乘運算;非線性濾波器如:非線性操作??臻g濾波器又叫模板,類似于矩陣,大小有3*3模板、5*5模板、9*9模板等。</p><p><b>  如:9*9模板:</b>&l

5、t;/p><p>  空間濾波對圖像的增強處理主要是通過模板運算實現(xiàn)的,按照指定的模板進行運算。</p><p>  如右圖,是對模板運算的</p><p><b>  的圖示解釋。</b></p><p>  模版運算實現(xiàn)的主要步驟:</p><p>  1、將模板在圖中遍歷,并將模板中心與圖中某個

6、像素位置重合;</p><p>  2、將模板上的各個系數(shù)與模板下的各對應像素的灰度值相乘;</p><p>  3、將所有乘積相加;</p><p>  4、將上述運算結果賦給模板中心位置的像素。</p><p>  最大值濾波、最小值濾波的原理:設輸出的圖像為g(x,y),</p><p><b>  最

7、大值濾波</b></p><p><b>  最小值濾波</b></p><p><b>  實驗內容:</b></p><p>  1,在百度圖庫中尋找一張圖片:</p><p>  2,在Photoshop中,將圖片改為寬300像素,高300像素的圖片,模式保存為RGB,8位/通道,

8、格式為bmp,保存在D盤中,命名為:myimge;</p><p>  3,打開TestVC.dsw工程文件,再打開mytest.cpp文件,在指定位置輸入程序</p><p>  4,編譯,調試,運行。</p><p><b>  實驗結果:</b></p><p>  利用for循環(huán)編寫代碼;</p>

9、<p>  1.1最大值濾波for循環(huán)主要代碼:</p><p>  void CTestVCView::test(BYTE inimage[300][300],BYTE outimage[300][300])</p><p><b>  {</b></p><p>  int i,j,max;</p><p>

10、;  for(i=1;i<300;i++)</p><p><b>  {</b></p><p>  for(j=1;j<300;j++)</p><p><b>  {</b></p><p>  max=inimage[1000][1000];</p><p&g

11、t;  if(inimage[i][j]>max)</p><p><b>  {</b></p><p>  max=inimage[i][j];</p><p><b>  }</b></p><p>  outimage[i][j]=max;</p><p>&l

12、t;b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  1.2代碼截圖:</b></p><p>  1.3 輸入圖像(左),輸出圖像(右);</p><p>

13、  2.1最小值濾波for循環(huán)主要代碼;</p><p>  void CTestVCView::test(BYTE inimage[300][300],BYTE outimage[300][300])</p><p><b>  {</b></p><p>  int i,j,min;</p><p>  for(i=

14、1;i<300;i++)</p><p><b>  {</b></p><p>  for(j=1;j<300;j++)</p><p><b>  {</b></p><p>  min=inimage[1000][1000];</p><p>  if(in

15、image[i][j]<min)</p><p><b>  {</b></p><p>  min=inimage[i][j];</p><p><b>  }</b></p><p>  outimage[i][j]=min;</p><p><b>  

16、}</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  2.2代碼截圖;</b></p><p>  2.3實驗的輸入圖像如下圖左,處理圖像如下圖右:</p><p>  二、利

17、用for、、、if判斷語句進行編碼;</p><p>  1.1 最大值濾波的主要編碼;</p><p>  void CTestVCView::test(BYTE inimage[300][300],BYTE outimage[300][300])</p><p><b>  {</b></p><p>  int i

18、,j,max;</p><p>  for(i=1;i<300;i++)</p><p><b>  {</b></p><p>  for(j=1;j<300;j++)</p><p><b>  {</b></p><p>  max=inimage[i][

19、j];</p><p>  if(inimage[i-1][j]>max)</p><p><b>  {</b></p><p>  max=inimage[i-1][j];</p><p><b>  }</b></p><p>  if(inimage[i-1][

20、j-1]>max)</p><p><b>  {</b></p><p>  max=inimage[i-1][j-1];</p><p><b>  }</b></p><p>  if (inimage[i-1][j+1]>max)</p><p><

21、b>  {</b></p><p>  max=inimage[i-1][j+1];</p><p><b>  }</b></p><p>  if(inimage[i][j-1]>max)</p><p><b>  {</b></p><p> 

22、 max=inimage[i][j-1];</p><p><b>  }</b></p><p>  if(inimage[i][j+1]>max)</p><p><b>  {</b></p><p>  max=inimage[i][j+1];</p><p>

23、<b>  }</b></p><p>  if(inimage[i+1][j-1]>max)</p><p><b>  {</b></p><p>  max=inimage[i+1][j-1];</p><p><b>  }</b></p><

24、p>  if(inimage[i+1][j]>max)</p><p><b>  {</b></p><p>  max=inimage[i+1][j];</p><p><b>  }</b></p><p>  if(inimage[i+1][j+1]>max)</p&

25、gt;<p><b>  {</b></p><p>  max=inimage[i+1][j+1];</p><p><b>  }</b></p><p>  outimage[i][j]=max;</p><p><b>  }</b></p>

26、<p><b>  }</b></p><p><b>  }</b></p><p><b>  1.2編碼截圖:</b></p><p>  1.3 實驗輸入圖像(左) 輸出圖像(右)</p><p>  2.1 最小值濾波的主要編碼;</p>&

27、lt;p>  void CTestVCView::test(BYTE inimage[300][300],BYTE outimage[300][300])</p><p><b>  {</b></p><p>  int i,j,min;</p><p>  for(i=1;i<300;i++)</p><p&

28、gt;<b>  {</b></p><p>  for(j=1;j<300;j++)</p><p><b>  {</b></p><p>  min=inimage[i][j];</p><p>  if(inimage[i-1][j]<min)</p><p

29、><b>  {</b></p><p>  min=inimage[i-1][j];</p><p><b>  }</b></p><p>  if(inimage[i-1][j-1]<min)</p><p><b>  {</b></p>&l

30、t;p>  min=inimage[i-1][j-1];</p><p><b>  }</b></p><p>  if (inimage[i-1][j+1]<min)</p><p><b>  {</b></p><p>  min=inimage[i-1][j+1];</p

31、><p><b>  }</b></p><p>  if(inimage[i][j-1]<min)</p><p><b>  {</b></p><p>  min=inimage[i][j-1];</p><p><b>  }</b></

32、p><p>  if(inimage[i][j+1]<min)</p><p><b>  {</b></p><p>  min=inimage[i][j+1];</p><p><b>  }</b></p><p>  if(inimage[i+1][j-1]<

33、min)</p><p><b>  {</b></p><p>  min=inimage[i+1][j-1];</p><p><b>  }</b></p><p>  if(inimage[i+1][j]<min)</p><p><b>  {<

34、;/b></p><p>  min=inimage[i+1][j];</p><p><b>  }</b></p><p>  if(inimage[i+1][j+1]<min)</p><p><b>  {</b></p><p>  min=inimag

35、e[i+1][j+1];</p><p><b>  }</b></p><p>  outimage[i][j]=min;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }<

36、/b></p><p><b>  2.2 編碼截圖;</b></p><p>  2.3,實驗輸入圖像(左) 輸出圖像(右)</p><p><b>  編碼分析</b></p><p>  如右圖,可以令圖像中某一象素的位置坐標為(s,t),其鄰域象素的坐標位置就如右圖所示,因為在圖像中象

37、素的坐標位置為二維數(shù)組,若用I,j代表s,t,則這九個點在程序輸入是的代碼為</p><p>  inimage[i-1][j]</p><p>  inimage[i-1][j-1]</p><p>  inimage[i-1][j+1]</p><p>  inimage[i][j-1]</p><p>  ini

38、mage[i][j]</p><p>  inimage[i][j+1]</p><p>  inimage[i+1][j-1]</p><p>  inimage[i+1][j]</p><p>  inimage[i+1][j+1]</p><p>  在最大值濾波中,只需要找出這九個位置的象素中灰度值最大的象素,

39、即若賦值(s,t)位置的象素灰度值最大(max= inimage[i][j]),只需要將另外八個位置象素的灰度值與其進行大小比較,若大于inimage[i][j],則將其灰度值賦值于max,再將其他位置的象素灰度值與其進行比較,直至找出這九個位置象素中灰度值最大的那個象素,然后將其灰度值代替中心象素(s,t)位置的象素灰度值。</p><p>  在最小值濾波中,只需要找出這九個位置象素中灰度值最小的象素,若賦值

40、(s,t)位置的象素灰度值最小(min=inimage[i][[j]),只需要將另外八個位置象素的灰度值與其進行大小比較,若小于inimage[i][j],則將其灰度值賦值于min,再將其他位置的象素灰度值與其進行比較,直至找這九個位置象素中灰度值最小的那個象素,然后再將其灰度值代替中心象素(s,t)位置的象素位置。</p><p>  在編碼過程中無論是使用for循環(huán)語句還是使用for、、、if,其編碼原理都大

41、致如此,只不過for循環(huán)語句比較簡單,但是for循環(huán)的語句中,因為在所有的數(shù)組中,其灰度值的范圍是是[1 300],所以在對最大值max進行賦值時一定要賦予一個最小的數(shù),目的就是為了讓圖像中所有象素的灰度值都大于max ,這樣就可以讓所有象素與max進行循環(huán)比較;對最小值min進行賦值時一定要賦予一個最大的數(shù),目的就是為了讓圖像中所有象素的灰度值都小于min,這樣就可以讓所有的象素與min進行循環(huán)比較。</p><p

42、>  用For、、、if語句進行編碼雖然麻煩,但是讀起來比較易懂,先把九個像素位置的灰度值表示出來,然后用所有象素的灰度值與其中一個象素灰度值逐依進行比較,直至得出最大灰度值象素或最小灰度值象素。</p><p><b>  實驗收獲:</b></p><p>  在這次小學期中,我對C語言有了更加深入地學習,而且初步對VC++有了了解,將程序設計與圖像處理很好

43、的結合,在之前一直用PS等作圖軟件對圖像進行處理的基礎上,也簡單的學會了用C語言、VC++等程序對圖像進行數(shù)字化處理。 </p><p>  這次小學期的主要任務是對圖像進行增強處理,主要是運用最大值濾波、最小值濾波對圖像進行操作。通過學習,不僅深入了解了圖像增強處理的方法和技巧,而且也對濾波有了更深入的了解,尤其是最大值濾波、最小值濾波、中值濾波、均值濾波等。在利用程序編碼對其進行操作時,也對程序編碼有了更深入

溫馨提示

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

評論

0/150

提交評論