16. Segmentation
Difference Between Seg and Obj Detection¶
在分割中,我们不需要判断同一个种类的物件有多少个,只需要判断某一个像素属于哪一个种类即可。
Naive Seg¶
如果使用一个 sliding windows,对于每一个 pixel,我们 extract a patch around that pixel,然后放到 CNN 里去分类。
缺点在于:运算量过于巨大。
Fully CNN Seg¶
如上图,对整张图进行卷积操作(保证每个 feature map 的 HxW 不变),最后得到每个 pixel 上的 category feature。
然后,通过 \(\mathop{\arg\max}_c (score_c)\) 来得到 prediction,通过 softmax+多类别交叉熵损失函数来得到损失。
缺点:很多网络都采用 aggressive pooling at beginning,因为对于一张大图片进行卷积是非常 computationally expensive。而 fully CNN 只能够对全图进行卷积。这无疑也是非常慢的。
Down-Sampling-Then-Up-Sampling CNN¶
如图,一目了然。我们的问题就在于:如何进行 up-sampling。
How to Up-Sample?¶
最简单的方法,就是 bed of nails 或者 nearest neighbor。
如果希望获得均匀的效果,那么就应该使用 bilinear interpolation 或者 bicubic interpolation。
Choose Which Up-Sampling Method?¶
如果我们采用 max pooling,那么就最好使用同样地 (misaligned) bed of nails 进行 "max unpooling"
- 其中,nail 的位置和 max pooling 的 arg 位置有关。这是为了避免 misalignment。
如果我们采用的是 average pooling,那么 unpooling 的时候,就用 bilinear/bicubic。
Transposed Convolution¶
Transposed convolution,又名
- deconvolution
- upconvolution
- fractional strided convolution
- backward convolution
如图,我们使用卷积核 \([x,y,z]\) transpose-convolve \([a,b]\),从而得到 \([ax,ay,az,0,0],[0,0,bx,by,bz] = [ax,ay,az+bx,by,bz]\)。
这在计算上,就相当于把卷积的剧本乘法的 \(X\) 取了转置(如图)。
Instance Segmentation¶
Concept: Things and Stuff¶
我们一般将事物分为两类,即 thing 以及 stuff。
Definition¶
如图,object detection 只关心 things,而且会区分同类不同个的 things。
Semantic segmentation 关心 things 以及 stuff,但是不去区分 things 以及 stuff。
Instance segmentation,在 object detection 的基础上,还希望对每一个 thing 都进行 semantic segmentation。如下图所示:
Mask R-CNN¶
训练也很简单:我们对每一个 proposal 的 box 内的像素取出来,然后使用一个 mask segmentation 来判断。
注意:
- instance segmentation 里的 semantic segmentation 只能把其中的 "main thing" 识别出来,比如说上上图的左蓝框里的 "main thing" 是左侧的牛,因此不应该把右侧的牛的像素也包含进去。
- 此处的 mask segmentation,相比之前的 semantic segmentation,只需要做二元分类(判断某个像素是否属于该 proposal 的 main object)即可,而不需要进行分类
Great Idea In CV: R-CNN + "Heads"¶
如上图所示:
- keypoint est = obj detection + keypoint prediction
- ...
我们发现,我们可以将复杂的图像处理任务,通过 Faster/Mask R-CNN 进行预处理,然后将每一个 box 内的图像再通过一个 overhead 来进行细化的处理,从而完成我们的任务。