麻辣GIS微信平台

更多 GIS 干货

微信关注不错过

IDL实现3*3均值滤波和中值滤波

关于均值滤波和中值滤波

属于空域图像增强的处理方法,均值滤波去麻点,中值滤波保边缘。

实现代码

;Name: 3x3平均值滤波&中值滤波
;Time: 2013-12-19
;Author: 尹全超

PRO item_c_1
  
  ;读取图像
  file =  DIALOG_PICKFILE(/READ, FILTER = '*.bmp')
  binary_img = READ_BMP(file)
  img01 = image(binary_img,LAYOUT=[3,1,1],title='Original')
  
  ;获取行数和列数
  row=N_elements(binary_img[0,*])
  col=N_elements(binary_img[*,0])
  ave=binary_img
  mid=binary_img
  
  ;3x3平均值滤波&3x3中值滤波
  FOR i=1,row-2 DO BEGIN
    FOR j=1,col-2 DO BEGIN
      ave[j,i]=fix(mean(binary_img[j-1:j+1,i-1:i+1]))
      mid[j,i]=fix(median(binary_img[j-1:j+1,i-1:i+1]))
    ENDFOR
  ENDFOR
  
  img02 = image(ave,LAYOUT=[3,1,2],/CURRENT,title='Mean-value')
  img03 = image(mid,LAYOUT=[3,1,3],/CURRENT,title='Mid-value')
   
END

效果图

相关阅读

麻辣GIS-Sailor

作者:

GIS爱好者,学GIS,更爱玩GIS。

声明

1.本文所分享的所有需要用户下载使用的内容(包括但不限于软件、数据、图片)来自于网络或者麻辣GIS粉丝自行分享,版权归该下载资源的合法拥有者所有,如有侵权请第一时间联系本站删除。

2.下载内容仅限个人学习使用,请切勿用作商用等其他用途,否则后果自负。

手机阅读
公众号关注
知识星球
手机阅读
麻辣GIS微信公众号关注
最新GIS干货
关注麻辣GIS知识星球
私享圈子

已有 2 条评论

  1. 麻辣GIS-Carollina
    1#
    Carollina  · 2015-12-14 10:00

    row=N_elements(binary_img[0,])

    col=N_elements(binary_img[,0])
    运行时显示这两句有语法错误,不知怎么修改,可以麻烦主页指点一下么?我的运行环境的ENVI4.8自带的IDL

      1. 麻辣GIS-Sailor
        Sailor  · 2015-12-14 20:37

        不好意思,是网站代码转义的问题,现在已经修正。不过均值滤波和中值滤波IDL是有自带的函数的,这里只是自己写着练习IDL的。

留言板(小编看到第一时间回复)