大家好,我是一名曾经只会excel的数据分析师。
后来经我的同事大鹏点拨,我知道了Python数据分析,向他学习进入了一条通神之路。今天是我“略懂”Python数据分析的第200天。
在这200天里,我的工作效率逐渐变高,处理数据量从千到万,接的项目越来越复杂,老板看我的眼神也越来越柔和,有时甚至单独请我吃饭……看来我很快就能升职加薪!
高兴之余,我对我的Python技术能力也有点担心,甚至陷入了一种瓶颈:
1. 工作中有大量的描述性统计工作,要求不高,对我这种审美捉急的人来说,excel的快速样式有时候很关键。
2. 我很少碰到Python能做而excel不能做的数据处理,excel很慢甚至死机,但只要电脑性能好,总能完成;
3. 虽说会Python是优势,但公司的excel普及程度很高,介于项目合作原因我总是需要用excel衔接数据合作。
这不免导致我对Python技能的定位产生怀疑,我称这个现象叫非典型性Python冷淡综合症。
新刺激来的很快,就在今天,带我入Python坑的同事大鹏介绍来了一个新人小覃。我很快感觉到老板对我关爱的眼神落到了小覃身上。这不,他们正在工位电脑前谈笑风生。
这怎么行!老板最宠的只能是我!
我决定再次展开“欢迎新人”套近乎策略,探探这位新人如此招待见的原因。
走近他们,我先注意到了小覃电脑屏幕上有一堆猫猫狗狗照片,而小覃正在边写python代码边和老板解释什么。只见他迅速写了十几行代码并运行,成功地识别了图片里的猫。
第一步:进行模型训练,构建识别猫狗的CNN模型
第二步:测试一张测试集里的照片,确认照片的分类为猫
这看似简单的操作却这让我和老板都很好奇。
我从未处理过除了CSV和JSON以外格式的数据,面对新的思路,我不禁怀疑是否自己之前太过浅薄。
而老板一个劲的点头,说找对了人,接下来的AI旅游小程序项目有亮点了,咱们的产品肯定会刷爆朋友圈,还一边拿手机里的产品概念图给小覃看:
图中为计算机通过机器学习识别街景图片中的行人、自行车和机动车并定位边界。该数据有助于识别城市道路使用情况,甚至研究街道美学,能帮助使用者快速认知陌生城市。本图来自“城室科技”,欢迎有兴趣的小伙伴微信自行搜索。
看来面前是一位新大神,经验告诉我,喂到嘴边的大腿不能不跪,我立刻上前献上的膝盖,说道:覃大哥,小弟也算略懂Python,之前在公司做数据分析工作,但从没完成过你这么酷的操作,快教教小弟,你刚刚用Python干了什么?
覃大哥笑道:过奖了,其实刚刚就是基本的利用机器学习神经网络算法来识别图片里的对象。我使用Python加载深度学习工具包Keras,构建了一个是简单卷积神经网络(CNN)模型进行猫狗识别,用于给老板解释原理。你也一起听吧。
总的来说,我有一些猫狗图片,作为训练集数据(Training Set),它们是用于建立和优化模型的已经有标签的原始数据。而我们也会有一些测试集数据(Test Set),用于检验模型。我的目标是为了构建一个模型系统,把未知猫狗标签图片放进这个系统进行测试,正确地给它们打上是猫还是狗的标签。
图为实时识别猫狗的动态位置,算法来自 Joseph Redmon ,他研究使用计算机视觉的一种检测系统yolo来定位他家的猫狗,相关介绍可自行搜索ted演讲How computers learn to recognize objects instantly。
一个好的模型并不是一蹴而就,需要进行调整。比如我刚建立的CNN模型的准确率大概只在50%到60%,很低。因此实际应用上,我们一般会投入大量精力做一些提高准确率的操作。
常用的操作包括增加训练集样本数量、尝试使用更多或更少的特征值、集成模型等等方法。这决定了学习机器学习必须要捡起你的数学,不过这都是后话。
分辨猫狗是业界一个成熟案例,这里我们以一个训练好的图像分类模型VGG16为例,以便得到更准确的结果:
<p style="margin-right: 8px;margin-left: 8px;padding: 0.5em;max-width: 100%;min-height: 1em;line-height: 18px;font-size: 14px;letter-spacing: 0px;font-family: Consolas, Inconsolata, Courier, monospace;border-radius: 0px;color: rgb(169, 183, 198);background: rgb(40, 43, 46);box-sizing: border-box !important;overflow-wrap: normal !important;word-break: normal !important;overflow: auto !important;"><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"> 1</span><span class="" style="max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(128, 128, 128);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"># 搭建全连接层</span><br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"> 2</span>top_model = Sequential()<br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"> 3</span>top_model.add(Flatten(input_shape=<span style="max-width: 100%;background-color: rgb(2, 30, 170);box-sizing: border-box !important;overflow-wrap: break-word !important;">vgg16_model</span>.output_shape[<span class="" style="max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;">1</span>:]))<br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"> 4</span>top_model.add(Dense(<span class="" style="max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;">256</span>,activation=<span class="" style="max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(238, 220, 112);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;">'relu'</span>))<br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"> 5</span>top_model.add(Dropout(<span class="" style="max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;">0.5</span>))<br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"> 6</span>top_model.add(Dense(<span class="" style="max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;">2</span>,activation=<span class="" style="max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(238, 220, 112);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;">'softmax'</span>))<br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"> 7</span><br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"> 8</span>model = Sequential()<br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;"> 9</span>model.add(vgg16_model)<br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /><span class="" style="padding-right: 20px;max-width: 100%;font-size: inherit;line-height: inherit;color: rgb(174, 135, 250);box-sizing: border-box !important;overflow-wrap: inherit !important;word-break: inherit !important;">10</span>model.add(top_model)<br style="max-width: 100%;box-sizing: border-box !important;overflow-wrap: break-word !important;" /></p>
左右滑动查看代码,获取完整代码请看文末
用此方法我们便可以更精确的辨认出猫狗。不管猫主子是何种奇特姿态,准确率都比较高,可达到85%。
覃大哥放下鼠标,转过头来,对我和老板说道:这是一个示例,让大家理解机器学习的一种工作方向,这个方向被称为“计算机视觉”,大家经常听说的的图像识别就是这门技术里的内容。老板想完成旅游小程序,用计算机视觉技术研究街景必不可少。
此时的我突然茅塞顿开,这不就是我一直找寻的突破口吗?早就听说人工智能机器学习,但一直觉得自己数学不好没有着手学习。现在看到演示,才发现千里之行,始于足下。
于是我立马向他问道:覃大神,请接收小弟的仰慕,能否教我这门技术,小弟能打水能锤肩学得快!
覃大神这候笑了:可以啊,入门不难,有个好老师带更是事半功倍,来网易云课堂免费体验一下便知:
Part.1
免费直播课
Part.2
免费7天计算机视觉体验课
Part.3
文中的模型及数据
1.25000张猫狗图片数据
2.猫狗识别代码及训练后的模型
3.文中涉及的Inception模型及学习框架
Part.4
7.6 G不可错过的AI入行秘籍
1. 6G Python入门资料
AI学习的必备帮手
2. 120+篇最新最全的AI报告
遍布政府、证券、咨询、IT等相关行业
3. 6门行业权威亲自授课的在线免费课程
160+篇涉及深度学习、计算机视觉各方向的论文(中英兼备,既泛且精
4. 20+部从小白到高手都能获益的人工智能PDF资料
含人工智能和机器学习领域国际权威学者吴恩达手稿
Part.5
领取方式
扫码加入QQ群
群号:929246020
席位有限,先到先得~
点击【阅读原文】,免费领取福利
本篇文章来源于: 菜鸟学Python
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ 常用python过滤器的排列11/10
- ♥ Python zip函数及用法11/21
- ♥ Python选择排序算法的性能分析10/11
- ♥ python中的global是什么意思?08/12
- ♥ Python3 枚举类比较的局限性是什么?12/22
- ♥ 如何在python中打开带有乱码的中文文件名10/22
内容反馈