论文网站:http://arxiv.org/abs/1404.3606html
论文下载地址:PCANet: A Simple Deep Learning Baseline for Image Classification?git
论文的matlab代码(第一个就是):Matlab Codes for Downloadgithub
本文的C++ 和 Scala 代码:https://github.com/Ldpe2G/PCANet网络
该文提出了一个简单的深度学习网络,用于图像分类,用于训练的图像的特征的提取包含如下步骤:
函数
一、cascaded principal component analusis 级联主成分分析;
学习
二、binary hashing 二进制哈希;测试
三、block-wise histogram 分块直方图网站
PCA(主成分分析)被用于学习多级滤波器(multistage filter banks),spa
而后用binary hashing 和 block histograms分别作索引和合并。.net
最后得出每一张训练图片的特征,每张图片的特征化为 1 x n 维向量,而后用这些特征向量来训练
支持向量机,而后用于图像分类。
首先假设咱们的训练图片的为N张,,每张图片大小为 m x n。
首先对每一幅训练图像作一个处理,就是按像素来作一个分块,分块大小为 k1 x k2。
上图解释什么事按像素分块,假设图像是灰度图大小为 5 x 5,分块大小为 2 x 2。
而后获得的分片矩阵大小是 4 x 16,按照上述计算公式能够获得。
而后若是图像是RGB 图像,则首先将三个通道分开,每一个通道都作上 诉的分片,获得的分块矩阵,
作一个竖直方向上的合并获得RGB图像的分块矩阵,则若是RGB图像大小为 5 x 5,分块大小2x2,
则获得的分块矩阵大小为 12 x 16。
须要注意的是按照论文的说法,分块的矩阵的列数为m*n,因此5x5矩阵的分块矩阵应该有25列,
可是从代码的实现上看,是按照上图的公式来计算的。
假设第 i 张图片,,分块后获得的矩阵为
,而后对每一列减去列平均,获得
。
接着对N张训练图片都作这样一个处理,获得
c为分快矩阵的列数。
而后接着求解的特征向量,取前
个最大的特征值对应的特征向量。
做为下一阶段的滤波器。数学表达为:
而后第一阶段的主成分分析就完成了。由于我将matlab代码移植到了opencv,因此对原来的代码
比较熟悉,这是结合代码来发分析的,代码实现和论文的描述有些不一样。
过程基本上和第一阶段同样。不一样的是第一阶段输入的N幅图像要和第一阶段获得的滤波器
分别作卷积,获得 L1 x N 张第二阶段的训练图片。
。
在卷积以前首先作一个0边界填充,使得卷积以后的图片和
大小相同。
一样对每一张图片作分块处理,而后把由N张图片和L1 个滤波器卷积获得的图片的
分块结果合在一块儿,首先获得:
这是N张图片和其中一个滤波器卷积的分块结果。
而后将全部的滤波器输出合在一块儿:
但实际上在代码的实现上,同一张图片 对应的全部滤波器的卷积是放在一块儿的,
其实就是顺序的不一样,对结果的计算没有影响。
而后求解的特征向量,取前
个最大的特征值对应的特征向量。
做为滤波器。
而后就来到特征训练的最后一步了。
而后对每一幅第二阶段主成分分析的输入图片作如下计算:
每张图片和L2个滤波器分别进行卷积。H(.)函数表示将一个矩阵转换为一个相同大小的
只包含0和1的矩阵,就是原来元素大于0,则新的矩阵对应的位置为1,不然为0.
而后乘以一个权值再加起来。权值由小到大依次对应的滤波器的也是由小到大。
而后对矩阵,将其分红B块,获得的分块矩阵大小为 k1k2 x B,
而后统计分块矩阵的直方图矩阵,直方图的范围是,
直方图矩阵大小为 2^L2 x B。
而后将直方图矩阵向量化为行向量获得,
最后将全部的的
连接起来
获得表明每张训练图的特征向量。
上图解释直方图统计:
而后训练的步骤就完成了。
接着开始支持向量机的训练和测试。
svm的核函数用的是线性核函数,论文的matlab用的是Liblinear,
由国立台湾大学的Chih-Jen Lin博士开发的,主要是应对large-scale的data classification。
而后opencv的svm的类型我选择了CvSVM::C_SVC,参数C设为1。
这是我将论文的matlab代码移植到opencv的测试结果,
用了120张图片做测试,精确度为65.5%,比论文中用一样的数据集caltech101,
获得的精度68%要差一点。
对SVM有兴趣的读者能够参考这位博主的文章: