这一篇博文是对图像处理的知识点和资料的整理.
http://blog.csdn.net/abcjennifer/article/details/8170687
http://www.cnblogs.com/skyseraph/archive/2011/05/03/2035643.html
http://blog.csdn.net/passball/article/details/5204132
颜色直方图是一种最基本的颜色特征
直方图之间的相似性度量是对于颜色直方图最基本的操作,可以用来衡量图像之间的相似性.
对比的方法,opencv 提供了四种:
http://www.opencv.org.cn/opencvdoc/2.3.2/html/doc/tutorials/imgproc/histograms/histogram_comparison/histogram_comparison.html
其中chi-square是解决以下问题:比如:
H1.red[0] = 0.001 H2.red[0] = 0.011
H1.red[0] = 0.1 and H2.red[0] = 0.11
虽然两种情况下差值相同,但是直方图距离应该是不同.
还有一种对比方法叫做交叉对比(Cross-bin-comparison):
http://stackoverflow.com/questions/6499491/comparing-two-histograms
比如说bin[i]代表的是红色,bin[j]代表的是暗红色,bin[k]代表的是绿色. M代表的是一个权重矩阵,那么M(i,j)比较大,M(i,k)比较小,最后的距离就是:
sqrt((H1-H2)*M*(H1-H2))
为了提高检索的速度,Smith和Chang提出了用颜色集的方法,首先将RGB颜色空间转换成视觉均衡的颜色空间(HSV),并将颜色空间量化成若干个bin,然后运用颜色自动分割技术将图像分为若干个区域,每个区域用量化颜色空间的某个颜色分量来索引,从而将图像表达成一个二进制的颜色索引表。在图像匹配中,比较不同图像颜色集之间的距离和颜色区域的空间关系。因为,颜色集表达为二进制的特征向量,可以构造二分查照树来加快检索速度,对大规模的图象集合十分有力。
颜色矩是一种简单而有效的颜色特征,是由Stricker和Oreng提出的,这种方法的数学基础是图像中的任何的颜色分布均可以用它的矩来表示。此外,由于颜色分布信息主要集中在低阶矩中,因此,仅采用颜色的一阶矩(mean)、二阶矩(Variance)和三阶矩(Skewness)就足以表达图像的颜色分布,与颜色直方图相比,该方法的另一个好处是无须对特征进行量化。
三个颜色矩的数学定义如下:
http://www.docin.com/p-1769701476.html
基于统计的特征,比如灰度共生矩阵,LBP
对图像上单个象素具有某个灰度进行统计的结果,而灰度共生矩阵是对图像上保持某距离的两象素分别具有某灰度的状况进行统计得到的。
取图像(N×N)中任意一点(x,y)及偏离它的另一点(x+a,y+b),设该点对的灰度值为(g1,g2)。令点(x,y)在整个画面上移动,则会得到各种(g1,g2)值。设灰度值的级数为L,则(g1,g2)的组合共有k(k=L*L)种。对于整个画面,统计出每一种(g1,g2)值出现的次数,然后排列成一个方阵,再用(g1,g2)出现的总次数将它们归一化为出现的概率P(g1,g2),这样的方阵称为灰度共生矩阵。距离差分值(a,b)取不同的数值组合,可以得到不同情况下的联合概率矩阵。(a,b) 取值要根据纹理周期分布的特性来选择,对于较细的纹理,选取(1,0)、(1,1)、(2,0)等小的差分值。
当a=1,b=0时,像素对是水平的,即0度扫描;当a=0,b=1 时,像素对是垂直的,即90度扫描;当a=1,b=1时,像素对是右对角线的,即45度扫描;当a=-1,b=-1时,像素对是左对角线,即135度扫描。
http://www.cnblogs.com/8335IT/p/5648445.html
http://blog.csdn.net/xw20084898/article/details/20528997
http://blog.csdn.net/quincuntial/article/details/50541815
基于模型的特征,随机场模型(最广泛的就是MRF,还有自回归纹理模型SAR),分形模型(分数布朗运动FBM模型,自相似模型ESS)
MRF就是马尔科夫随机场
http://lib.csdn.net/article/machinelearning/46301
SAR自回归纹理模型
http://blog.sina.com.cn/s/blog_92c398b00102vs4o.html
信号处理类的提取方法,一般都是从变换域提取纹理特征,比如Gabor滤波,小波变换
http://blog.csdn.net/jinshengtao/article/details/17797641
https://zhuanlan.zhihu.com/p/22450818?refer=dong5
https://wenku.baidu.com/view/8d1372b0d0d233d4b14e69c5.html
http://blog.csdn.net/daisy9212/article/details/49184271
http://blog.csdn.net/jwh_bupt/article/details/7621681
http://blog.csdn.net/jwh_bupt/article/details/7628665
http://blog.csdn.net/abcjennifer/article/details/7639681
http://blog.csdn.net/jwh_bupt/article/details/6564835
方向梯度直方图
http://blog.csdn.net/zouxy09/article/details/7929348/
最早是用来人脸表示
http://blog.csdn.net/zouxy09/article/details/7929570/
http://blog.csdn.net/zouxy09/article/details/49080029
可以实现图像的拉伸,缩放,平移,旋转等变化
http://www.cnblogs.com/ghj1976/p/5199086.html
http://blog.csdn.net/hitwengqi/article/details/6888783
http://www.opencv.org.cn/opencvdoc/2.3.2/html/doc/tutorials/imgproc/imgtrans/warp_affine/warp_affine.html
http://blog.csdn.net/hitwengqi/article/details/6890220
汇总:
http://www.cnblogs.com/skyseraph/archive/2010/12/21/1913058.html
这个就是最常用的大津法.
就是求最大类间方差,具体可以参考 http://blog.csdn.net/liyuanbhu/article/details/49387483
就是求使两个类之间的熵最大的阈值.
http://blog.csdn.net/happygirlliu520/article/details/47026649
阈值分割其实都是基于灰度直方图的方法,求取最优划分.
区域分裂合并法(Gonzalez,2002)的基本思想是首先将图像任意分成若干互不相交的区域,然后再按照相关准则对这些区域进行分裂或者合并从而完成分割任务,该方法既适用于灰度图像分割也适用于纹理图像分割。
大致有两种方法,一个是基于灰度值的,另外一个是基于距离变换的(MATLAB 就是用的这种).
此类方法把图像分割问题与图的最小割(min cut)问题相关联。首先将图像映射为带权无向图G=
主要就是指的水平集方法
首先利用边缘检测生成种子点,然后进行区域生长 http://www.cnblogs.com/skyseraph/archive/2011/05/22/2047049.html
颜色直方图一般是作为一个图像特征来使用,但是也可以直接用来进行图像分割
这是最基础的图像分割方法,做法就是提取出颜色直方图,然后选取直方图范围进行分割.
http://www.cnblogs.com/skyseraph/archive/2011/06/14/2081042.html
用于图像分割: http://blog.csdn.net/u014568921/article/details/45197027/
meanshift 同样可用于目标跟踪: http://blog.csdn.net/jinshengtao/article/details/30258833
这是基于聚类的图像分割:
http://blog.csdn.net/jteng/article/details/48811881
每一个像素点都是一个向量,这个向量可以是只有颜色信息,也可以是颜色信息加空间信息,在进行聚类的时候,向量特征需要进行归一化,也可以进行加权.
kmeans 可以用来进行图像预处理,这样颜色就只会有k类.
就是一个指数变换,用来拉伸较暗区域或者较亮区域的对比度,gamma为1的时候,曲线为线性。https://www.zhihu.com/question/27467127 这个讲的非常好。为啥需要gamma校正,涉及到一个采样的问题,因为现在主流图片的灰阶是256个,用256个采样点去采样真实世界中无数的颜色(模拟量),这就存在一个资源分配的问题,如果说不进行gamma校正,那么128阶就是对应着真实世界反射率为50%的颜色,50阶对应着反射率为22%的颜色,但是对于人眼来说反射率为22%的颜色才是中灰,所以如果不进行校正的话,从黑到中灰只有50个阶来记录了,造成暗处采样不足,高光采样冗余,所以在采样编码的时候,就需要把反射率为22%的颜色对应到128上,所以采样编码的时候有一个gamma为1/2.2 = 0.454的校正,这样反射率从0-22%就有128个阶来采样记录了。然后在显示屏显示的时候,再把128阶的反射率对应到22%上,也就是一个gamma为2.2的校正。
需要gamma校正的原因有两个,一个是人眼对于光的感知是非线性的,另外一个就是当前由于存储空间和传输效率的限制,用256个灰阶进行描述颜色,灰阶不够充分所以在采样的时候就尽量在亮和暗的区域(对于人眼,暗是0-22%反射率,亮是22%-100%)各用128个来描述,假如可以用32位图像来描述,那么就有4billion多个灰阶,即使不进行校正,暗的区域用4billion*22%个色阶描述,那也足够了。
靠累计分布函数来实现.