基于keras实现多标签分类(multi-label classification)

共 2340字,需浏览 5分钟

 ·

2022-02-06 09:12

6451122454d52119b3c6685a46260a4d.webp

向AI转型的程序员都关注了这个号👇👇👇

机器学习AI算法工程   公众号:datayx


首先讨论多标签分类数据集(以及如何快速构建自己的数据集)。


之后简要讨论SmallerVGGNet,我们将实现的Keras神经网络架构,并用于多标签分类。


然后我们将实施SmallerVGGNet并使用我们的多标签分类数据集对其进行训练。


最后,我们将通过在示例图像上测试我们的网络,并讨论何时适合多标签分类,包括需要注意的一些注意事项。


相关代码,获取方式:

关注微信公众号 datayx  然后回复 多标签分类 即可获取。



数据集包含六个类别的2,167个图像,包括:

黑色牛仔裤(344图像)
蓝色连衣裙(386图像)
蓝色牛仔裤(356图像)
蓝色衬衫(369图像)
红色连衣裙(380图像)
红色衬衫(332图像)

6类图像数据可以通过python爬虫在网站上抓取得到。


c1bde613a58e0a8e9befc69e90708c00.webp


为了方便起见,可以通过使用Bing图像搜索API(Microsoft’s Bing Image Search API)建立图像数据(需要在线注册获得api key,使用key进行图像搜索),python代码:


913281c57a6fd6675f6c4bc0fa4e0fc9.webp

59fed41fc57e23be6f94fb73eda362f2.webp


使用find方法得到下载的图像数据数目

088eedcab281c2e7c54fe30857a343bb.webp




多标签分类multi-label classsification

这里给出的是项目的文件结构 

b3d98198092af731ac444c20ac363e21.webp



多标签分类的网络结构--smallervggnet【Very Deep Convolutional Networks for Large Scale Image Recognition.】

https://arxiv.org/pdf/1409.1556/


smallervggnet.py

f31393f5556368520ca786cabbc9e1a6.webp

566c7a06596ff415b53142deb7b6eebd.webp

baa4710405264a10420cf443d78ac548.webp


train.py

f9e8cb696cdf670c31c00961a73c351e.webp

c5f7168be8fc1384614dede3ef8eb624.webp

bd43d092c838e62624f9d5d6889d0911.webp


run

140955cf4cc0f09c3b3c681e6996ed40.webp


继续preprocessing 

18ae54635c88797b485ffd305ba50858.webp


run

9764b69272d3f56afaab78bf5c1a5993.webp


构建训练和测试数据集,做数据增强

648682d2358481bb7dcbca75a661d684.webp



构建模型,初始化Adam优化器

bfd53f0efaf63a01068389cdc6d505af.webp



编译模型,开始训练

ec6766694bef38fcdce78b01264e3be3.webp



训练后保存模型,并二值化标签

17fe1bf5564c0e208f31f43af38deec0.webp


绘制出acc,loss

7e4b944dc033b3c2f6e57e62eac2ab9e.webp


绘制好的结果会保存成图片格式保存。


多标签分类模型训练

python train.py --dataset dataset --model fashion.model --labelbin mlb.pickle

使用训练完成的模型预测新的图像 

classify.py

6247f4c7177c4d85ee40c81eb9b456eb.webp

8b5525246250ab5a4c1cec1d9329da47.webp



最终显示出预测的分类结果

fe58bd63caf276320aef48ad28a86567.webp


使用Keras执行多标签分类非常简单,包括两个主要步骤:

1.使用sigmoid激活替换网络末端的softmax激活
2.二值交叉熵作为分类交叉熵损失函数


shortcomings:

网络无法预测没有在训练集中出现过的数据样品,如果出现的次数过少,预测的效果也不会很好,解决办法是增大数据集,这样可能非常不容易,还有一种用的已经很多的方法用在大的数据集上训练得到的权重数据对网络做初始化,提高模型的泛化能力。


机器学习算法AI大数据技术

 搜索公众号添加: datanlp

长按图片,识别二维码




阅读过本文的人还看了以下文章:


TensorFlow 2.0深度学习案例实战


基于40万表格数据集TableBank,用MaskRCNN做表格检测


《基于深度学习的自然语言处理》中/英PDF


Deep Learning 中文版初版-周志华团队


【全套视频课】最全的目标检测算法系列讲解,通俗易懂!


《美团机器学习实践》_美团算法团队.pdf


《深度学习入门:基于Python的理论与实现》高清中文PDF+源码


《深度学习:基于Keras的Python实践》PDF和代码


特征提取与图像处理(第二版).pdf


python就业班学习视频,从入门到实战项目


2019最新《PyTorch自然语言处理》英、中文版PDF+源码


《21个项目玩转深度学习:基于TensorFlow的实践详解》完整版PDF+附书代码


《深度学习之pytorch》pdf+附书源码


PyTorch深度学习快速实战入门《pytorch-handbook》


【下载】豆瓣评分8.1,《机器学习实战:基于Scikit-Learn和TensorFlow》


《Python数据分析与挖掘实战》PDF+完整源码


汽车行业完整知识图谱项目实战视频(全23课)


李沐大神开源《动手学深度学习》,加州伯克利深度学习(2019春)教材


笔记、代码清晰易懂!李航《统计学习方法》最新资源全套!


《神经网络与深度学习》最新2018版中英PDF+源码


将机器学习模型部署为REST API


FashionAI服装属性标签图像识别Top1-5方案分享


重要开源!CNN-RNN-CTC 实现手写汉字识别


yolo3 检测出图像中的不规则汉字


同样是机器学习算法工程师,你的面试为什么过不了?


前海征信大数据算法:风险概率预测


【Keras】完整实现‘交通标志’分类、‘票据’分类两个项目,让你掌握深度学习图像分类


VGG16迁移学习,实现医学图像识别分类工程项目


特征工程(一)


特征工程(二) :文本数据的展开、过滤和分块


特征工程(三):特征缩放,从词袋到 TF-IDF


特征工程(四): 类别特征


特征工程(五): PCA 降维


特征工程(六): 非线性特征提取和模型堆叠


特征工程(七):图像特征提取和深度学习


如何利用全新的决策树集成级联结构gcForest做特征工程并打分?


Machine Learning Yearning 中文翻译稿


蚂蚁金服2018秋招-算法工程师(共四面)通过


全球AI挑战-场景分类的比赛源码(多模型融合)


斯坦福CS230官方指南:CNN、RNN及使用技巧速查(打印收藏)


python+flask搭建CNN在线识别手写中文网站


中科院Kaggle全球文本匹配竞赛华人第1名团队-深度学习与特征工程



不断更新资源

深度学习、机器学习、数据分析、python

 搜索公众号添加: datayx  


浏览 41
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报