去除噪声(中值滤波法)(C语言程序)

  1. int median_value(unsigned char c[9]);   
  2.    
  3. /*---median---利用中值滤波法去除噪声----------------------------------  
  4.      image_in:   输入图像数组  
  5.      image_out:  输出图像数组  
  6. --------------------------------------------------------------------*/   
  7. void median(unsigned char image_in[Y_SIZE][X_SIZE],   
  8.             unsigned char image_out[Y_SIZE][X_SIZE])   
  9. {   
  10.     int i, j;   
  11.     unsigned char c[9];   
  12.    
  13.     for(i = 1; i < Y_SIZE-1; i++)   
  14.     {   
  15.         for(j = 1; j < X_SIZE-1; j++)   
  16.         {   
  17.             c[0] = (int)image_in[i-1][j-1];   
  18.             c[1] = (int)image_in[i-1][j];   
  19.             c[2] = (int)image_in[i-1][j+1];   
  20.             c[3] = (int)image_in[i][j-1];   
  21.             c[4] = (int)image_in[i][j];   
  22.             c[5] = (int)image_in[i][j+1];   
  23.             c[6] = (int)image_in[i+1][j-1];   
  24.             c[7] = (int)image_in[i+1][j];   
  25.             c[8] = (int)image_in[i+1][j+1];   
  26.             image_out[i][j] = median_value(c);   
  27.         }   
  28.     }   
  29. }   
  30.    
  31. /*---median_value---求出9个像素的中央值-------------------------------  
  32.      c:  像素  
  33. --------------------------------------------------------------------*/   
  34. int median_value(unsigned char c[9])   
  35. {   
  36.     int i, j, buf;   
  37.     for(j = 0; j < 8; j++)   
  38.     {   
  39.         for(i = 1; i < 8; i++)   
  40.         {   
  41.             if(c[i+1] < c[i])   
  42.             {   
  43.                 buf = c[i+1];   
  44.                 c[i+1] = c[i];   
  45.                 c[i] = buf;   
  46.             }   
  47.         }   
  48.     }   
  49.     return c[4];   
  50. }   
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值