pdf code

SuperPoint: Self-Supervised Interest Point Detection and Description

这篇论文完成的任务是从一张图中使用神经网络提取出keypoints,这些keypoints的关键是要求对旋转,scale,平移鲁棒。

Training procedure

image

训练过程需要三个阶段,第一个阶段,使用一些简单的几何图片,用一些没有歧义的图片和keypoint,进行初始训练。

第二阶段,使用一些没有label的真实图片,对同一张图,使用Homographic transform(旋转平移等的组合),转换成一个batch的图.用前文的detector,生成keypoint,再转换为原图坐标系中。这个batch会在当前图形成一个keypoint的heatmap. 第三阶段,使用joint training。进行训练

网络模型

image

第一阶段只使用上部分那一支,第三阶段会有descriptor部分。

Encoder类似于VGG,

Interest Point Decoder,65个Channels,意思是周边个方块有keypoint的概率,还有一个是空类. 这里的对应的是pytorch.nn.pixelshuffel操作,将channel的内容翻到feature map空间的区域。

如果ground truth里面区域里面有不止一个点则随机选取一个作为该区域里面有效的ground truth。

这里使用cross-entropy,计算进行训练。

descriptor的训练,依靠的是同一张图,将图homographic transform到另一张图去,要求keypoint对应的位置描述相同。指代对应关系