如何将“机器学习”引入自动化?原来只需要这三步
moboyou 2025-05-11 16:42 55 浏览
要说现在最热门的前沿技术,那非人工智能(AI)莫属。而人工智能的核心却是机器学习(ML)。可以说,掌握了机器学习,你也就掌握了人工智能技术。
那么,对于工业用户来说,如何将机器学习引入到自动化领域,突破传统自动化技术发展的天花板呢?面对人工智能、机器学习、深度学习、神经网络……这些深奥的概念,如何快速了解和掌握呢?
今天,给我5分钟,我告诉你答案!一文让您对机器学习的概念、关键技术、如何应用到工业自动化之中等全部都轻松掌握!
首 先
我们先来看一个,用机器学习进行优化的一个运动控制案例,以便你对机器学习有一个感性的认识。
这是两个相同的直线加圆弧的传输轨道,但我们可以看到,左边轨道上的工件输送十分平缓,而右边轨道上的工件传输很不平稳,加速很急,产品都快要被甩出去了。这不仅对轨道上的工件影响很大,而且轨道自身的磨损也很严重,右边轨道上工件运动曲线的设计显然不如左边的传输轨道。
那如何才能设计出左边这样的运动曲线呢?这里就需要用到机器学习,通过对工件多次的速度、加速度、位置等信息的记录,再经过建立数据模型,不断优化(训练)模型,最后得出一个最佳的运动曲线。为何要用机器学习来设计呢,这是因为这样的运动曲线设计并没有现存的曲线(如正圆、椭圆、渐开线等),也不能通过数学方程计算出来,所以只有借助机器学习的“算法模型加训练”来求解出来。
看完这个例子,你对机器学习的作用应该有了一个初步认识。下面我们再来理解几个常见概念。
人工智能(AI)
能够模仿人智力的智能,分为弱AI和强AI,目前AI处于弱AI阶段。
机器学习(ML)
达到弱AI的水平,基于可以通过“训练数据”学习特定任务的数学模型进行优化。
深度学习(DL)
专注于深度神经网络(DNN)作为模型,需要大量数据集进行训练的复杂模型,目前主要用于强大的视觉应用。
三者的关系是从属关系,如下图所示:
简单理解,机器学习就是通过根据各类算法建立数学模型,然后通过数据不断训练模型,提高模型准确性,最后将训练好的模型放到实际应用场景中运行做推理计算,解决用普通数学方法难以解决的实际问题。
所以我们可以总结一下,将机器学习引入到工业自动化中,需要三步:收集工业现场数据、建立模型并训练模型、下载到实际应用中运行,如下图所示:
看上去是不是过程很简单?
当然了,实际使用过程并非如此简单,每个环节都会涉及到专业知识和工具,下面我们就来一一展开介绍一下,让你不仅入门,而且成为“专家”!
第 /一/ 步收集工业现场数据
首先,在数据收集阶段,就是要通过各类传感器和测试测量工具来采集现场数据,这个环节就会用到我们自动化控制中的很多产品,比如像倍福的TwinCAT3 Scope、TwinCAT3 Database Server、TwinCAT3 Data Agent和TwinCAT3 Analytics Logger等工具,可以利用这些工具将数据采集到本地数据库或者云端存储、呈现,以便下一步来建模和训练。
第 /二/ 步模型的搭建和训练
这一步是至关重要的一步,也是目前机器学习中最难、研究最多的一步。这一步里首先需要对上一步采集到的数据进行预处理,数据清洗除去异常值,数据转化或者数据集成等。然后,选择特征数据确定数学模型,进行学习微调,并进行未知数据的学习模型验证。模型训练后,生成导出一个可供TwinCAT3等模型运行环境的描述文件:XML文件或者ONNX文件。这一步中特征数据的挖掘,也就是提取哪些数据来建模是整个机器学习能否成功的关键,往往需要精通行业知识经验的人才能做到。
在这一步中,搭建模型时往往需要用到第三方框架(平台工具),比如:Python SciKit、MATLAB Machine Learning Toolbox,以及深度学习框架TensorFlow (谷歌)、Keras (frontend for TensorFlow, CNTK, …)、PyTorch (脸书)、MxNet (亚马逊)、CNTK (微软)、MATLAB Deep Learning Toolbox (MathWorks)等,其中大多数是开源的和基于Python的。
当然,除了这些框架外,还有一个重要的事,数学模型的选择和建立。在数学上,可以把万事万物所有问题分为两大问题:回归问题和分类问题。回归问题通常是用来预测一个值,如预测房价、未来的天气情况等。分类问题是用于将事物打上一个标签,通常结果为离散值,如判断一幅图片上的动物是一只猫还是一只狗。解决这两类问题需要用到不同的数学模型,比如常见的有支持向量机(SVM)、神经网络、决策树和随机森林、线性回归、贝叶斯线性回归等,这些模型在框架中是现存的,可以直接使用。
在这里,还需要提到一个知识点,那就是ONNX开放神经网络交换文件,这是一种针对机器学习所设计的开放式文件格式,用于存储训练好的模型。它使得不同的人工智能框架(如Pytorch,MXNet)可以采用相同格式存储模型数据并交互。主要由微软,亚马逊 ,Facebook 和 IBM 等公司共同开发。
第 /三/ 步加载模型到控制器里运行
说完了模型搭建和模型训练后,最后一步就是将模型加载到工业电脑或者控制器中运行计算。由于模型描述文件并不能被工业控制器所识别,所以就需要用到像倍福TwinCAT 3这样的自动化控制软件平台作为引擎,将训练好的模型文件加载到控制器,才能在自动化中应用机器学习。
目前、TwinCAT3以及无缝集成了机器学习引擎接口。可以通过机器学习文件转换器(ML Converter)把训练生成的模型文件XML或者ONNX转化成BML(倍福的机器学习文件)进行加密保护,经过TwinCAT3 的ML Runtime 进行加载,这样已训练好的模型就可以被TwinCAT TcCOM对象进行实时调用执行,同时可以被PLC、C/C++ 封装的TcCOM的接口进行调用!如果神经网络较小,如权值大小为10K的多层感知器(MLP)可以在一个亚毫秒的任务周期中多次调用,以确保实时性!
同时,TwinCAT 3本身所提供的支持多核技术也同样适用于机器学习应用,不同的任务程序可以访问同一个特定的TwinCAT 3推理引擎而不会相互限制。机器学习应用完全可以访问TwinCAT中所有可用的现场总线接口和数据,这将使其能够使用到大量数据。
TwinCAT 3现在有两个机器学习推理引擎,TF380x TC3和TF381x TC3,前者是经典机器学习模型的推理引擎,包括支持向量机(SVM), 主成分分析(PCA), k均值(k-means)等,后者是神经网络(NN)推理引擎,包括多层感知器(MPL),卷积神经网络(CNN),长短期记忆模型(LSTM)等。
举个例子 最优运动曲线是如何“机器学习”出来的
看完了上面的一般性方法介绍,下面我们再拿文章开头的那个传输轨道最优运动曲线是如何通过机器学习来进行优化的。
首先,将这个运动曲线优化的问题转化为数学问题,在一定的时间内,从pi顺时针到pf找到最优(最柔和)的运动曲线,运动过程中加速度要尽量小。
1 第一步
就是要采集数据,包括工件的位置、速度、加速度、时间等,把这些数据收集存储起来,以便下一步优化。
2 第二步
提取步骤一里面的特征数据建立模型,用 () 来作为优化准则,通过神经网络算法来循环迭代,监督学习训练模型。
3 第三步
将训练好的模型通过ONNX文件部署到TwinCAT 3里,从而通过控制器实现最优的运动曲线。
举个例子 一个不需要故障数据的风扇异常检测
通常,我们通过大数据分析来做预测性维护,需要很多故障数据,可工业实际场景中往往没有太多故障数据,比如一个风机在开始几年并不太会有故障,只有到后期才有故障数据。可是,通过机器学习的方法,就可以解决这个问题,在无需故障数据的情况做到故障检测。
比如,要检测下图服务器工作站上的风扇是否有异常,就可以通过机器学习来做。
首先,通过TwinCAT 3 Scope来采集大量风扇正常情况下的压力、转速、振动等数据,然后用MATLAB来读取这些数据,使用one-class SVM(一类支持向量机)模型来训练,等模型学习了大量正常数据后,就会自动产生一个正常数据的边界。最后将模型从MATLAB导出为一个ONNX文件,转换后加载到控制器的TwinCAT 3中。这样,当采集的数据超出边界时,控制器就会检测到风扇发生了异常状况。
这个应用看上去是十分简单的,但是这其中最难的一部分是特征数据的挖掘和提取,也就是常说的特征工程。至于数据的采集、模型的创建、训练,以及最后的控制器上的运行,已经有很多现存的工具和平台,比如MATLAB和倍福的TwinCAT 3。站在这些“巨人”的肩膀上,你只要专注用工业现场知识和经验,就可以轻松将机器学习这一“高大上”的新技术引入到工业自动化之中。
相关推荐
- Excel技巧:SHEETSNA函数一键提取所有工作表名称批量生产目录
 - 
        
首先介绍一下此函数:SHEETSNAME函数用于获取工作表的名称,有三个可选参数。语法:=SHEETSNAME([参照区域],[结果方向],[工作表范围])(参照区域,可选。给出参照,只返回参照单元格...
 
- Excel HOUR函数:“小时”提取器_excel+hour函数提取器怎么用
 - 
        
一、函数概述HOUR函数是Excel中用于提取时间值小时部分的日期时间函数,返回0(12:00AM)到23(11:00PM)之间的整数。该函数在时间数据分析、考勤统计、日程安排等场景中应用广泛。语...
 
- Filter+Search信息管理不再难|多条件|模糊查找|Excel函数应用
 - 
        
原创版权所有介绍一个信息管理系统,要求可以实现:多条件、模糊查找,手动输入的内容能去空格。先看效果,如下图动画演示这样的一个效果要怎样实现呢?本文所用函数有Filter和Search。先用filter...
 
- FILTER函数介绍及经典用法12:FILTER+切片器的应用
 - 
        
EXCEL函数技巧:FILTER经典用法12。FILTER+切片器制作筛选按钮。FILTER的函数的经典用法12是用FILTER的函数和切片器制作一个筛选按钮。像左边的原始数据,右边想要制作一...
 
- office办公应用网站推荐_office办公软件大全
 - 
        
以下是针对Office办公应用(Word/Excel/PPT等)的免费学习网站推荐,涵盖官方教程、综合平台及垂直领域资源,适合不同学习需求:一、官方权威资源1.微软Office官方培训...
 
- WPS/Excel职场办公最常用的60个函数大全(含卡片),效率翻倍!
 - 
        
办公最常用的60个函数大全:从入门到精通,效率翻倍!在职场中,WPS/Excel几乎是每个人都离不开的工具,而函数则是其灵魂。掌握常用的函数,不仅能大幅提升工作效率,还能让你在数据处理、报表分析、自动...
 
- 收藏|查找神器Xlookup全集|一篇就够|Excel函数|图解教程
 - 
        
原创版权所有全程图解,方便阅读,内容比较多,请先收藏!Xlookup是Vlookup的升级函数,解决了Vlookup的所有缺点,可以完全取代Vlookup,学完本文后你将可以应对所有的查找难题,内容...
 
- 批量查询快递总耗时?用Excel这个公式,自动计算揽收到签收天数
 - 
        
批量查询快递总耗时?用Excel这个公式,自动计算揽收到签收天数在电商运营、物流对账等工作中,经常需要统计快递“揽收到签收”的耗时——比如判断某快递公司是否符合“3天内送达”的服务承...
 
- Excel函数公式教程(490个实例详解)
 - 
        
Excel函数公式教程(490个实例详解)管理层的财务人员为什么那么厉害?就是因为他们精通excel技能!财务人员在日常工作中,经常会用到Excel财务函数公式,比如财务报表分析、工资核算、库存管理等...
 
- Excel(WPS表格)Tocol函数应用技巧案例解读,建议收藏备用!
 - 
        
工作中,经常需要从多个单元格区域中提取唯一值,如体育赛事报名信息中提取唯一的参赛者信息等,此时如果复制粘贴然后去重,效率就会很低。如果能合理利用Tocol函数,将会极大地提高工作效率。一、功能及语法结...
 
- Excel中的SCAN函数公式,把计算过程理清,你就会了
 - 
        
Excel新版本里面,除了出现非常好用的xlookup,Filter公式之外,还更新一批自定义函数,可以像写代码一样写公式其中SCAN函数公式,也非常强大,它是一个循环函数,今天来了解这个函数公式的计...
 
- Excel(WPS表格)中多列去重就用Tocol+Unique组合函数,简单高效
 - 
        
在数据的分析和处理中,“去重”一直是绕不开的话题,如果单列去重,可以使用Unique函数完成,如果多列去重,如下图:从数据信息中可以看到,每位参赛者参加了多项运动,如果想知道去重后的参赛者有多少人,该...
 
- Excel(WPS表格)函数Groupby,聚合统计,快速提高效率!
 - 
        
在前期的内容中,我们讲了很多的统计函数,如Sum系列、Average系列、Count系列、Rank系列等等……但如果用一个函数实现类似数据透视表的功能,就必须用Groupby函数,按指定字段进行聚合汇...
 
- Excel新版本,IFS函数公式,太强大了!
 - 
        
我们举一个工作实例,现在需要计算业务员的奖励数据,右边是公司的奖励标准:在新版本的函数公式出来之前,我们需要使用IF函数公式来解决1、IF函数公式IF函数公式由三个参数组成,IF(判断条件,对的时候返...
 
- Excel不用函数公式数据透视表,1秒完成多列项目汇总统计
 - 
        
如何将这里的多组数据进行汇总统计?每组数据当中一列是不同菜品,另一列就是该菜品的销售数量。如何进行汇总统计得到所有的菜品销售数量的求和、技术、平均、最大、最小值等数据?不用函数公式和数据透视表,一秒就...
 
- 一周热门
 
- 最近发表
 - 
- Excel技巧:SHEETSNA函数一键提取所有工作表名称批量生产目录
 - Excel HOUR函数:“小时”提取器_excel+hour函数提取器怎么用
 - Filter+Search信息管理不再难|多条件|模糊查找|Excel函数应用
 - FILTER函数介绍及经典用法12:FILTER+切片器的应用
 - office办公应用网站推荐_office办公软件大全
 - WPS/Excel职场办公最常用的60个函数大全(含卡片),效率翻倍!
 - 收藏|查找神器Xlookup全集|一篇就够|Excel函数|图解教程
 - 批量查询快递总耗时?用Excel这个公式,自动计算揽收到签收天数
 - Excel函数公式教程(490个实例详解)
 - Excel(WPS表格)Tocol函数应用技巧案例解读,建议收藏备用!
 
 
- 标签列表
 - 
- 外键约束 oracle (36)
 - oracle的row number (32)
 - 唯一索引 oracle (34)
 - oracle in 表变量 (28)
 - oracle导出dmp导出 (28)
 - 多线程的创建方式 (29)
 - 多线程 python (30)
 - java多线程并发处理 (32)
 - 宏程序代码一览表 (35)
 - c++需要学多久 (25)
 - css class选择器用法 (25)
 - css样式引入 (30)
 - css教程文字移动 (33)
 - php简单源码 (36)
 - php个人中心源码 (25)
 - php小说爬取源码 (23)
 - 云电脑app源码 (22)
 - html画折线图 (24)
 - docker好玩的应用 (28)
 - linux有没有pe工具 (34)
 - 可以上传视频的网站源码 (25)
 - 随机函数如何生成小数点数字 (31)
 - 随机函数excel公式总和不变30个数据随机 (33)
 - 所有excel函数公式大全讲解 (22)
 - 有动图演示excel函数公式大全讲解 (32)
 
 
