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

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

3天内不再提示

如何建设机器学习平台,该如何去做

茶棚小二a 来源:Thoughtworks 作者:茶棚小二的专栏 2021-10-12 17:42 次阅读

00. 平台的业务

从平台这个概念本身来说,它提供的是支撑作用,通过整合、管理不同的基础设施、威廉希尔官方网站 框架,一些通用的流程规范来形成一个通用的、易用的GUI来给用户使用。通用性是它的考量之一、也是所有平台的愿景之一:希望平台能适用于各个不同的业务线来产生价值。所以从业务上来说,作为一个平台本身是不会、也不应该有太多specific的业务功能的。当然这只是理想情况,有时候为了平台使用方的需求,也不得不加上一些业务领域特定的功能或者补丁来适应业务方,特别是平台建设初期,在没有太多业务的使用的时候。整体来看,平台自身的业务可谓是非常简单,可以用一张图来表示:

1-how-to-build-machine-learning-platform-768x198.png

平台的业务

上面这个分支是标准的机器学习流程的抽象。从数据准备,数据处理,模型训练,再到模型上线实现价值完成整个流程。

下面这个分支,也是机器学习和数据科学领域中不可或缺的,主要指的是类似于Jupyter Notebook这类,提供高度灵活性和可视化的数据探索服务,用户可以在里面进行数据探索、尝试一些实验来验证想法。当然当平台拥有了SDK/CLI之后,也可以在里面无缝集成上面这条线里面的功能,将灵活性与功能性融合在一起。

01. 基础设施

上面提到平台本身是整合了不同的基础设施、威廉希尔官方网站 框架和流程规范。在正式开始之前,有必要介绍下本文后续所使用的的基础设施和框架。

在容器化、云化的潮流中,Kubernetes基本上是必选的基础设施,它提供灵活易用的基础设施和应用管理能力,同时扩展性非常好。它可以用于

部署平台本身

调度一些批处理任务(这里主要指离线任务,如数据处理、模型训练。适用的威廉希尔官方网站 为:Spark on kubernetes/Kubernetes Job),

部署常驻服务(一般指的是RESTful/gRPC等为基础的服务,如启动的Notebook、模型发布后的模型推理服务。适用的威廉希尔官方网站 为Kubernetes Deployment/Kubernetes Statefulset/Service等)。

机器学习的主要场景下,数据量都是非常大的,所以Hadoop这一套也是必不可少的,其中包含基础的Hadoop(HDFS/HIVE/HBase/Yarn)以及上层计算框架Spark等。大数据威廉希尔官方网站 体系主要用于数据存储和分布式数据处理、训练的业务。

最后就是一些机器学习框架,Spark系的(Spark MLlib/Angel),Python系的(Tensorflow/Pytorch)。主要用途就是模型训练和模型发布(Serving)的业务。

02.原始数据

原始数据,也叫做数据源,也就是机器学习的燃料。平台本身并不关心原始数据是如何被收集的,只关心数据存储的方式和位置。存储的方式决定了平台是否能支持此种数据的操作。存储的位置决定了平台是否有权限、有能力去读取到此数据。按主流的情况来看,原始数据的存储一般支持四类形式:

传统的数据库,例如RDS/NoSQL。这类数据源见得比较少,因为一般在大数据场景下,通用的解决方案是将此类数据源通过一些工具导入到大数据体系中(如Sqoop)。对于此类数据源的支持也是很简单的,使用通用的Driver 或者 Connector即可。

以HDFS为媒介的通用大数据存储。此类数据源使用较为广泛,最常见的是HDFS文件(parquet/csv/txt)和基于HDFS的HIVE数据源。另外,由于是大数据场景下的经典数据源,所以上层的框架支持较为完善。

NFS。NFS由于其快速的读写能力,以及悠久的历史。很多企业内部都有此基础设施,因而已有的数据也极有可能存储在上面。

OSS(对象存储)。最过于流行的要属S3了。对象存储是作为数据湖的经典方案,使用简单,存储理论上无限,和HDFS一样具备数据高可用,不允许按片段更改数据,只能修改整个对象是其缺点。

值得注意的是,NFS和OSS一般用于存储非结构化数据,例如图片和视屏。或者用于持久化输出目的,如容器存储,业务日志存储。而HDFS和数据库里面存放的都是结构化、半结构化的数据,一般都是已经经过ETL处理过的数据。存储的数据不一样决定了后续的处理流程的区别:

NFS/OSS系数据源,基本上都是通过TensorFlow/Pytorch来处理,数据一般通过Mount或者API来操作使用。当然也有特例,如果是使用云服务,例如AWS的大数据体系的话,绝大多数场景下,是使用S3来代替HDFS使用的,这也得益于AWS本身对于S3的专属EMRFS的定制化。当然Spark本身等大数据处理框架也是支持此类云存储的。

HDFS系和传统数据库系数据源,这个大数据框架、Python系框架都是可以的。

平台一般会内嵌对以上数据源的支持能力。对于不支持的其他存储,比如本地文件,一般的解决方案是数据迁移到支持的环境。

03.数据导入

这应该是整个平台里较为简单的功能,有点类似于元数据管理的功能,不过功能要更简单。要做的是在平台创建一个对应的数据Mapping。为保证数据源的可访问,以及用户的操作感知。平台要做的事情可以分为三步:

访问对应的数据源,以测试数据是否存在、是否有权限访问。

拉取小部分数据作为采样存放在平台中(如MySQL),以便于快速展示,同时这也是数据本身的直观展现(Sample)。对于图片、视频类的,只需要存储元信息(如资源的url、大小、名称),展示的时候通过Nginx之类的代理访问展示即可。

如果是有Schema的数据源,例如Hive表,数据源的Schema也需要获取到。为后续数据处理作为输入信息。

威廉希尔官方网站 上来说,平台中会存在与各种存储设施交互的代码,大量的外部依赖。此时,外部依赖可能会影响到平台本身的性能和可用性,比如Hive的不可用、访问缓慢等,这个是需要注意的。

业务上来说,更多考量的是提高系统的易用性,举个例子,创建Hive表数据源,是不是可以支持自动识别分区,选择分区又或者是动态分区(支持变量)等。

04.数据处理

这里的数据处理是一个大的概念,从我的认知上来看。大体可以分成两个部分, 数据标注以及特征处理。

数据标注

数据标注针对是的监督学习任务,目前机器学习的应用场景大多都是应用监督学习任务习得的。巧妇难为无米之炊,没有足够的标注数据,算法的发挥也不会好到哪儿去。对于标注这块。业务功能上来说,基本上可以当成是另一套系统了,我们可以把它叫做标注平台。但从逻辑关系上来说,标注数据是为了机器学习服务的。本质上也是对数据的处理,所以划到机器学习平台里面也没有什么问题。

标注平台对应了之前提到平台的另一功能:提供通用的流程规范。这里,流程指的是整个标注流程,规范指的是标注数据存储的规范,比如在图像领域,目前没有通用而且规范的存储格式,比较需要平台来提供一种通用的存储格式。

数据标注有两种,一种是人工标注; 另一种是使用已训练好的机器学习模型来标注,然后再辅以人工确定和修订。无论是使用哪种方式,最后都需要人工介入。因为数据标注的正确性是非常重要的,大家应该都听过一句话: 数据和特征决定了机器学习的上限,而模型和算法只是逼近这个上限而已。 如果给你的数据都是有问题的,那模型如何能学习到正确的能力呢。

在标注平台中,往往都是人工+模型混合使用的,整体流程如下:

2-how-to-build-machine-learning-platform-768x257.png

在标注平台中,人工+模型混合使用

在最开始可能没有模型来辅助进行标注(这里的预标注),这个时候就需要人为手工介入,以此来训练出一个模型

当我们根据标注出的数据(训练数据集)训练出不错的模型之后,就可以使用此模型来对新输入的数据做一个预标注的工作,然后再辅以人工确认和修订

如此反复迭代,随着输入数据的增多,当我们训练出的模型准确率达到一个很高的水准之后,需要人工操作的数据就会越来越少。以此减少人工成本费

标注平台中需要考量的问题有几点:

一般来说,需要标注的数据量都是非常巨大的。不存在说两三个人随便标几下就完事。所以更为通用的做法是做一个众包平台,外包给其他公司或者自由职业者(标注员)来做。参考AWS的Amazon Mechanical Turk。这就涉及到了权限控制、角色控制。

标注数据的准确性问题。不能避免有些标注员划水摸鱼,随意标注。此时是需要己方人员去做一个审计工作的,这里就是一个工作流,和上图所示差不多。是一个相对来说较为规范的流程,可以随着业务来增加额外的流程。

标注工具的开发。如果有合适开源工具,可以集成开源工具,如VGG-VIA/Vatic, poplar。开源工具一般不会满足所有的需求,在开源上做二次开发往往成本更高。这里更倾向于自己开发,这样更能满足需要,自定义程度高,灵活性强

标注数据的存储。最好是一个相对通用的格式,以便于往各种其他格式做一个转换。在使用时做一个数据格式转换。这里更偏好Json格式类似的存储,可读性和代码可操作性都非常高

威廉希尔官方网站 上的考量,这里并不是太多。唯一需要注意的可能是数据的处理,如图片、视频标注,资源的拆剪、缩放,各种标注数据的保存,坐标计算等。相对而言,后端主要是工作流处理,前端的各种标注工具是威廉希尔官方网站 核心点。

特征处理

在正式开始模型构建与训练之前,对数据做特征处理基本上是必不可少的环节。特征处理的输入是之前创建的数据集、或者是标注完成后产生的数据集。它的输出是经过一系列数据操作后、可以直接输入到模型中的数据,这里称它为训练数据。

这里又可以分为两类,一类是不需要太多操作的特征处理,常见于非结构化数据,如图片、视屏。另一类是针对结构化/半结构化数据的特征处理流程,这类数据往往不是拿来即可用的,需要一定的特征处理。

首先来看第一类,第一类的典型应用场景就是CNN图像领域。对于输入的图片,一般不需要太多的操作。此类数据源往往也是存储在NFS/OSS上的。对于此类数据的处理,一般也不会使用到大数据框架,一般都是自己手撸Python(C++)来处理;或者是放在模型训练一起处理,不单独拎开。Spark2.3开始是支持图片格式的,不过目前没有看到太多的使用案例。整体流程如下:

3-how-to-build-machine-learning-platform-768x118.png

CNN图像领域

本质上是一个批处理过程,Kubernetes的Job天然适用于此类问题。当然其他调度框架来做这个任务调度也是可以的。

然后是第二类,这种基本上就是传统的特征工程了,以Hive/HDFS输入为经典例子。由于对数据的操作是非常多样的,所以一般倾向于构建一个数据处理的流水线,也就是Pipeline:

poYBAGFlVuyATy9sAABEC7l6zSc139.png

传统的特征工程

把对数据的操作拆分成一个一个的操作运算(也就是一个Pipeline Node节点),可以把它叫做算子,然后利用Pipeline把操作进行自由组合,从而达到对数据进行各种变换处理的过程。使用过Sklearn pipeline或者Spark MLlib pipeline的小伙伴应该对此并不陌生,事实上,这就是基于此的可视化建模。使得用户可以在界面上进行拖拉拽,选择和输入一些参数来完成对于数据的操作,提供更灵活的功能。

那么这条Pipeline里面都有哪些操作呢,整个算子大致可以分为这几类别:

pYYBAGFlVuyAeSArAACr174DbfI300.png

特征处理

威廉希尔官方网站 上,使用Spark MLlib是个不错的选择,可以适应不同数据量的规模。且天然支持这种Pipeline的形式,只需要对此做一定的封装。同时,考虑到业务功能,还需要手动定制、修改一些算子;对于扩展这点,它的支持也是非常不错的,自定义算子、算法都比较简单。当然也可以基于其他框架(如Azkaban)或者自己造轮子。需要注意的是,在大数据场景下,Spark MLlib里面部分自带的算子会有性能问题(有些直接OOM),需要分析源码定位然后修复。包括我们自己实现的算子,也都要考量大数据场景下这个问题,这对于测试而言是个Case。

整个Pipeline的核心是构造一个DAG,解析后,提交给对应的框架来做处理。抛开威廉希尔官方网站 来说,功能上来说,易用性和快速反馈是Pipeline需要注意的。比如:

所有的算子都应该能自动获取到可用的输入、对应类型,自动生成输出

支持参数校验,Pipeline完整性校验

支持调试/快速模式,利用部分Sample data快速验证效果,相当于一个试验功能

日志查看,每个算子状态查看,以及操作完成后的Sample data查看

支持一些变量、SQL书写,以扩展更灵活的功能,比如参数动态化

支持定时调度,任务状态邮件、短袖及时告警、同步等

05.模型训练

到了模型训练这块。从功能上来看需要的不是很多,更多是体验上的设计。比如参数在界面上的展示和使用,日志、训练出的Metrics的可视化、交互方式,模型的一些可视化等。核心功能包含这几块儿:

1.预置算法/模型

这里考量的点是:

支持界面手动调参

训练中日志、Metrics的可视化。支持同时使用不同的参数多次训练,直观对比结果方便调参

需要支持常用的框架,如Spark MLlib/Tensorflow/Pytorch,或者一些特定的框架(业务方需要的)

预置算法/模型很简单,在不同的框架上封装一层并且暴露对应的参数给到用户即可。有些算法可能框架不支持,这种根据情况决定如何解决(自己实现或者其他解决方案)。有一点就是,框架不宜太多,否则在后续模型发布的Serving上,也需要多套解决方案。对于训练本身来说,分为两种:单体/单机训练和分布式训练,分布式训练是训练这块的大头(也是威廉希尔官方网站 难点所在)。

对于单体/单机训练的解决方案,和上诉特征处理中的解决方案一致。优先使用Kubernetes的Job,或者使用Spark,控制下Executor即可。

对于分布式训练,目前接触到的,基本上都是数据并行:

poYBAGFlVuyAfiXMAABa1fEmoHs005.png

分布式机器学习

以Spark为基础的基本都使用的是PS模式。PS模式一般使用的都是异步更新参数,每个Worker只需要和PS通信,所以容错管理上会更加简单。AllReduce模式则是同步的参数模式,而且每个Worker都需要上下游通信,相对而言,容错处理会更苛刻一些。

Spark系的分布式训练,经典的算法可以由Spark MLlib提供。但是其对于DNN的支持并不好,而且Spark的训练是一个同步的过程,如果数据倾斜的话,整个训练的速度取决于最慢的RDD。如果要在Spark上跑深度学习的模型,一般会选用其他框架或者基于Spark的框架,如腾讯的Angel、 Intel的BigDL。两者的思想都是一致的,同属于PS模式下的分布式训练,整个流程可以概括为这几步:

利用Spark来作为任务调度、资源分配、数据读取和容错处理的容器

从PS拉取参数,然后将数据和参数通过JNI喂到底层的框架代码中去(如Pytorch C++ Frontend)完成训练,返回梯度

使用优化算法和梯度,更新参数,再将新的参数更新到PS。如此反复

借用一张Angel的图:

pYYBAGFlVu2AauwbAABnQnC2XS8961.png

Angel的图

顺着这个思路,可以以Spark为基础,兼容任何深度学习框架。只要底层框架:

支持模型/代码序列化,以支持分发模型到所有Worker中进行本地训练

通过JNI能调用模型提供的接口,如Forward/Backward

这要比自己造轮子更加便利和友好,毕竟Spark已经是一个成熟的分布式计算框架了。

如果使用的是Python系的深度学习框架有两点需要注意:

如何读取分布式存储上的数据以支持数据并行。也就是Spark里面Partition的概念。当然最简单的方法,就是将数据拆分成块,不同的节点读取不同的数据来训练。

另外一点在于容错性,基于Spark的分布式训练的优势就在于数据的分配、容错处理。现在就得自己去保障这两点了。

训练部署上面。Spark系的,使用Spark支持的即可(Yarn/Kubernetes/Standalone)。Python系的更倾向于云原生、或者基于Kubernetes的解决方案(自定义Operator是个比较好的选择),这里有个为云原生和容器化而生的框架:Polyaxon,值得一试。

2. 自定义算法

关于自定义算法,个人更倾向于将这个功能放在Notebook中而不是界面化的操作上,因为这个功能的自由度很高,允许用户自己写代码。平台其实只需要提供:

数据读取能力,这里包括源数据、平台内生成的数据

NFS/OSS使用Mount形式或者API提供(如Databricks 的DBFS)

HDFS系列的API提供支持(如提供pyspark)

调度能力,能根据需求调度起任务。

以上两者功能,都或多或少依赖于SDK/API/CLI。可以参考大厂的实现Amazon SageMaker、Databricks Notebooks。

另外一点是GPU的支持,这点,如果是选择Kubernetes作为基础设施,是有基本的功能支持的,利用Extended Resource(ER)配合 Device plugin体系:

poYBAGFlVu2AEhxDAACn1P_1K8o361.png

Extended Resource(ER)配合 Device plugin体系

对于Hadoop体系的话,3.1.X之后也是支持的。

这两者对于GPU的支持都非常有限,都是处于一个能用,但是不好用的状态。使用的时候,淌坑可能在所难免。

3. AutoML

关于AutoML这块。目前还没有太多的接触。从我看来,做个简单的随机搜索还是问题不大的,集成算法来自动调参、自动构建模型也是不难的。就跟上诉集成算法进来是一样的。唯一考量的是,集成那些算法进来以及计算资源的考量,尤其是深度学习大行其道的今天,类似于随机搜索这样耗费的资源是巨大的。如何设计这个功能,以及具体实现还是需要非常专业的领域知识。

总的来说,模型训练这块。是一个很偏威廉希尔官方网站 的功能。完成一个Demo的端到端,实现基本的功能很简单。但是要做到好用、稳定性这两点就并不那么容易。尤其是分布式机器学习这一块儿,还是需要不断淌坑的。

06.模型发布

终于来到最后一步,是整个平台产生价值的最后一环。模型发布,通常包含两种发布:

发布成API(RESTful/gRPC),以供业务侧实时调用。这类服务通常对于性能要求苛刻

发布成批处理形式,用于批处理数据,上述标注平台中的预标注属于此类任务

对于批处理形式的发布,较为简单。一般框架本身都支持模型的序列化和加载做预测:

Spark系的就依旧走原始路线,提交Spark Job,做批处理预测

TensorFlow类似的,配合不同的镜像环境,Mount模型,读取数据,配合Kubernetes Job的方式来启动批处理达到一个统一的处理流程

对于实时推理服务,于平台而言,能使用通用的框架/威廉希尔官方网站 来做那当然是极好的。然鹅,现实很残酷。通用的解决方案,要么性能不够(如MLeap),要么支持的算子/操作/输入有限(如ONNX。想要在真正的业务场景下发挥价值都是需要淌坑的。用的更多的,往往都是性能领域强悍的C/C++/RUST来实现,比如自研、或者框架本身自带的(如TensorFlow的Serving),会更能满足性能需求。平台选用的框架最好是不要太多,这样做Serving会比较麻烦,不同的框架都要去找解决方案实现一遍。

虽然做不到通用的模型Serving方案,但是通用的模型发布、提供服务的平台却是可以做到的。这是这部分的重点,即如何设计一个通用的推理平台。一个推理平台需要考量的点如下所示:

支持各种框架,多语言、多环境

模型版本管理

API安全性

可用性、可扩展性,服务状态监控、动态扩容

监控、告警,日志可视化

灰度上线/AB Testing

把Serving看做是普通的Web服务。对于上诉的点,Kubernetes体系是绝佳的选择:

镜像,配合NFS的模型,启动时Mount再复制到容器内部。可以支持多语言、多环境

版本管理,每个版本在NFS上创建新的版本目录,比如0.0.1,放入对应的模型和启动脚本配合一个Service。这样就允许不同版本的Service同时在线,或者部分在线

API安全性,与Kubernetes本身无关。简单的做法是为每个API生成对应的调用Token来做鉴权,或者使用API网关来做

可用性、可扩展性。利用Kubernetes原生的Liveness/Readness probe,可以检测单个Pod中服务的状态。使用Kubernetes的HPA、或者自己实现监控再配合Autoscale可以满足需求,而且这些都可以成为一些配置暴露给用户

监控、告警。可以Prometheus+Grafana+Alertmanager三件套,或者配合企业内部的运维体系

交给Istio即可。灰度发布肯定妥妥的,利用一些Cookie/Header来做分流到不同版本的服务也可以做到部分AB Testing的事情

由于Serving服务与服务之间是没有关系的,是一个无状态的单体服务。对于单体服务的各种处理就会比较简单。比如不使用Kubernetes,使用AWS云的EC2来部署,配合Auto Scaling、CloudWatch等也是非常简单的。

07. Addons

除开上诉的核心功能。一般来说,机器学习平台还有一些扩展。最经典的当属CLI和SDK了。

CLI就不用多说了,主要提供快捷入口。可以参考AWS的CLI。需要包含的点主要是:

提供基本的操作功能,满足用户的使用

以及导入导出功能。方便用户共享配置、快速创建和使用平台的功能

支持多环境、认证

完善的操作使用文档、帮助命令、模板文件等

对于SDK这块,需要和平台本身的功能做深度集成;同时,还需要一定的灵活性。比如上诉的自定义算法,用户可以在Notebook里面读取平台生成的数据集,写完代码后,还得支持提交分布式训练。既要集成平台功能,又得支持一定程度的自定义,如何设计会是一个难点。

08.探索实验(Notebook)

Notebook本身功能并不复杂。实质上就是对Jupyter Notebook/JupyterLab等的包装。通常的做法是使用Kubernetes的Service,启动一个Notebook。以下几点是需要考量的:

存储要能持久化,需要引入类似于NFS这样的持久目录以供用户使用

内置Demo,如读取平台数据、访问资源、提交任务

预置不同的镜像,支持不同的框架,以及CPU/GPU诉求用于启动不同的Notebook

安全问题,一个是Notebook本身的安全。另一个是容器本身的安全

有可用的安全源,以供用户安装和下载一些包和数据

能够访问到基础设施里面的数据,Mount/API

最好能有Checkpoint机制,不用的时候回收资源。需要的时候再启动,但环境不变

大致的解决思路如下:

持久化需要Mount存储。Storage class可以帮助

Notebook自身的安全,可以在里面增加Handler或者外面配置一层Proxy来鉴权。容器的安全大概有这几点需要考量(要做到更严格还有很多可以深挖):

限制容器内部用户的权限

开启SELinux

Docker的—cap-add/—cap-drop

heckpoint机制的实现,数据已经持久化在外部存储了。只需要Save新的镜像,作为下次启动的镜像即可,可使用Daemonset+Docker in dokcer的形式做一个微服务来提交镜像。

09. 平台的基石

这一节主要讨论的是做平台一定绕不开的问题。首先逃脱不了的是多租户问题:

可能要和已有的系统进行集成。而不是新开发

租户间权限、数据隔离

租户资源配额、任务优先级划分

威廉希尔官方网站 上来说,系统自身的租户功能难度不高。主要是数据、资源隔离这块。要看对应的基础设施:

Hadoop可以使用Keberos

Kubernetes可以使用Namespace

再配合不同的调度队列。即可完成需求。

另外一点是偏威廉希尔官方网站 层面的调度功能。这可以算是整个平台运行的基础,无论是数据处理还是模型训练、模型部署都依赖于此, 调度系统分为两块:

调度本身,即如何调度不同的任务到不同的基础设施上

状态管理,有些任务可能存在依赖关系,会触发不同的Action。这也是一个状态机的问题

状态管理这块,业务场景不复杂的情况下自己实现即可。一般平台上也没有太复杂的依赖关系,经典的模型训练也不过单向链路而已。如果过于复杂,可以考虑其他开源任务编排工具:

pYYBAGFlVu6AC_wpAABC1mDlSLQ143.png

状态管理

调度本身是一个任务队列+任务调度组合而成。队列用啥都可以,数据库也可以。只要能保证多个Consumer的数据一致性即可。任务调度,如果不考虑用户的感受,可以直接丢给对应的基础设施,如Yarn/Kubernetes都可以。由这些基础设施来负责调度和管理,这样最简单。

如果想做的尽善尽美,那还是需要维护一个资源池。同步基础设施的使用情况,然后根据剩余资源和任务优先级来做调度。

状态更新方面。对于Yarn体系,只能通过API去轮询状态、获取日志。

对于Kubernetes体系,推荐一个Informer机制,通过List&Watch机制可以方便、快速获取整个集群的情况:

poYBAGFlVu6ASirVAAD91vAw72o562.png

Custom Controller

关于如何提交任务到基础设施:

Spark/Yarn - 直接API、包装下命令行者Livy都可

Kubernetes - SDK

10.最终Boss

做平台,最怕的是什么?当然不是某某威廉希尔官方网站 太过于复杂,攻克不下。而是没有用户使用平台,或者不能通过平台产生真实业务价值,这才是最重要的。有某一业务场景在平台实现端到端产生价值,才能证明这个平台的价值,才能吸引其他用户来使用。

对于用户来说,一般都已经有自己成熟的威廉希尔官方网站 线。想要他们往平台上迁移,实属不易,除非已有系统满足不了他们的需求、或者已有系统不好用。毕竟,自己用的好好的系统,迁移是需要耗时耗力的,用别人的东西也没有自己做来的灵活;学习一个新的系统使用也是如此,有可能一开始用着并不习惯。此外,新的系统,没有人期望第一个来当小白鼠的。有这么多缺点,当然平台本身也有其优点。比如将基础设施这块甩给了第三方,不用去关注底层的东西,只要关注自己的业务了。

事实上的流程往往都是,随着平台MVP的发布。部分用户开始上来试用,然后提各种想法和需求;紧接着,会逐渐迁移部分功能上来试用,比如搞些数据上来跑跑Demo,看看训练的情况等。同时,在这个阶段,就会需要各种适配用户原始的系统了,比如原始数据导入与现有系统不兼容,需要格式的转换;再比如只想用平台的部分功能,想集成到自己现有的系统中等。最后才是,真正的在平台上使用。想要用户能端到端的使用平台,来完成他们的业务需求,还是需要漫长的过程的。

相对而言,至上而下的推动往往更为有效。总有一批人要先来体验、先来淌坑,给出建议和反馈。这样这个平台才会越来越好,朝好的地方发展。而不是一开始上来就堆功能,什么炫酷搞什么、大而全。但是在用户使用上,易用性和稳定性并不好,或者是并不能解决用户的需求和难点。那这种平台是活不下去的。
fqj

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

    关注

    7

    文章

    3807

    浏览量

    64434
  • 机器学习
    +关注

    关注

    66

    文章

    8420

    浏览量

    132687
收藏 人收藏

    评论

    相关推荐

    传统机器学习方法和应用指导

    在上一篇文章中,我们介绍了机器学习的关键概念术语。在本文中,我们会介绍传统机器学习的基础知识和多种算法特征,供各位老师选择。 01 传统机器
    的头像 发表于 12-30 09:16 157次阅读
    传统<b class='flag-5'>机器</b><b class='flag-5'>学习</b>方法和应用指导

    如何选择云原生机器学习平台

    当今,云原生机器学习平台因其弹性扩展、高效部署、低成本运营等优势,逐渐成为企业构建和部署机器学习应用的首选。然而,市场上的云原生
    的头像 发表于 12-25 11:54 111次阅读

    构建云原生机器学习平台流程

    构建云原生机器学习平台是一个复杂而系统的过程,涉及数据收集、处理、特征提取、模型训练、评估、部署和监控等多个环节。
    的头像 发表于 12-14 10:34 140次阅读

    什么是机器学习?通过机器学习方法能解决哪些问题?

    来源:Master编程树“机器学习”最初的研究动机是让计算机系统具有人的学习能力以便实现人工智能。因为没有学习能力的系统很难被认为是具有智能的。目前被广泛采用的
    的头像 发表于 11-16 01:07 418次阅读
    什么是<b class='flag-5'>机器</b><b class='flag-5'>学习</b>?通过<b class='flag-5'>机器</b><b class='flag-5'>学习</b>方法能解决哪些问题?

    NPU与机器学习算法的关系

    在人工智能领域,机器学习算法是实现智能系统的核心。随着数据量的激增和算法复杂度的提升,对计算资源的需求也在不断增长。NPU作为一种专门为深度学习机器
    的头像 发表于 11-15 09:19 472次阅读

    使用机器学习和NVIDIA Jetson边缘AI和机器人平台打造机器人导盲犬

    Selin Alara Ornek 是一名富有远见的高中生。她使用机器学习和 NVIDIA Jetson 边缘 AI 和机器人平台,为视障人士打造了机器人导盲犬。 该项目名为 I
    的头像 发表于 11-08 10:05 405次阅读

    机器学习算法原理详解

    机器学习作为人工智能的一个重要分支,其目标是通过让计算机自动从数据中学习并改进其性能,而无需进行明确的编程。本文将深入解读几种常见的机器学习
    的头像 发表于 07-02 11:25 1083次阅读

    深度学习与传统机器学习的对比

    在人工智能的浪潮中,机器学习和深度学习无疑是两大核心驱动力。它们各自以其独特的方式推动着威廉希尔官方网站 的进步,为众多领域带来了革命性的变化。然而,尽管它们都属于机器
    的头像 发表于 07-01 11:40 1407次阅读

    广和通发布机器人开发平台

    广和通近日隆重发布了其全新研发的具身智能机器人开发平台——Fibot。平台旨在满足客户在验证Mobile ALOHA协同学习与简单示教操作
    的头像 发表于 03-29 09:34 638次阅读

    NVIDIA Isaac机器人平台升级,加速AI机器人威廉希尔官方网站 革新

    NVIDIA Isaac机器人平台近期实现重大升级,通过引入最新的生成式AI威廉希尔官方网站 和先进的仿真威廉希尔官方网站 ,显著加速了AI机器人威廉希尔官方网站 的发展步伐。平台正不断扩展其基础模型、
    的头像 发表于 03-27 10:36 689次阅读

    机器学习8大调参技巧

    今天给大家一篇关于机器学习调参技巧的文章。超参数调优是机器学习例程中的基本步骤之一。方法也称为超参数优化,需要搜索超参数的最佳配置以实现最
    的头像 发表于 03-23 08:26 632次阅读
    <b class='flag-5'>机器</b><b class='flag-5'>学习</b>8大调参技巧

    人工智能和机器学习的顶级开发板有哪些?

    机器学习(ML)和人工智能(AI)不再局限于高端服务器或云平台。得益于集成电路(IC)和软件威廉希尔官方网站 的新发展,在微型控制器和微型计算机上实现机器学习
    的头像 发表于 02-29 18:59 843次阅读
    人工智能和<b class='flag-5'>机器</b><b class='flag-5'>学习</b>的顶级开发板有哪些?

    如何使用TensorFlow构建机器学习模型

    在这篇文章中,我将逐步讲解如何使用 TensorFlow 创建一个简单的机器学习模型。
    的头像 发表于 01-08 09:25 997次阅读
    如何使用TensorFlow构建<b class='flag-5'>机器</b><b class='flag-5'>学习</b>模型

    集成电路学习与实训平台配置方案-高职院校第一期建设

    北京革新创展能科技有限公司提供的集成电路学习与实训平台配置方案,主要用于高职院校第一期建设需求,如需详细方案,请随时联系我们。
    的头像 发表于 01-03 10:42 860次阅读
    集成电路<b class='flag-5'>学习</b>与实训<b class='flag-5'>平台</b>配置方案-高职院校第一期<b class='flag-5'>建设</b>

    集成电路学习与实训平台配置方案-本科院校第一期建设

    北京革新创展科技有限公司提供的集成电路学习与实训平台配置方案,主要用于本科院校第一期建设。如需详细方案资料,请随时联系我们。
    的头像 发表于 01-03 10:29 1061次阅读
    集成电路<b class='flag-5'>学习</b>与实训<b class='flag-5'>平台</b>配置方案-本科院校第一期<b class='flag-5'>建设</b>