前言

  网上一堆狂吹PCA和讲原理的,可就是不讲怎么用。
  给了代码的,拿过来用效果贼差,毕竟那些只是为了画图的代码而已。。。


上代码

  真正使用,分3步即可:
1、数据预处理(非常重要!!!)——零均值化和缩放
原因可以看网上原理教程,这里只关心怎么做。
很简单:

from sklearn.preprocessing import StandardScaler

scaler = StandardScaler().fit(des_query)
des_query = scaler.transform(des_query)
des_train = scaler.transform(des_train)

2、真正执行PCA

from sklearn.decomposition import PCA

pca = PCA(n_components=32, whiten=True).fit(des_query_new)
des_query_pca = pca.transform(des_query)
des_train_pca = pca.transform(des_train)

3、对结果再做归一化(欧氏距离就用l2)

import torch

def desc_l2norm(desc):
    eps_l2_norm = 1e-10
    return (desc / torch.Tensor(desc).pow(2).sum(dim=1, keepdim=True).add(eps_l2_norm).pow(0.5)).numpy()

des_query_new = desc_l2norm(des_query_pca)
des_train_new = desc_l2norm(des_train_pca)

4、注意train和query要用同一个fit,因为不然分开学习,肯定最后结果是个“0”。这里具体fit内容怎么设置,我还没整明白,随大流填个query的吧。。。

运行结果

  这时候再去做匹配,发现维度下降,有效果且精度甚至会上升。(图就不画了,懒。。。)
  注意:这里只是粗匹配上升了啊,它很可能有很多的误匹配的!!!

后言

其他还有umap可以玩玩。


[hide]
论文:https://arxiv.org/pdf/2006.10202.pdf
代码:
结构:

特点:
  HyNet是L2Net-HardNet-SOSNet系列本地补丁描述符的下一阶段。它与之前的作品有两个不同之处:

  1. HardNet体系结构中的BatchNorm和ReLU分别被FRN和TLU取代。
  2. 在训练过程中,为了更好的学习,以不同的方式计算到负(非匹配)样本d(0)和正(匹配)样本s(0)的距离,见下图。U和v表示描述符为:

[/hide]


目前仅供内部阅读,非常抱歉~


[hide]
知道大家最关心什么,所以,相关的Github链接:

基线与评估框架

基线:

评估:

流程:

指标:
1、0.95召回率时假阳性率(通常用于UBC PhotoTour)

  观察到这个度量与描述符的实际性能几乎没有关联,因此它的可用性仅限于模型训练期间的收敛性检查

2、平均精度(MAP)

  其中sij是查询i中第j大的分配置信度得分,V表示样本Sij和样本sij-1的召回率的差,P表示精度,考虑样本si, 1,…, Sij。APi的值是在查询Q中取的平均值,其中每个查询包含Ni个样本。这个度量在HPatches中有三个任务:

  • 验证:描述符用于为一对补丁分配一个分数,以指示它们是否对应。
  • 检索:有一个查询补丁,描述符用于从一组给定的补丁中检索相应的补丁,该补丁包含几个正数和大量的负数。
  • 匹配:与图像匹配管道最相关的任务是给定一个查询patch和一组包含一个正数的patch,找到对应的patch。

相关数据集

  • HPatches:此dataset是本地特性描述符基准测试的一部分。它包含116个场景,每个场景6张图像,根据主要的妨害因素,这些图像被分割为光照(57个场景)和视点子集。在光照分割中,场景是由静态网络摄像机在一天中的不同时间捕获的,视点分割包含显著的摄像机姿态变化。图像通过单应性与参考图像相关联。采用DoG、Hessian-Hessian和Harris-Laplace检测器进行关键点提取。参考图像中最小的patch大小为16x16像素,而提取的patch大小为65x65。补丁根据数量被进一步划分为难度级别(简单,困难和非常困难)
  • PhotoSynth(PS):数据集包含了来自30个场景的光照和视角变化的补丁。使用COLMAP SfM软件进行三维重建,并验证补丁的对应关系。每个patch的缩放和旋转都是标准化的。尺寸最小为20x20像素,最大为128x128像素。裁剪后的补丁大小调整为48x48px。从每个场景中提取大约40万个patch。经过训练的描述符在视点分割的HPatches基准测试中达到了最先进的性能。然而,它牺牲了对光度变化的鲁棒性。虽然场景包含光度变化,训练的描述符只有在HPatches的视点分割上才能获得更好的结果。
  • UBC Phototour(也叫Brown):由3个场景组成:Liberty、Notredame和Yosemite。利用Bundler structure-from-motion库对原始图像构造点云三维重建和密集深度图,获得相应的patch集。利用高斯差和哈里斯特征点检测器对每个场景进行重构。Liberty序列经常被用作一个单独的数据集来训练。它也被用于测试,但随着学习描述符的兴起,通常使用的FPR95指标已经低于1%,使这个基准饱和。
  • IMW Phototourism 2020:这个数据集是最近为即将到来的CVPR图像匹配研讨会创建的,是广泛的评估软件的一部分。目前它包含13个训练场景,3个验证场景和10个测试场景。使用COLMAP SfM软件进行三维重建,并验证补丁的对应关系。每个文件夹的3D重建场景包含2D到3D点通信。它不提供尺度和旋转的信息,提取的小块不易归一化。然而,我们观察到,就训练过的描述符的性能而言,这并不是一个大问题。由于这些图像是由Phototourism数据获得的,它涵盖了一些天气和照明的变化。提取的小块的数量与所有图像中关键点的总数成正比,并且在整个场景中变化很大。如Brandenburg Gate有超过200万个补丁,而Trevi Fountain有超过1500万个补丁
  • AMOS Patches:可用于提高局部描述符对光度变化的鲁棒性的训练数据很少。我们建议通过引入AMOS Patches数据集来填补这一空白。它是由AMOS全球静态网络摄像机集合创建的,涵盖了各种照明和季节相关的采集条件。AMOS是一个从户外网络摄像机中收集的持续增长的公开可用数据集,目前包含超过10亿(或20 TB)的图像。它被组织成单独的相机目录,这些目录根据收购的年份和月份被分成文件夹。图像的大小不同,它们的质量和每个相机目录中的图像数量也不同。典型的AMOS相机是静态的,大约有300x 300像素大小。许多相机可以在所有季节和全天存储图像。

相关模型

  • L2NET:介绍了相对简单的卷积网络架构,输出长度为128的向量。
  • HardNet:网络采用L2Net架构并引入了Hard采样的三态损耗函数。
  • GeoDESC:使用来自多视图重建的几何约束。
  • SOSNet:引入了二阶相似性正则化,该正则规则化被添加到loss函数。

(总结:以上其实都是L2Net结构,只是变了loss函数)

  • VGG:HardNet是一种VGG风格的网络,它由空间大小逐渐减小的卷积层块组成,并且通道数量不断增加。
  • HardNet变体:与原始版本相比:

    • HardNet7x2每层通道数增加了两倍。
    • HardNet8在第块中增加了一个卷积层。
    • HardNet9在第和第块中增加了两个层。
    • HardNet8x2每层的通道数是HardNet8的两倍。
    • 注意:HardNet架构的输入大小为32x32像素。由于观察到从HardNet8进一步扩大模型体系结构并不能带来更好的性能,因此调整HardNet8架构,使其预期输入更大的尺寸。首先,在倒数第二层将stride改为2,然后输入大小为64x64像素。如果我们还将最后一个卷积层的内核大小设置为6x6像素,则输入大小为48 x48像素。请注意两个相反的趋势:在HPatches和AMOS Patches上,更大的输入大小导致更好的性能,但是这样的模型在IMW PT基准上给出了较差的结果
  • ResNet:另一种流行的体系结构类型是ResNet。它由称为ResBlock的卷积层块组成。每个块的输出与它的输入相加,因此网络学习的是增量变化,而不是直接转换。然而,在我们的所有实验中,它都不是更好的,而且它对GPU内存的要求更高,所以我们不建议使用这种架构类型来学习一个局部特征描述符。

HardNet变体-结构:

HardNet变体-评估:

Resnet-结构:

Resnet-评估:

HardNet结构:

  HardNet描述符在各种基准测试中的性能很好。HardNet描述符是一个实值卷积网络,输出向量长度为128,输入patch大小为32x32p像素。该体系结构采用VGG风格,由卷积层组成,每个层后面依次是批处理归一化ReLU激活。使用p=0.3Dropout。输入到网络的是均值方差归一化loss函数:

  M是margin,如果后一段距离与前一段距离之差至少为M,则损失为零。

各个实验比较

不同图像缩放程度下

不同模态数据集


  G为灰度,D为(估计单)深度。

不同数据集大小


  ei为补丁集i在其包含的所有补丁上的这些差异的平均值。

较小数据集下的HardNet:

多数据集训练


  结合这些数据集可以带来一些改进。然而,有几件事你必须要小心。首先,在某些情况下,我们经常会经历相反的行为,例如:在Colosseum训练的HardNet8获得70.75 mAA(100),而添加Liberty则获得70.21 mAA(109)。从某种意义上说,这种负面影响可以通过描述符的压缩来恢复,因为我们发现,如果模型在更多的数据集上训练,降维效果会更好。

不同输入大小

不同的输出大小


  输出向量变长,带来内存占用率高、最近邻搜索速度慢等缺点。如果我们将HardNet8的输出大小减少到128以匹配SIFT的向量长度,我们将得到较差的结果:在IMW PT基准上68.75 mAA(109)和69.43 mAA(109)。另一种减少输出大小的方法是使用降维技术。在此,我们利用主成分分析(PCA)来压缩特征嵌入。降维是有益的。我们可以看到,最好的组合是HardNet8,输出大小为512,然后压缩为128。在这个实验中,我们在UBC Phototour的Liberty数据集上进行训练,我们在训练数据的模型输出上拟合PCA。

最后的池化影响


替换最后一个卷积层为:

  • 增加接收域:不优于基线。
  • local pool:性能比基线更糟糕。
  • Non-learned Pooling:MaxPool实现更糟糕的结果,AvGPool无法学习。

不同的margin

不同的batch size

不同的epoch数

不同模型的评估

结论

1、更多数据集的训练可能会使描述符质量恶化。
2、resnet类架构和模型不如那些vgg类模型。类似的观察也发生在切换到局部池或增加接受域。
3、更大的训练批量是有益的。
4、使用PCA压缩网络输出可以在IMW PT基准测试中获得更好的结果。
5、在减少了一个数量级的数据集上进行训练,可以获得类似的性能。
6、通过切换到RGB或用估计的单深度映射连接补丁来丰富数据模式,会导致有限或没有任何改进。
7、在手动选择摄像机进行训练时,小而多样化的子集比具有相似视图或不精确对齐的图像的大子集更好。
8、在训练过程中对一批patch进行采样时,使用较少的源摄像机是有益的。

参考文献

1、Improving the HardNet Descriptor

[/hide]


目录

  • conda
  • virtualenv
  • 其他

conda

查看版本

conda –V

更新conda

conda update conda

查看已有环境

conda env list

建立新的虚拟环境

conda create --name myenv python=3.5

启动虚拟环境

conda activate myenv

查看虚拟环境安装列表

conda list

安装包

conda install numpy
pip3 install numpy

退出虚拟环境

deactivate

删除包

conda remove --name myenv numpy
pip3 uninstall numpy

删除虚拟环境

conda env remove --name myenv

virtualenv

创建虚拟环境

virtualenv --no-site-packages myenv  --python=python3.6

启动虚拟环境

source myenv/bin/activate

# windows:
.\myenv\Scripts\activate.ps1
或
.\myenv\Scripts\activate.bat

安装包

pip3 install numpy

删除包

pip3 uninstall numpy

退出虚拟环境

deactivate

删除虚拟环境

# 删除这个文件夹即可
rm -rf myenv

其他

鉴于virtualenv不便于对虚拟环境集中管理,所以推荐直接使用virtualenvwrappervirtualenvwrapper提供了一系列命令使得和虚拟环境工作变得便利。它把你所有的虚拟环境都放在一个地方。