百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

产品经理也能动手实践的AI(四)- 多标签识别,图像分割

off999 2024-10-10 07:56 29 浏览 0 评论

上一篇讲了产品经理也能动手实践的AI(三)- 深入图像识别,在线辨猫,形象的说明了SGD的原理,就是如何将一个线性函数你和到我们预设的散点图上。今天主要讲2个案例,1个核心模块,分别是卫星图像的多标签识别,图片分割着色,数据块这个核心模块。

这也是图像识别的最后一课了,我承认到这里可能就有点枯燥了,因为有很多需要消化的东西,不过我觉得重点是大概理解这是怎么一回事儿,以及把自己关注的点研究明白,不见得每个细节都要在一开始搞明白。

接下来就会讲解NLP和协同过滤,而且这节课也没有什么特别全新的东西,都是细节上的提升或者更详细的讲解。而我印象最深的就是u-net这个模型,以及他的lr(指代Learning Rate学习率,下文都会直接用lr来代替)训练方式,是先增后降。

1.概览

本节课主要讲解的是多标签识别(用卫星图像预测天气),图像分割(用不同颜色区分行人、道路、房子等),还有支持这两种类型的核心模块 - data block。

这是卫星图片,以及对应的标签

这是如何将一副路边的图像,用无人驾驶的视角按类别变成色块

2.1核心流程

  • 下载数据(这一节主要来源于公共数据库)
  • 创建databunch(data block的核心流程)
  • 准备输入的数据
  • 划分训练组和验证组数据
  • 给输入的数据打标签
  • 「可选」变形
  • 「可选」增加测试组
  • 转化成databunch
  • 创建learner
  • 开始训练
  • 调优

2.2核心数学概念

  • U-net:相对于CNN卷积神经网络,有更好的效果,普通的CNN只做到了左侧下降的把图片拆成一片一片的小块的过程。
  • Sigmoid函数:又叫做S型生长曲线,是以前神经网络用的最多的函数,现在都用ReLU
  • ReLU(rectified linear unit):线性整流函数,是一种人工神经网络中常用的激活函数(activation function),通常指代以斜坡函数及其变种为代表的非线性函数。
  • 通用逼近定理:当有一组线性和非线性函数,你就可以做出一个无线接近任意函数的函数。

2.3核心机器学习概念

  • flip翻转:在transform的时候,可以随机水平翻转或者垂直翻转图像,来提高训练的准确度,默认是水平翻转,比如训练识别猫的AI,而识别卫星图像的就可以同时垂直旋转;
  • warp透视:和45度拍照显脸小是一个道理,就相当于对一个正面拍摄的照片做了一个透视处理,虽然都是你本人,但是在图像上呈现的效果不同,所以这样的处理可以提高识别准确度;
  • normailize规范化:后面会专门讲
  • threshold阈值:主要是多标签时用,因为识别时会有N个结果,不像单标签,选最大的那个就行(argmax),这里要选threshold值以上的;
  • DataSet:数据集,只有getitem和len属性
  • DataLoader:用于把DataSet中的数据,按要求抽取成一个个mini-batch
  • DataBunch:训练组DataLoader和验证组DataLoader的组合
  • Mixed Precision Training 混合精确训练:创建learner时用16bits代替32bits,需要GPU支持

2.4核心Python、FastAI、Jupyter等命令

  • !:是在Jupyter Notebook中执行命令行的操作,如:# ! conda install -y -c haasad eidl7zip
  • Pandas:处理表格数据和常用库,比如查看数据:df = pd.read_csv(path/'train_v2.csv')
  • partial:Python3的特性,可以非常方便的生成一个具备固定参数的函数,这样代码看起来就更好懂,比如:acc_02 = partial(accuracy_thresh, thresh=0.2)
  • .shape:Image.shape 会给出这个tensor的大小,主要是包含channels,类似于维度,这个之后会讲 (channels x height x width)
  • .plot:把学习过程的数据打出来,loss,lr,等各种指标
  • lambda:匿名函数,即没有函数名的函数,例如输入x返回x+1:result = lambda x:x+1
  • 双斜杠:Python里相除取整的意思,比如size = src_size//2

3.1实例详细分析(用卫星图像预测天气)

上一节讲的是通过Google image自己找图片然后自己下载下来,打上标签。这一届直接用Kaggle竞赛提供的数据。

  • 下载数据
  • 注册Kaggle
  • 安装Kaggle下载工具 ! pip install kaggle --upgrade
  • 授权
  • 创建API Token - kaggle.json
  • 下载并传到自己的Jupyter目录
  • 接受该卫星项目许可(不然会遇到下载失败情况)
  • 下载数据下载 kaggle competitions download -c competition_name -f file_name.
  • 解压缩数据 需要安装edil7zip
  • 创建DataBunch
  • 先养成查看数据的习惯,看目录结构,看数据样本 pd.read_csv
  • 准备输入的数据 ImageFileList.from_folder(path)
  • 划分训练组和验证组数据 random_split_by_pct(0.2)
  • 给输入的数据打标签 label_from_csv()
  • 「可选」变形 transform(tfms, size=128)
  • 「可选」增加测试组
  • 转化成databunch databunch().normalize()
  • 训练模型
  • 调优
  • 核心小技巧:先训练128x128尺寸的图像,然后再用迁移学习,训练256x256尺寸的图像,这样又快又准

3.2实例详细分析(图像分割,用不同颜色区分行人、道路、房子等)

  • 下载数据,通过内置的Camvid数据库
  • 查看数据,找到一条数据,用open_mask打开看看
  • 创建databunch SegmentationItemList.from_folder(path_img)
  • 创建learner 使用u-net代替CNN来训练模型
  • 开始训练
  • 调优

3.3原理详细分析

learn.recorder.plot_losses()

learn.recorder.plot_lr()

为什么lr会先升后降呢,这就是fit_one_cycle做的方式,因为相对而言,这种学习效率更高,形象点说就是先探探路,然后再大步走,感觉方向对了,就逐渐放慢脚步,然后到达那个最优点。如下演示的是以一个固定的lr,如下分别是lr为0.1,0.7,0.99,1.01时的机器的学习路径,看到0.7是最快接近底部,也就是loss最低的时候,而过低的lr和过高的lr都会影响效率,而高到一定程度反而会无法触达底部。

这是一种比较理想的情况,而实际应用中不会有这么平滑的弧度,肯定有各种小坑,而那时,固定的lr很容易陷到某一个小坑中而得到了不够理想的准确度,俗称拟合不足。

所以这里采用了更加动态的lr,只需要设定一个上限值,系统就会自动生成一个lr的抛物曲线,然后得到更准确的模型。

4.最后

本节课还讲了一个用回归模型识别头部中心点的例子,以及如何用IMDB数据预测评论的正负面情绪(NLP),之后的课程有更详细的讲解,所以这里就先不展开。

相关推荐

PYTHON-简易计算器的元素介绍

[烟花]了解模板代码的组成importPySimpleGUIassg#1)导入库layout=[[],[],[]]#2)定义布局,确定行数window=sg.Window(&#...

如何使用Python编写一个简单的计算器程序

Python是一种简单易学的编程语言,非常适合初学者入门。本文将教您如何使用Python编写一个简单易用的计算器程序,帮助您快速进行基本的数学运算。无需任何高深的数学知识,只需跟随本文的步骤,即可轻松...

用Python打造一个简洁美观的桌面计算器

最近在学习PythonGUI编程,顺手用Tkinter实现了一个简易桌面计算器,功能虽然不复杂,但非常适合新手练手。如果你正在学习Python,不妨一起来看看这个项目吧!项目背景Tkint...

用Python制作一个带图形界面的计算器

大家好,今天我要带大家使用Python制作一个具有图形界面的计算器应用程序。这个项目不仅可以帮助你巩固Python编程基础,还可以让你初步体验图形化编程的乐趣。我们将使用Python的tkinter库...

用python怎么做最简单的桌面计算器

有网友问,用python怎么做一个最简单的桌面计算器。如果只强调简单,在本机运行,不考虑安全性和容错等的话,你能想到的最简单的方案是什么呢?我觉得用tkinter加eval就够简单的。现在开整。首先创...

说好的《Think Python 2e》更新呢!

编程派微信号:codingpy本周三脱更了,不过发现好多朋友在那天去访问《ThinkPython2e》的在线版,感觉有点对不住呢(实在是没抽出时间来更新)。不过还好本周六的更新可以实现,要不就放一...

构建AI系统(三):使用Python设置您的第一个MCP服务器

是时候动手实践了!在这一部分中,我们将设置开发环境并创建我们的第一个MCP服务器。如果您从未编写过代码,也不用担心-我们将一步一步来。我们要构建什么还记得第1部分中Maria的咖啡馆吗?我们正在创...

函数还是类?90%程序员都踩过的Python认知误区

那个深夜,你在调试代码,一行行检查变量类型。突然,一个TypeError错误蹦出来,你盯着那句"strobjectisnotcallable",咖啡杯在桌上留下了一圈深色...

《Think Python 2e》中译版更新啦!

【回复“python”,送你十本电子书】又到了周三,一周快过去一半了。小编按计划更新《ThinkPython2e》最新版中译。今天更新的是第五章:条件和递归。具体内容请点击阅读原文查看。其他章节的...

Python mysql批量更新数据(兼容动态数据库字段、表名)

一、应用场景上篇文章我们学会了在pymysql事务中批量插入数据的复用代码,既然有了批量插入,那批量更新和批量删除的操作也少不了。二、解决思路为了解决批量删除和批量更新的问题,提出如下思路:所有更新语...

Python Pandas 库:解锁 combine、update 和compare函数的强大功能

在Python的数据处理领域,Pandas库提供了丰富且实用的函数,帮助我们高效地处理和分析数据。今天,咱们就来深入探索Pandas库中四个功能独特的函数:combine、combine_fi...

记录Python3.7.4更新到Python.3.7.8

Python官网Python安装包下载下载文件名称运行后选择升级选项等待安装安装完毕打开IDLE使用Python...

Python千叶网原图爬虫:界面化升级实践

该工具以Python爬虫技术为核心,实现千叶网原图的精准抓取,突破缩略图限制,直达高清资源。新增图形化界面(GUI)后,操作门槛大幅降低:-界面集成URL输入、存储路径选择、线程设置等核心功能,...

__future__模块:Python语言版本演进的桥梁

摘要Python作为一门持续演进的编程语言,在版本迭代过程中不可避免地引入了破坏性变更。__future__模块作为Python兼容性管理的核心机制,为开发者提供了在旧版本中体验新特性的能力。本文深入...

Python 集合隐藏技能:add 与 update 的致命区别,90% 开发者都踩过坑

add函数的使用场景及错误注意添加单一元素:正确示例:pythons={1,2}s.add(3)print(s)#{1,2,3}错误场景:试图添加可变对象(如列表)会报错(Pytho...

取消回复欢迎 发表评论: