Learning Image Conditioned Label Space for Multilabel Classification

论文相关内容

本文中解决多标记图像分类问题的方法:

该工作解决了多标签图像分类的问题。受深卷积神经网络(CNNs)在单标签视觉语义嵌入方面取得的巨大成功启发,我们利用这些模型对多标签图像进行扩展。具体来说,我们提出了一个依赖于图像的排序模型,该模型根据标签与输入图像的相关性返回标签的排序列表。与传统的CNN模型学习图像表示(即图像嵌入向量)不同,本文模型从图像中学习映射(即转换矩阵),试图区分其相关和不相关的标签。尽管我们的方法在概念上很简单,但是在公共基准数据集上的实验结果表明,与其他多标签分类方法相比,该模型在使用较少的训练图像的情况下实现了最先进的性能。

本文主要思想和模型:

*加粗样式
在这里插入图片描述
本文是基于AlexNet模型进行转换矩阵A的学习,通过转换矩阵A把用词向量表示的标签,从d维的词向量空间转换到k维的欧式空间再根据与原点的距离进行相关标签和不相关标签的分类。

损失函数

在这里插入图片描述
在这里插入图片描述
这是本文所使用的铰链排序损失,它是对每个单独的不相关标签进行损失的求和,用平均相关标签的方式消除了误标签和差样本主导损失的情况。

标签的预测

W ={wi}表示标签集的向量表示。CNN模型接受一个输入图像I并返回一个转换矩阵A。对于每个wi,我们计算wi’ = Awi,并根据L2-norm对标签进行排序,即wi’到新空间原点的距离。检索距离较小的标签。

总结

相关背景:用于单标签视觉语义嵌入的CNNs的成功。
问题是什么:进行多标签图像的分类。
现有解决方案:WARP、CNN-RNN、MIE等方法。
作者的核心思想、创新点在哪里:本文基于视觉语言嵌入模型,提出了一种考虑了多标签之间的关系,学习一个线性转换矩阵来把表示标签的词向量转换到欧式空间进而进行多标签图像分类的模型。
通过什么样的实验进行验证:在NUS-WIDE数据集上使用3个对比算法和查全率、查准率等评价指标进行了多组实验,证明了本文模型的优势。
对我的启发:需习得利用已有的‘器’去解决自己所关注的问题。

### 回答1: calib_check_cond - ill-conditioned matrix for input array 0是一个计算机程序中的错误信息。这个错误信息通常出现在进行矩阵运算时,输入矩阵存在不良条件(ill-conditioned)的情况下。 矩阵的条件数(condition number)是矩阵的一个数值特征,用于描述矩阵在数值计算中的稳定性。当矩阵的条件数很大时,说明矩阵很不稳定,即很容易出现数值误差,这样的矩阵被称作不良条件的矩阵。 在程序运行中,如果输入的矩阵是不良条件的矩阵,就会出现上述的错误信息。这意味着程序无法进行矩阵运算,因为输入矩阵的条件数过大,导致程序不稳定,进而出错。 如果遇到这样的错误信息,我们应该首先检查输入矩阵是否正确。如果输入矩阵本身就存在问题,例如存在无穷或未定义的元素等,就需要修正输入矩阵,再重新运行程序。如果输入矩阵本身没有问题,那么可能需要使用更高精度的算法或者调整算法参数来改善程序的数值稳定性,同时提高程序的精度和效率。 ### 回答2: calib_check_cond是用于检查矩阵条件数的函数,通常被用于计算机视觉和机器学习领域。在使用calib_check_cond时,如果发现输入数组中的矩阵条件数过差,就会出现这种错误信息。 所谓条件数,是用于描述矩阵变形的一个指标。矩阵的条件数越大,就说明在矩阵变形时数据的精度越容易受到影响。因此,在使用calib_check_cond之前,需要先对数据集进行预处理,以确保输入矩阵在变形时不会出现过多的误差。 如果出现了calib_check_cond - ill-conditioned matrix for input array 0的错误信息,通常会有两种解决方案。第一种是通过重新选择、清洗或规范化数据集来降低矩阵的条件数。第二种则是通过增加算法的鲁棒性,让算法能在低条件数的矩阵中正常运行。 总之,在使用calib_check_cond时,需要注意输入矩阵的条件数,避免出现过大的误差。同时,也需要根据具体的情况选择合适的解决方案,以确保算法的稳定性和准确性。 ### 回答3: calib_check_cond - ill-conditioned matrix for input array 0 in function 'cal',这个错误提示是,在计算过程中使用了病态矩阵,导致计算的精度出现了问题,从而得到了不合理的结果。病态矩阵是指条件数非常大的矩阵,即矩阵中部分数值非常小或非常大,导致计算误差非常大。当一个矩阵的条件数很大时,意味着微小的误差会被放大,从而导致数值计算的不准确。 要解决这个问题,可以尝试使用数值稳定的算法或者重新设计算法,以克服矩阵条件数大的问题。另外,检查输入数据的有效性也是必要的。可以分析出错的数据,看看是不是存在错误的输入,或者数据本身就不合理。若是因为输入数据不合理导致的问题,需要调整输入数据以保证矩阵的条件数在一个合理的范围内。同时,也可以尝试使用数值精度更高的数据类型,例如Double precision浮点数,从而提高计算精度。 总之,遇到calib_check_cond - ill-conditioned matrix for input array 0 in function 'cal'这个错误提示,需要注意输入数据的有效性和矩阵的条件数,并采用合理的算法和数据类型进行优化,以获得更精确的计算结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值