机器学习算法比较

本文主要回顾下几个常用算法的适应场景及其优缺点!(提示:部分内容摘自网络)。


机器学习算法太多了,分类、回归、聚类、推荐、图像识别领域等等,要想找到一个合适算法真的不容易,所以在实际应用中,我们一般都是采用启发式学习方式来实验。通常最开始我们都会选择大家普遍认同的算法,诸如SVM,GBDT,Adaboost,现在深度学习很火热,神经网络也是一个不错的选择。假如你在乎精度(accuracy)的话,最好的方法就是通过交叉验证(cross-validation)对各个算法一个个地进行测试,进行比较,然后调整参数确保每个算法达到最优解,最后选择最好的一个。但是如果你只是在寻找一个“足够好”的算法来解决你的问题,或者这里有些技巧可以参考,下面来分析下各个算法的优缺点,基于算法的优缺点,更易于我们去选择它。


偏差&方差


在统计学中,一个模型好坏,是根据偏差和方差来衡量的,所以我们先来普及一下偏差(bias)和方差(variance):


  • 偏差:描述的是预测值(估计值)的期望E’与真实值Y之间的差距。偏差越大,越偏离真实数据。

640?wx_fmt=png 

  • 方差:描述的是预测值P的变化范围,离散程度,是预测值的方差,也就是离其期望值E的距离。方差越大,数据的分布越分散。

640?wx_fmt=png

模型的真实误差是两者之和,如下:

640?wx_fmt=png

通常情况下,如果是小训练集,高偏差/低方差的分类器(例如,朴素贝叶斯NB)要比低偏差/高方差大分类的优势大(例如,KNN),因为后者会发生过拟合(overfiting)。然而,随着你训练集的增长,模型对于原数据的预测能力就越好,偏差就会降低,此时低偏差/高方差的分类器就会渐渐的表现其优势(因为它们有较低的渐近误差),而高偏差分类器这时已经不足以提供准确的模型了。


当然,你也可以认为这是生成模型(如NB)与判别模型(如KNN)的一个区别。

为什么说朴素贝叶斯是高偏差低方差?


以下内容引自知乎:


首先,假设你知道训练集和测试集的关系。简单来讲是我们要在训练集上学习一个模型,然后拿到测试集去用,效果好不好要根据测试集的错误率来衡量。但很多时候,我们只能假设测试集和训练集的是符合同一个数据分布的,但却拿不到真正的测试数据。这时候怎么在只看到训练错误率的情况下,去衡量测试错误率呢?


由于训练样本很少(至少不足够多),所以通过训练集得到的模型,总不是真正正确的。(就算在训练集上正确率100%,也不能说明它刻画了真实的数据分布,要知道刻画真实的数据分布才是我们的目的,而不是只刻画训练集的有限的数据点)。而且,实际中,训练样本往往还有一定的噪音误差,所以如果太追求在训练集上的完美而采用一个很复杂的模型,会使得模型把训练集里面的误差都当成了真实的数据分布特征,从而得到错误的数据分布估计。这样的话,到了真正的测试集上就错的一塌糊涂了(这种现象叫过拟合)。但是也不能用太简单的模型,否则在数据分布比较复杂的时候,模型就不足以刻画数据分布了(体现为连在训练集上的错误率都很高,这种现象较欠拟合)。过拟合表明采用的模型比真实的数据分布更复杂,而欠拟合表示采用的模型比真实的数据分布要简单。


在统计学习框架下,大家刻画模型复杂度的时候,有这么个观点,认为Error = Bias + Variance。这里的Error大概可以理解为模型的预测错误率,是有两部分组成的,一部分是由于模型太简单而带来的估计不准确的部分(Bias),另一部分是由于模型太复杂而带来的更大的变化空间和不确定性(Variance)。


所以,这样就容易分析朴素贝叶斯了。它简单的假设了各个数据之间是无关的,是一个被严重简化了的模型。所以,对于这样一个简单模型,大部分场合都会Bias部分大于Variance部分,也就是说高偏差而低方差。


在实际中,为了让Error尽量小,我们在选择模型的时候需要平衡Bias和Variance所占的比例,也就是平衡over-fitting和under-fitting。


偏差、方差、模型复杂度三者之间的关系使用下图表示会更容易理解:

640?wx_fmt=png

当模型复杂度上升的时候,偏差会逐渐变小,而方差会逐渐变大。


常见算法优缺点


1. 朴素贝叶斯


朴素贝叶斯属于生成式模型(关于生成模型和判别式模型,主要还是在于是否需要求联合分布),比较简单,你只需做一堆计数即可。如果注有条件独立性假设(一个比较严格的条件),朴素贝叶斯分类器的收敛速度将快于判别模型,比如逻辑回归,所以你只需要较少的训练数据即可。即使NB条件独立假设不成立,NB分类器在实践中仍然表现的很出色。它的主要缺点是它不能学习特征间的相互作用,用mRMR中R来讲,就是特征冗余。引用一个比较经典的例子,比如,虽然你喜欢Brad Pitt和Tom Cruise的电影,但是它不能学习出你不喜欢他们在一起演的电影。


优点:


  • 朴素贝叶斯模型发源于古典数学理论,有着坚实的数学基础,以及稳定的分类效率。

  • 对小规模的数据表现很好,能个处理多分类任务,适合增量式训练;

  • 对缺失数据不太敏感,算法也比较简单,常用于文本分类。


缺点:


  • 需要计算先验概率;

  • 分类决策存在错误率;

  • 对输入数据的表达形式很敏感。


2. Logistic Regression(逻辑回归)


逻辑回归属于判别式模型,同时伴有很多模型正则化的方法(L0, L1,L2,etc),而且你不必像在用朴素贝叶斯那样担心你的特征是否相关。与决策树、SVM相比,你还会得到一个不错的概率解释,你甚至可以轻松地利用新数据来更新模型(使用在线梯度下降算法-online gradient descent)。如果你需要一个概率架构(比如,简单地调节分类阈值,指明不确定性,或者是要获得置信区间),或者你希望以后将更多的训练数据快速整合到模型中去,那么使用它吧。


Sigmoid函数:

640?wx_fmt=png

优点:


  • 实现简单,广泛的应用于工业问题上;

  • 分类时计算量非常小,速度很快,存储资源低;

  • 便利的观测样本概率分数;

  • 对逻辑回归而言,多重共线性并不是问题,它可以结合L2正则化来解决该问题;


缺点:


  • 当特征空间很大时,逻辑回归的性能不是很好;

  • 容易欠拟合,一般准确度不太高

  • 不能很好地处理大量多类特征或变量;

  • 只能处理两分类问题(在此基础上衍生出来的softmax可以用于多分类),且必须线性可分

  • 对于非线性特征,需要进行转换;


3. 线性回归


线性回归是用于回归的,它不像Logistic回归那样用于分类,其基本思想是用梯度下降法对最小二乘法形式的误差函数进行优化,当然也可以用normal equation直接求得参数的解,结果为:

640?wx_fmt=jpeg

而在LWLR(局部加权线性回归)中,参数的计算表达式为:

640?wx_fmt=png

由此可见LWLR与LR不同,LWLR是一个非参数模型,因为每次进行回归计算都要遍历训练样本至少一次。


优点:实现简单,计算简单;

缺点:不能拟合非线性数据.


4. 最近邻算法——KNN


KNN即最近邻算法,其主要过程为:


1) 计算训练样本和测试样本中每个样本点的距离(常见的距离度量有欧式距离,马氏距离等);

2) 对上面所有的距离值进行排序(升序);

3) 选前k个最小距离的样本;

4) 根据这k个样本的标签进行投票,得到最后的分类类别;


如何选择一个最佳的K值,这取决于数据。一般情况下,在分类时较大的K值能够减小噪声的影响,但会使类别之间的界限变得模糊。一个较好的K值可通过各种启发式技术来获取,比如,交叉验证。另外噪声和非相关性特征向量的存在会使K近邻算法的准确性减小。近邻算法具有较强的一致性结果,随着数据趋于无限,算法保证错误率不会超过贝叶斯算法错误率的两倍。对于一些好的K值,K近邻保证错误率不会超过贝叶斯理论误差率。


KNN算法的优点


  • 理论成熟,思想简单,既可以用来做分类也可以用来做回归;

  • 可用于非线性分类;

  • 训练时间复杂度为O(n);

  • 对数据没有假设,准确度高,对outlier不敏感;


缺点


  • 计算量大(体现在距离计算上);

  • 样本不平衡问题(即有些类别的样本数量很多,而其它样本的数量很少)效果差;

  • 需要大量内存;


5. 决策树


决策树的一大优势就是易于解释。它可以毫无压力地处理特征间的交互关系并且是非参数化的,因此你不必担心异常值或者数据是否线性可分(举个例子,决策树能轻松处理好类别A在某个特征维度x的末端,类别B在中间,然后类别A又出现在特征维度x前端的情况)。它的缺点之一就是不支持在线学习,于是在新样本到来后,决策树需要全部重建。另一个缺点就是容易出现过拟合,但这也就是诸如随机森林RF(或提升树boosted tree)之类的集成方法的切入点。另外,随机森林经常是很多分类问题的赢家(通常比支持向量机好上那么一丁点),它训练快速并且可调,同时你无须担心要像支持向量机那样调一大堆参数,所以在以前都一直很受欢迎。


决策树中很重要的一点就是选择一个属性进行分枝,因此要注意一下信息增益的计算公式,并深入理解它。


信息熵的计算公式如下:

640?wx_fmt=png

其中的n代表有n个分类类别(比如假设是二类问题,那么n=2)。分别计算这2类样本在总样本中出现的概率p1和p2,这样就可以计算出未选中属性分枝前的信息熵。


现在选中一个属性xi用来进行分枝,此时分枝规则是:如果xi=v的话,将样本分到树的一个分支;如果不相等则进入另一个分支。很显然,分支中的样本很有可能包括2个类别,分别计算这2个分支的熵H1和H2,计算出分枝后的总信息熵H'=p1 * H1+p2 * H2,则此时的信息增益ΔH = H - H’。以信息增益为原则,把所有的属性都测试一边,选择一个使增益最大的属性作为本次分枝属性。


决策树自身的优点


  • 计算简单,易于理解,可解释性强;

  • 比较适合处理有缺失属性的样本;

  • 能够处理不相关的特征;

  • 在相对短的时间内能够对大型数据源做出可行且效果良好的结果。


缺点


  • 容易发生过拟合(随机森林可以很大程度上减少过拟合);

  • 忽略了数据之间的相关性;

  • 对于那些各类别样本数量不一致的数据,在决策树当中,信息增益的结果偏向于那些具有更多数值的特征(只要是使用了信息增益,都有这个缺点,如RF)。


5.1 Adaboosting


Adaboost是一种加和模型,每个模型都是基于上一次模型的错误率来建立的,过分关注分错的样本,而对正确分类的样本减少关注度,逐次迭代之后,可以得到一个相对较好的模型。该算法是一种典型的boosting算法,其加和理论的优势可以使用Hoeffding不等式得以解释。有兴趣的同学可以阅读下笔者后面写的这篇文章Adaboost - 新的角度理解权值更新策略(http://www.csuldw.com/2016/08/28/2016-08-28-adaboost-algorithm-theory/)。下面总结下它的优缺点。


优点


  • Adaboost是一种有很高精度的分类器。

  • 可以使用各种方法构建子分类器,Adaboost算法提供的是框架。

  • 当使用简单分类器时,计算出的结果是可以理解的,并且弱分类器的构造极其简单。

  • 简单,不用做特征筛选。

  • 不易发生overfitting。


关于随机森林和GBDT等组合算法,参考这篇文章:机器学习-组合算法总结(http://www.csuldw.com/2015/07/22/2015-07-22%20%20ensemble/


缺点:对outlier比较敏感


6. SVM支持向量机


支持向量机,一个经久不衰的算法,高准确率,为避免过拟合提供了很好的理论保证,而且就算数据在原特征空间线性不可分,只要给个合适的核函数,它就能运行得很好。在动辄超高维的文本分类问题中特别受欢迎。可惜内存消耗大,难以解释,运行和调参也有些烦人,而随机森林却刚好避开了这些缺点,比较实用。


优点


  • 可以解决高维问题,即大型特征空间;

  • 能够处理非线性特征的相互作用;

  • 无需依赖整个数据;

  • 可以提高泛化能力;


缺点


  • 当观测样本很多时,效率并不是很高;

  • 对非线性问题没有通用解决方案,有时候很难找到一个合适的核函数;

  • 对缺失数据敏感;


对于核的选择也是有技巧的(libsvm中自带了四种核函数:线性核、多项式核、RBF以及sigmoid核):


  • 第一,如果样本数量小于特征数,那么就没必要选择非线性核,简单的使用线性核就可以了;

  • 第二,如果样本数量大于特征数目,这时可以使用非线性核,将样本映射到更高维度,一般可以得到更好的结果;

  • 第三,如果样本数目和特征数目相等,该情况可以使用非线性核,原理和第二种一样。


对于第一种情况,也可以先对数据进行降维,然后使用非线性核,这也是一种方法。


7. 人工神经网络的优缺点


人工神经网络的优点:


  • 分类的准确度高;

  • 并行分布处理能力强,分布存储及学习能力强,

  • 对噪声神经有较强的鲁棒性和容错能力,能充分逼近复杂的非线性关系;

  • 具备联想记忆的功能。


人工神经网络的缺点:


  • 神经网络需要大量的参数,如网络拓扑结构、权值和阈值的初始值;

  • 不能观察之间的学习过程,输出结果难以解释,会影响到结果的可信度和可接受程度;

  • 学习时间过长,甚至可能达不到学习的目的。


8. K-Means聚类


之前笔者写过一篇关于K-Means聚类的文章,参见机器学习算法-K-means聚类(http://www.csuldw.com/2015/06/03/2015-06-03-ml-algorithm-K-means/)。关于K-Means的推导,里面可是有大学问的,蕴含着强大的EM思想。


优点


  • 算法简单,容易实现 ;

  • 对处理大数据集,该算法是相对可伸缩的和高效率的,因为它的复杂度大约是O(nkt),其中n是所有对象的数目,k是簇的数目,t是迭代的次数。通常k<<n。这个算法通常局部收敛。

  • 算法尝试找出使平方误差函数值最小的k个划分。当簇是密集的、球状或团状的,且簇与簇之间区别明显时,聚类效果较好。


缺点


  • 对数据类型要求较高,适合数值型数据;

  • 可能收敛到局部最小值,在大规模数据上收敛较慢

  • K值比较难以选取;

  • 对初值的簇心值敏感,对于不同的初始值,可能会导致不同的聚类结果;

  • 不适合于发现非凸面形状的簇,或者大小差别很大的簇。

  • 对于”噪声”和孤立点数据敏感,少量的该类数据能够对平均值产生极大影响。


算法选择参考


之前笔者翻译过一些国外的文章,其中有一篇文章中给出了一个简单的算法选择技巧:


1. 首当其冲应该选择的就是逻辑回归,如果它的效果不怎么样,那么可以将它的结果作为基准来参考,在基础上与其他算法进行比较;


2. 然后试试决策树(随机森林)看看是否可以大幅度提升你的模型性能。即便最后你并没有把它当做为最终模型,你也可以使用随机森林来移除噪声变量,做特征选择;


3. 如果特征的数量和观测样本特别多,那么当资源和时间充足时(这个前提很重要),使用SVM不失为一种选择。


通常情况下:【GBDT>=SVM>=RF>=Adaboost>=Other…】,现在深度学习很热门,很多领域都用到,它是以神经网络为基础的,目前笔者自己也在学习,只是理论知识不扎实,理解的不够深入,这里就不做介绍了,希望以后可以写一片抛砖引玉的文章。


算法固然重要,但好的数据却要优于好的算法,设计优良特征是大有裨益的。假如你有一个超大数据集,那么无论你使用哪种算法可能对分类性能都没太大影响(此时就可以根据速度和易用性来进行抉择)。


参考文献


[1] https://en.wikipedia.org/wiki/Bias%E2%80%93variance_tradeoff
[2] 
http://blog.echen.me/2011/04/27/choosing-a-machine-learning-classifier/
[3] 
http://www.csuldw.com/2016/02/26/2016-02-26-choosing-a-machine-learning-classifier/


来源:http://www.csuldw.com/2016/02/26/2016-02-26-choosing-a-machine-learning-classifier/

640?wx_fmt=png


选择置顶,关键时刻

第一时间送达! 

640?wx_fmt=jpeg


长按二维码关注

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/525643.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

还在用 Python 2.x?Python 3.7.0 正式发布!

6 月 27 日&#xff0c;期待已久的 Python 3.7.0 正式发布&#xff0c;与之同行的还有 3.6.6 版本的更新。此次&#xff0c;最新版的 Python 3.7.0 带来了诸多的新功能和优化&#xff0c;接下来&#xff0c;让我们一睹为快。Python 3.7.0 主要更新新的语法特性&#xff1a;PEP …

2018 年你需要知道的 11 个 JavaScript 库

译者按&#xff1a;你可能已经用到Underscore或者Lodash。本文列举了11个常用的库来提高开发效率。为了保证可读性&#xff0c;本文采用意译而非直译。另外&#xff0c;本文版权归原作者所有&#xff0c;翻译仅用于学习。JavaScript依然是2018年最受欢迎、最流行的编程语言&…

云化要求下,数据库架构的演进

如今&#xff0c;大型企业如金融企业和银行等&#xff0c;在下一代的微服务架构转型要求下&#xff0c;需要基础软件和数据平台能够实现原生的云化&#xff0c;以满足微服务架构的需求。微服务&#xff0c;也就是一种面向服务的&#xff0c;有特定边界的松散耦合的架构。主要特…

消息中间件—简谈Kafka中的NIO网络通信模型

前面写的两篇RocketMQ源码研究笔记系列&#xff1a;1. 消息中间件—RocketMQ的RPC通信&#xff08;一&#xff09;2. 消息中间件—RocketMQ的RPC通信&#xff08;二&#xff09;基本上已经较为详细地将RocketMQ这款分布式消息队列的RPC通信部分的协议格式、消息编解码、通信方式…

如何系统学习领域驱动设计?

一、领域驱动设计为何又焕发青春&#xff1f;领域驱动设计&#xff08;Domain Driven Design&#xff0c;DDD&#xff09;确实已不再青春&#xff0c;从 Eric Evans 出版了划时代的著作《领域驱动设计》至今&#xff0c;已有将近十五年的时间&#xff0c;在软件设计领域中&…

如何运用DDD解决团队协作与沟通问题?

领域驱动设计的核心是“领域”&#xff0c;因此要运用领域驱动设计&#xff0c;从一开始就要让团队走到正确的点上。当我们组建好了团队之后&#xff0c;应该从哪里开始&#xff1f;不是UI原型设计&#xff0c;不是架构设计&#xff0c;不是设计数据库&#xff0c;这些事情重要…

微服务等于Spring Cloud?一文告诉你微服务到底是什么

作者&#xff1a;TIM XU 原文&#xff1a;https://xiaoxubeii.github.io/articles/microservices-architecture-introduction/1微服务初探什么是微服务&#xff1f;首先微服务并没有一个官方的定义&#xff0c;想要直接描述微服务比较困难&#xff0c;我们可以通过对比传统WEB应…

我们爬了上千个数据分析师信息, 你真的懂数据分析师嘛?

01 项目简介有人说&#xff0c;这个时代&#xff0c;只要站在了风口&#xff0c;猪都能飞起来&#xff0c;尤其互联网行业&#xff0c;千变万化&#xff0c;日异月殊&#xff0c;一不小心就错过了风口&#xff0c;如果没记错的话&#xff0c;前几年火的是App开发&#xff0c;后…

高可用Redis服务架构分析与搭建

作者&#xff1a;HorstXu 原文&#xff1a;https://www.cnblogs.com/xuning/p/8464625.html基于内存的Redis应该是目前各种Web开发业务中最为常用的Key-Value数据库了&#xff0c;我们经常在业务中用其存储用户登陆态&#xff08;Session存储&#xff09;&#xff0c;加速一些热…

java怎么弄redis,java怎么使用redis

开始在 Java 中使用 Redis 前&#xff0c; 我们需要确保已经安装了 redis 服务及 Java redis 驱动&#xff0c;且你的机器上能正常使用 Java。Java的安装配置可以参考我们的 Java开发环境配置 接下来让我们安装 Java redis 驱动&#xff1a;首先你需要下载驱动包 下载 jedis.ja…

我花了14个小时找了一下长春长生们究竟卖到了哪里去

前言本文首发于个人的公众号和v2ex&#xff0c;事先也没想到会有这么多人关注。在这边重新编辑一下&#xff0c;去掉了原先前言中对此次疫苗事件背景的描述及部分不严谨的措辞。全文的观点从技术讨论出发&#xff0c;尽量客观中立&#xff0c;观点及行为为员工自发&#xff0c;…

我们分析了50万条拼多多商品数据,告诉你到底是消费升级还是降级?

作者&#xff1a;放开那个猕猴桃来源&#xff1a;人工智能与大数据生活转自&#xff1a;知乎&#xff0c;恋习Python一、缘起我在杭州有位朋友&#xff0c;提到有家做社交的电商很火&#xff0c;叫拼多多&#xff0c;我没有在意&#xff0c;直到有一天&#xff0c;我居然在电视…

java并发集合面试题,那些经常被问的JAVA面试题(1)—— 集合部分

【本文转自极客原创 作者&#xff1a;张锋 原文链接&#xff1a;】Java集合框架是什么&#xff1f;说出一些集合框架的优点&#xff1f;每种编程语言中都有集合&#xff0c;最初的Java版本包含几种集合类&#xff1a;Vector、Stack、HashTable和Array。随着集合的广泛使用&…

拯救阿波罗14号!那些伟大太空计划背后的计算机工程师们

&#xfeff;&#xfeff;1971年1月31日&#xff0c;阿波罗14号发射。外太空旅行近一周后的凌晨&#xff0c;回程中的阿波罗14号突然面临一个严峻的问题&#xff1a;它可能没办法正常降落了。问题出在其计算机工程师Don Eyles编写的一个应急程序上&#xff0c;他必须在很短的时…

golang web php,golang 适合做web开发吗

使用go语言来做web开发&#xff0c;是非常方便的。如果不使用框架&#xff0c;仅仅使用net/http包&#xff0c;也能快速开发一个web应用。但是&#xff0c;官方包不支持RESTful风格的API&#xff0c;所以我们依然还是需要选择一个框架来帮助我们进行开发。 (推荐学习&#xff1…

我又花了28个小时分析了一下各省二类疫苗采购公示数据

1前 言距离《我花了14个小时找了一下长春长生们究竟卖到了哪里去》发出来已经过去了4天&#xff0c;过去的几天里&#xff0c;每天晚上我都在搜集和整理数据&#xff0c;终于把之前没做完的工作做的差不多了。现在做一个大致的总结&#xff0c;分析相对粗略&#xff0c;大家见…

[重磅] 如何更好地实现服务调用和消息推送

第四届阿里中间件性能挑战赛是由阿里巴巴集团发起&#xff0c;阿里巴巴中间(Aliware)、阿里云天池联合举办&#xff0c;是集团少有的工程性品牌赛事。大赛的初衷是为热爱技术的年轻人提供一个挑战世界级技术问题的舞台&#xff0c;希望选手在追求性能极致的同时&#xff0c;能深…

开发怼产品,天经地义?大惊小怪?

最近&#xff0c;又有一件轰动程序员界的事情发生了&#xff0c;想必大家伙都已经奔走相告了。来回顾下事情的经过&#xff0c;1张图就能说明白了骚不&#xff1f;反正有句话叫「从技术层面出发&#xff0c;总归有办法实现的」&#xff0c;还有这么一句话叫「从技术角度出发&am…

php实现数据排序算法,PHP实现排序堆排序算法

这篇文章主要为大家详细介绍了PHP实现排序堆排序(Heap Sort)算法&#xff0c;具有一定的参考价值&#xff0c;感兴趣的小伙伴们可以参考一下算法引进&#xff1a;在这里我直接引用《大话数据结构》里面的开头&#xff1a;在前面讲到 简单选择排序 &#xff0c;它在待排序的 n 个…

谷歌Edge TPU:将机器学习引入边缘,撬动边缘计算/IOT大“地球”

近期&#xff0c;谷歌在Cloud Next会议上推出其最新产品&#xff0c;Edge TPU芯片和Cloud IOT Edge软件&#xff0c;并将于10月推出Edge TPU开发套件。作为Cloud TPU的补充&#xff0c;目前Edge TPU仅用于推理&#xff0c;专为在边缘运行TensorFlow Lite ML模型而设计。Edge TP…