A implementation of boxfilter

boxfilter 是均值滤波的一种改进。在以下这篇blog里面有介绍。

http://www.cnblogs.com/easymind223/archive/2012/11/13/2768680.html

这里我使用matlab对其进行实现。

可是这里边界问题没有处理好,假设viewer有好的意见欢迎告诉我

  1. % % *********************************************************
  2. % code writer : EOF
  3. % code file : my_boxfilter.m
  4. % code date : 2014.10.21
  5. % e-mail : jasonleaster@gmail.com
  6. %
  7. % Code description :
  8. % Here is my implementation of boxfilter :)
  9. % It work correctly in the region where is not close to
  10. % the end boundary but will meet problem on some where
  11. % close to the image end boundary.
  12. % *********************************************************
  13.  
  14. function Filted_Img = my_boxfilter(Image)
  15.  
  16. if size(Image,3) ~= 1
  17. fprintf('ERROR Imput-Image must be ##ONE## channel image\n');
  18. return;
  19. end
  20.  
  21. Height_Img = size(Image,1);
  22. Width_Img = size(Image,2);
  23.  
  24. Buffer = zeros(1,Width_Img);
  25. Filted_Img = zeros(Height_Img,Width_Img);
  26.  
  27. % treat this varible as a constant
  28. SEARCH_WIN_HEIGHT = 10;
  29. SEARCH_WIN_WIDTH = 10;
  30.  
  31. for row = 1: Height_Img
  32. for col = 1: Width_Img
  33.  
  34. sum_value = 0;
  35. if (row + SEARCH_WIN_HEIGHT) < Height_Img
  36.  
  37. for temp = row : (row + SEARCH_WIN_HEIGHT)
  38. sum_value = sum_value + Image(temp,col);
  39. end
  40. else
  41.  
  42. for temp = row : Height_Img
  43. sum_value = sum_value + Image(temp,col);
  44. end
  45. end
  46.  
  47. Buffer(col) = sum_value;
  48. end
  49.  
  50. for col = 1:Width_Img
  51.  
  52. if (col + SEARCH_WIN_WIDTH) < Width_Img
  53.  
  54. for temp = col : col + SEARCH_WIN_WIDTH
  55. Filted_Img(row,col) = Filted_Img(row,col) + Buffer(temp);
  56. end
  57. else
  58. for temp = col : Width_Img
  59. Filted_Img(row,col) = Filted_Img(row,col) + Buffer(temp);
  60. end
  61. end
  62. end
  63.  
  64. end
  65.  
  66. Filted_Img = Filted_Img./(SEARCH_WIN_HEIGHT * SEARCH_WIN_WIDTH);
  67. end

版权声明:本文博客原创文章,博客,未经同意,不得转载。

boxfilter 实现的更多相关文章

  1. 机器学习进阶-阈值与平滑-图像平滑操作(去噪操作) 1. cv2.blur(均值滤波) 2.cv2.boxfilter(方框滤波) 3. cv2.Guassiannblur(进行高斯滤波) 4. cv2.medianBlur(进行中值滤波)

    1.cv2.blur(img, (3, 3))  进行均值滤波 参数说明:img表示输入的图片, (3, 3) 表示进行均值滤波的方框大小 2. cv2.boxfilter(img, -1, (3, ...

  2. opencv3.2.0图像处理之方框滤波boxFilter API函数

    /*.1.方框滤波:boxFilter函数(注:均值滤波是归一化后的方框滤波)*/ /*函数原型: void boxFilter(InputArray src, OutputArray dst, in ...

  3. 图像处理之滤波---滤波在游戏中的应用boxfilter

    http://www.yxkfw.com/?p=7810 很有意思的全方位滤波应用 https://developer.nvidia.com/sites/default/files/akamai/ga ...

  4. 【计算机视觉】极限优化:Haar特征的另一种的快速计算方法—boxfilter

    这种以Boxfilter替代integral image 的方法很难使用到haar.LBP等特征检测中,因为像下面说的,它不支持多尺度,也就是说所提取的特征必须是同一个大小,最起码同一个宽高比的,这一 ...

  5. boxFilter in opencv

    , -),bool normalize=true,int borderType=BORDER_DEFAULT) Smoothes image using box filter Parameters: ...

  6. opencv —— boxFilter、blur、GaussianBlur、medianBlur、bilateralFilter 线性滤波(方框滤波、均值滤波、高斯滤波)与非线性滤波(中值滤波、双边滤波)

    图像滤波,指在尽量保留图像细节特征的条件下对目标图像的噪声进行抑制,是图像与处理中不可缺少的操作. 邻域算子,指利用给定像素及其周围的像素值,决定此像素的最终输出值的一种算子.线性邻域滤波器就是一种常 ...

  7. 积分图(三) - Boxfilter 的实现过程分析

    Boxfilter 快速计算 它可以使复杂度为O(MN)的求和,求方差等运算降低到O(1)或近似于O(1)的复杂度,它的缺点是不支持多尺度. Boxfilter 的原理有点类似 Integral Im ...

  8. 学习 opencv---(8)非线性滤波:中值滤波,双边滤波

    正如我们上一篇文章中讲到的,线性滤波可以实现很多种不同的图像变换.然而非线性滤波,如中值滤波器和双边滤波器,有时可以达到更好的实现效果. 邻域算子的其他一些例子还有对 二值图像进行操作的形态学算子,用 ...

  9. 学习 opencv---(7) 线性邻域滤波专场:方框滤波,均值滤波,高斯滤波

    本篇文章中,我们一起仔细探讨了OpenCV图像处理技术中比较热门的图像滤波操作.图像滤波系列文章浅墨准备花两次更新的时间来讲,此为上篇,为大家剖析了"方框滤波","均值滤 ...

随机推荐

  1. Git使用摘要

    svn过渡到git流程.使用我一直git svn场景,对于遇到的一些问题,并经常使用的功能来概括: 1.git svn出口: git svn clone "svn通路" 2.git ...

  2. 【Android进阶】Android面试题目整理与讲解(二)

    1. ArrayList,Vector, LinkedList 的存储性能和特性 ArrayList 和 Vector 都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,它们 ...

  3. android于src和background差额

    ImageView中XML属性src和background的差别: background会依据ImageView组件给定的长宽进行拉伸,而src就存放的是原图的大小.不会进行拉伸.src是图片内容(前 ...

  4. HTML&lt;!DOCTYPE&gt; 宣示

    在html页面,下面这行代码到底有什么用呢? <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" & ...

  5. simple factory, factory method, abstract factory

    simple factory good:1 devide implementation and initialization2 use config file can make system more ...

  6. Arrays.asList()

    1.数组--->List String[] ss={"abc","def","xyz","aaaaaaaa",&q ...

  7. 升级到cocos2d-x 2.0.2代码差异

    来自:http://www.cnblogs.com/TopWin/archive/2012/09/12/2682042.html 近期看cocos2d-x 2.0.2公布后升级了一下.升级后发现又出现 ...

  8. Java Swing 绝对布局管理方法,null布局(转)

    首先把相关容器的布局方式设为 setLayout(null); 然后调用组件的  setBounds() 方法 设置button的位置为(100,100) 长宽分别为 60,25 jButton.se ...

  9. Oracle Instanc Client安装命令工具

    条件 1.Linux RHEL 6.X X86_64操作系统 2.从安装Oracleserver的server此次收购Oracle相关文件(同OS) 软件下载 从Oracle包: 1)  instan ...

  10. 认识Backbone (三)

    Backbone.Collection(集合)  collection是model对象的一个有序的组合,我们可以在集合上绑定 "change" 事件,从而当集合中的模型发生变化时f ...