补充一下MCAN-VQA:
data:image/s3,"s3://crabby-images/df1f6/df1f60d27e50cefa75487ffc956e50e6245cdc4a" alt=""
对图片的处理:首先输入图片到Faster R-CNN,会先设定一个判断是否检测到物体的阈值,这样动态的生成m∈[10,100]个目标,然后从检测到的对应的区域通过平均池化提取特征。第i个物体特征表示为:,所以一张图片就被表示为一个特征矩阵:
。
对问题的处理:首先分成词,最多分为14个词,然后用300-D GloVe word embeddings变成向量,然后过LSTM,使用LSTM所有单词的输出,得到问题特征矩阵:,n是分成的单词个数。
m和n可能不一样,用0填充到max(m,n)。
然后有了图片和问题的特征矩阵X和Y,送入下面的Deep Co-Attention Learning模块,由L层MAC层堆叠。
这个MAC层分为两种,stacking和encoder-decoder,和transformer很像,大概如下图:
data:image/s3,"s3://crabby-images/b39e2/b39e27202a77e1cb799c8d6493d06c411127eb2a" alt=""
data:image/s3,"s3://crabby-images/1cb0c/1cb0cf6e748ce35023351ab81b4d948afc2e750c" alt=""
data:image/s3,"s3://crabby-images/3ce1f/3ce1fc969f5a7e80ca56512d238b8f6b4a633d54" alt=""
Deep Co-Attention Learning模块输出的,
,送入Multimodal Fusion and Output Classifier模块,这个模块有个两层的MLP
,做attention reduction
data:image/s3,"s3://crabby-images/7167a/7167a1403c3140234fe2a7355dfd922e820f3627" alt=""
data:image/s3,"s3://crabby-images/a1517/a15176f2b730453e03acc3b597ec9c07609aa12b" alt=""
α是学习到的权重。
然后线性多模态融合:
data:image/s3,"s3://crabby-images/722d0/722d0dd3e0d47c192b5f6029ee92d89acee90d2e" alt=""
data:image/s3,"s3://crabby-images/56984/5698458ed18483af81dee51f666e591c61717d59" alt=""
得到Z之后后面就是做分类,sigmoid。
一些实验结果:
data:image/s3,"s3://crabby-images/5b457/5b457ea53ac829e312b6c1021a52590c5bd3daec" alt=""
所以SA(Y)-SGA(X,Y)比较好,Encoder-decoder比较好。