0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

AI项目研发过程中的一些感想

新机器视觉 来源:新机器视觉 作者:皮特潘 2021-01-07 14:16 次阅读

前言

AI虐我千百遍,我待AI如初恋。什么才是好的AI?答:能落地的AI才是好AI。AI项目从无到有,再到最终落地,无非不是挖坑、踩坑、填坑的过程。本文从笔者的一些经历、经验、血泪教训展开,说一下对AI项目研发过程中的感想。

被虐的案例

案例1:经过N次版本修改与优化,最终定稿。支持切换型号、云端训练、人工调参等。搞到最后,才发现别人要求准确率100%。

案例2:样机各种灯光闪来闪去,各种运动机构群魔乱舞。什么犄角旮旯都覆盖到,什么划痕、残缺、脏污都面面俱到。但是,一个产品检测竟然要30s。到过一次现场才发现,人工目检只需要2s。

案例3:光学算法、界面都ok了。在热火朝天、干劲十足的准备推广成千上百套变现的时候,客户说只要一套。

案例4:同上,最终客户说再考虑一下,当然是杳无音信。算是被耍呢?还是算是白嫖呢?

案例5:当我们正为识别准确率是99%的时候,客户把一个识别成功的和一个识别失败拿到一起,问:这两个明明一模一样,为啥这个失败了,这个成功了?

案例6:我去生产现场培训客户标注。他们非常配合,找来的也是目检老手。我示范了几个后,让他试试。他就是不肯,搞到最后才知道:额,他不会用电脑

案例7:我们的算法好牛掰,我们模型好先进。AI+传统方法一起来搞,完美。不过你需要调整这20个超参数。人呢?别走啊!

案例8:已经上线运行了,最后发现某一种型号的某一种缺陷打光不佳,图像上很难判断。最终只能推倒重来。

案例9:没有意识到数据的重要性,每次都是几张图片在测试,结果是很完美,最匆匆拍板上线。最终大批量测试的时候,发现不work了。

为啥这么难?

工业AI,尤其是缺陷检测这块都是硬骨头。虽然场景非常简单,虽然数据都是源源不断,虽然算法都是非常纯粹。主要是其需求太分散了,不是不能做,而是值不值得去做。因为你要面临以下问题:

说不清道不明、模棱两可的需求标准,某些难以量化的标准。

频繁的变更需求标准,难以做到只靠调后处理参数就快速响应。

频繁更换型号的场景,留给你训练的时间不多。甚至无法提供良好的训练环境。

立体的产品,各种吃光照,吃视角的缺陷,极其微弱的缺陷。

难以保证的样本一致性问题。

准确率能不能到100%?

有没有人工做的更快?

有没有人工费用更便宜?

需要配合繁复的硬件设备,尤其是运动设备。如何才能保证整套设备的稳定性?

后期维护成本问题?由于涉及的环节太多,需要“全才”才能搞定。

......

一般流程

AI要敏捷开发,更要方法论,更更要稳定成熟的流程。

a6c18c74-503b-11eb-8b86-12bb97331649.jpg

这里要提的是,工业场景的AI不过是整套系统中的一个小小组件,你一定不会靠单纯的AI去make money。即便如此,AI从无到有,依然经过以下几个环节:

需求阶段

包括场景分析,问题定义,可行性分析。很多任务都是从该阶段直接进入end。这个是好事,一定不要盲目自信和盲目乐观。所谓一叶障目不见泰山,只看到算法容易实现就忽略以上的问题,最后只能惨淡收场。最怕投入太多沉没成本之后,想收场却不甘心。

什么是需求,什么是真正需求,什么是隐藏等待发掘的真正需求。很多时候,和客户一起聊需求的时候,他们给不出明确的需求。最简单直接的办法就是,深入参观他们的生产现场。和工人融到一起,学会他们的判断标准。为他们发掘需求,尤其是下面几点必须提前明确清楚:

什么是绝对不能容忍的错误,一旦出现就是质量事故。我们要知道算法的下限在哪里。

涉不涉及更换型号,能否提供符合模型训练的场景要求,比如至少得有GPU吧,或者可以上网进行云端训练。

对时间上的要求,很多替换人工工位都要要求比人更快。我们要知道系统的物理极限,例如运动设备。

对于算法难以界定的灰色地带,接不接受人工二次复检。对于不work的个例,我们要有backup。

其他都比较直白,对于第二点说明一下。大家想必都知道,我们做算法复现的时候,推理部分比训练部分要容易好几个等级。同理,上线部署的时候,如果涉及用户自己训练,那么难度就上来了。要把标注、数据处理、训练参数、测试评估等都打包在一起,还要实现全自动化。甚至会遇到诸如用户电脑不能上网&没有GPU,没有错,即便是你提训练必须条件,他也不一定会给你配到。

以上这几点,一定要仔细论证,全局论证,反复论证。论证不是内卷,不是效率不高,不是执行力不高。没有详细论证而匆匆上马的项目,一般后期有无数个坑在等着你。

打光阶段

包括光学设计,成像分析,当然还包括不是那么AI的结构设计等。俗话说:七分靠打光,三分靠调参。打光非常重要,因为后续算法只能为图片负责。一般我会用“明显”和“明确”来进行可行性分析,“明显”就是来自光学。最直观的判断就是,人肉眼能否通过图片进行精准判断。如果存在模棱两可的部分,那么它也将成为算法模棱两可的地方。

数据阶段

包括数据采集,数据标注,数据处理。数据的重要性不言而喻,正所谓:七分靠数据,三分靠trick。数据到位了,一切都好说。数据的重要性,想必是任何一个从业人员都深有体会的。我们要数据,要有效的数据。没有数据的场景,抱歉请用传统方法。要记住,模型泛化,没那么重要,当然模型也没有那么强的泛化能力。它之所以能够识别,那是因为它见过。将模型理解成一个存储器,而不是泛化器。之前的你,需要建立数据库来存储数据用以测试时的比对,现在的你,模型就是你的数据库。

数据标注就会涉及标准的定义,很多时候很难拿到清晰的标准。或者说无法量化为清晰的标准。往往会存在灰色地带,这就要提前有一个清晰的认识。对于灰色地带的处理,或者说客户的容忍,要提前想好策略。这里比较困难的是,灰色地带可能很难量化出来,我们只是知道这个样本是灰色地带,到底有多灰,have no idea。

另外,比较重要的是尽快建立稳定的、有代表性的数据集合,尤其是测试集,这点非常重要。可以帮助非常敏捷进行后续的benchmark实验。如果你不知道你对什么样的最终结果负责,那么你将永无止境的做下去。

算法设计阶段

包括任务定义,任务拆分,模型选择。尤其是任务拆分,你不肯定把所有的大象都装到一个冰箱里面,你也不可能把所有的鸡蛋放到一个篮子里面。

杜绝唯模型论 & SOTA 论。我们需要的是在特定场景下解决特定的问题。这里涉及学院派思维转变,学院派的高手为imageNet和COCO等数据集负责,而我为我自己的场景和自己数据集负责。SOTA看中的是模型的上限,而实际的场景,看中的是模型的下限。

杜绝唯AI论。不管传统方法还是AI方法,能work的就是好算法。如果传统方法没有明显的缺陷,那么请选择传统方案。或者你可以这么认为,当前看似高大上的AI并不是真正的AI,或许30年后一天,你会说:先用传统方法YOLO V28 来试一下吧!

训练评估阶段

包括模型调参,模型训练,指标评估。所谓的“炼丹”。前几步做好了,一般不会有太大问题,如果有,请向前追溯。这里要说一句,“提前优化是万恶之源“。在保证精度的时候,再去考虑速度,再去做优化。当然你靠58个模型联合起来获取的精度不在该讨论范围。

部署阶段

这个阶段坑比较多,基本上都是技术方面。也是所谓的“脏活”。包括模型优化,跨平台前向推理,模型加密。终于到部署阶段了,也看到了落地的曙光。关于深度学习人工智能落地,已经有有很多的解决方案,不论是电脑端、手机端还是嵌入式端,将已经训练好的神经网络权重在各个平台跑起来,应用起来才是最实在的。不过依然存在这么多工作需要做:

跨平台:可跑目标硬件上,包括各类cpu/gpu/npu/fpga等等。

高效能:速度快、占用内存少等。

精度没有丢失:经过一通量化、剪枝、蒸馏、图优化等操作后,终于满足时间要求了,却突然发现部署测试精度掉了一半,WTF

加密需求:你一定不希望自己辛辛苦苦搞出来的成果被别人白嫖吧!

闭环生态:当然你不能一劳永逸,怎么在应用中收集样本,更新系统。你需要作成实用、好用的闭环工具链。

运维阶段

包括运行监控,模型更新等。你以为可以所以口气了,并没有。能不能经受海量产能和时间的考验,请瑟瑟发抖地注视着吧!运维的核心就是保证业务安全稳定运行。上面提到,AI泛化能力还是比较欠缺的,所以很可能会在实际运行的过程中遇到不work的情况。当然最最直接的办法就是持续不断扩充数据。当然要保证你的模型有足够的capacity,如果没有,那么就是算法设计环节没有做好。收集数据利用上面部署阶段所说的闭环生态工具链来持续完成这个事情。至此,你的AI项目已经落地。

责任编辑:xj

原文标题:谈一谈我对AI项目落地的看法

文章出处:【微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • AI
    AI
    +关注

    关注

    87

    文章

    31157

    浏览量

    269502
  • 人工智能
    +关注

    关注

    1792

    文章

    47444

    浏览量

    239030

原文标题:谈一谈我对AI项目落地的看法

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    充分考虑设备的体验性易用性 蓝鹏设计部将这理念贯穿于整个研发过程

    关键字:蓝鹏测控设计部,蓝鹏测控测径仪,蓝鹏测控专利,测径仪专利, 蓝鹏设计部在研发过程中充分考虑设备的体验性和易用性,这理念对于提升产品的市场竞争力具有重要意义。 蓝鹏设计部在研发设备时,始终
    发表于 12-24 14:07

    电能质量治理产品如何解决分布式光伏电站运行过程中一些问题

    安科瑞徐赟杰 18706165067 1. 概述 随着全球对可再生能源需求的增加,分布式光伏电站的建设和发展迅速。然而,分布式光伏电站的运行过程中面临着系列问题,比如导致企业关口计量点功率因数
    的头像 发表于 11-13 10:19 164次阅读
    电能质量治理产品如何解决分布式光伏电站运行<b class='flag-5'>过程中</b>的<b class='flag-5'>一些</b>问题

    自己做的TAS5825板子软件开发过程中怎么接到PPC3上去调试呢?

    我们打算做个TAS5825的板子,PPC3软件已经申请下来了,有个问题是我们自己做的TAS5825板子软件开发过程中怎么接到PPC3上去调试呢?
    发表于 10-15 08:15

    LORA类产品PCB板载天线的研发测试方案

    LORA模组相关的产品项目研发过程中,需要对设计的pcb天线进行辐射功率测试,保证LORA模组在相应场景下满足基本通信需求。
    的头像 发表于 10-05 16:19 803次阅读
    LORA类产品PCB板载天线的<b class='flag-5'>研发</b>测试方案

    使用VCA810过程中遇到的一些问题求解

    我在使用VCA810过程中遇到一些问题,请各位大神指点,具体如下: 1、控制电压最小只能加到-1.7V,再减小的话输出信号消失或者放大倍数骤然减小。 2、输入端出现个叠加在信号上的直流,输出端直
    发表于 08-30 07:11

    康谋分享 | 在基于场景的AD/ADAS验证过程中,识别挑战性场景!

    基于场景的验证是AD/ADAS系统开发过程中的重要步骤,然而面对海量驾驶记录数据时,如何实现自动且高效地识别、分类和提取驾驶记录的挑战性场景?本文康谋为您介绍IVEX软件识别挑战性场景并进行数据分析的强大功能。
    的头像 发表于 08-28 10:16 1104次阅读
    康谋分享 | 在基于场景的AD/ADAS验证<b class='flag-5'>过程中</b>,识别挑战性场景!

    OPA657在使用过程中如何降噪,如何提高信噪比?

    OPA657在使用过程中如何降噪,如何提高信噪比?有没有通用的一些技巧?谢谢
    发表于 08-26 07:13

    开源 KiCad/AD 查看器 + AI Copilot?

    优先从原理图中提取 BOM,没有原理图时,从 PCB 中提取 BOM 开发和反馈过程中一些 bug 修复: SCH 的图纸引脚位置不正确 解析 从 AD 转换的 SCH
    发表于 08-18 22:41

    电容充放电过程中电压的变化规律

    电容充放电过程中电压的变化规律是个非常重要的电子学课题,涉及到电容器的基本工作原理和特性。在这篇文章,我们将详细探讨电容充放电过程中电压的变化规律,包括电容的基本特性、充电
    的头像 发表于 07-11 09:43 6102次阅读

    FMEA在手术机器人研发的应用

    在医疗科技飞速发展的今天,手术机器人已经成为精准医疗的重要工具。然而,如何确保手术机器人在研发过程中能够稳定、可靠地运行,避免潜在的风险和失误,是摆在研发团队面前的大挑战。此时,失效模式与影响分析
    的头像 发表于 06-18 11:25 517次阅读

    字节跳动否认AI手机研发项目

    近日,有市场传闻称字节跳动已在两个月前秘密启动了AI手机研发项目,引发业界广泛关注。然而,字节跳动相关人士迅速对此作出回应,表示这些消息并不属实。
    的头像 发表于 06-12 15:54 619次阅读

    FPGA开发过程中配置全局时钟需要注意哪些问题

    在FPGA开发过程中,配置全局时钟是个至关重要的步骤,它直接影响到整个系统的时序和性能。以下是配置全局时钟时需要注意的一些关键问题: 时钟抖动和延迟 :全局时钟资源的设计目标是实现最低的时钟抖动
    发表于 04-28 09:43

    做FPGA向FX3写数据的过程中遇到了一些问题求解

    你好我在做FPGA向FX3写数据的过程中遇到了一些问题想要明确下: (缓冲区的大小设置为16kB,数据总线位宽为32位,水印值为6) 1、如果以16kB为单位写,这时候pktend_n信号是否可以
    发表于 02-28 07:45

    Stages—研发过程可视化建模和管理平台

    、ISO26262等标准。Stages聚焦于研发过程的用户体验,允许用户集中访问过程描述信息、项目文档、模板、实践或者技术知识库。在Stages定义好的
    的头像 发表于 02-05 14:36 410次阅读
    Stages—<b class='flag-5'>研发过程</b>可视化建模和管理平台

    在BF707开发过程中向Flash烧写段代码,然后断电进行加载,发现并未加载成功如何解决?

    在BF707开发过程中向Flash烧写过段代码,然后断电进行加载,发现并未加载成功,当进行如下操作却失败】 1.利用CCES仿真器,在debug情况下对JTAG进行Test结果为OK的,但当
    发表于 01-12 06:03