如何快速在阿里云上构建自己的机器学习应用

本文涉及的产品
传统型负载均衡 CLB,每月750个小时 15LCU
对象存储 OSS,20GB 3个月
交互式建模 PAI-DSW,5000CU*H 3个月
简介: 在2017云栖大会深圳峰会开源专场上,阿里云容器服务技术专家车漾做了题为《在阿里云上构建机器学习应用》的精彩演讲,车漾首先从2016年深度学习最火的两个应用AlphaGo与Prisma谈起,从宏观层面分享了机器学习以及深度学习所做的事情,并就Prisma的发展故事谈起,为大家介绍了应该学会以工程思想思考和解决问题,并着重介绍了阿里云基于容器服务的机器学习解决方案架构设计以及如何借助阿里云快速搭建自己的机器学习应用,精彩不容错过。
摘要:在2017云栖大会深圳峰会开源专场上,阿里云容器服务技术专家车漾做了题为《在阿里云上构建机器学习应用》的精彩演讲,车漾首先从2016年深度学习最火的两个应用AlphaGo与Prisma谈起,从宏观层面分享了机器学习以及深度学习所做的事情,并就Prisma的发展故事谈起,为大家介绍了应该学会以工程思想思考和解决问题,并着重介绍了阿里云基于容器服务的机器学习解决方案架构设计以及如何借助阿里云快速搭建自己的机器学习应用,精彩不容错过。

以下内容根据嘉宾演讲视频以及PPT整理而成。

在2016年有两个深度学习应用使得深度学习这个概念走入了平常百姓家,大家开始意识到深度学习技术好像和我们的生活开始产生联系了。第一件事情就是AlphaGo战胜了围棋世界的高手李世石,它向我们证明了一件事情:计算机不但具有强大的运算能力,它甚至开始学会学习了,更可怕的是计算机的学习能力是一种纵向深入的学习能力,也就是随着计算机看到的数据越来越多,随着时间的不断往前发展,计算机有可能成为某个领域的专家,在围棋中是这样,在其他的领域,比如医学等领域也都会有同样的影响。可以说,AlphaGo是第一个使我们真正意识到机器学习具有一种自我演进能力的应用。
88b936aed30086c61e31fce430e52719757bcc06
第二件事情就比较有意思了,Prisma这款应用是2016年度苹果APP Store的排到第一名的最佳手机应用,这款手机应用其实也是基于深度学习技术来实现的,它所做的事情就是像将自己家小区后院的照片传上去,然后指定一个绘画大师的作品,比如指定梵高的《星空》这个作品,将两者合成一张新的图片。
86f6dd5b91d3c54dbf41741aee1e4e5f172aba3b
合成后的这个图片的特点就是内容还是楼下的小区,但是这张图片的风格看起来就是梵高画出来的了。那么如果使用机器学习的语言来解释一下这是如何做的就是实际上这个应用做了两件事情:第一件事情就是从这张梵高的画中学习出来一个函数f(),这个函数f()的价值是什么呢?其实就是反应了梵高这幅画作的风格,这就是机器学习所做的第一件事情,从这张画作学习到了一个能够反应梵高风格的函数。其实比如说产生整个图片的工作需要花费10个小时的话,上面说的这个产生f()函数的这件事情需要花费9个小时,甚至是9个小时55分钟。而最后将这个函数f()求出来之后,将楼下小区的照片这个X赋值到f()函数中,就产生了一个新的图片,其实剩下的仅有的5分钟就是用来做这件事情的。
2b2805a9627812f3fcc4980b4957fc7a1af0a341
讲到这里大家应该就能理解所谓机器学习是在做什么,应该怎样去转换这张图片。这时候可能大家会产生一个疑问,其实早在2010年就已经滤镜程序了,通过一个滤镜打上去其实也可以产生这样的效果,这个滤镜程序和深度学习的画像有什么区别呢?其实两者之间的区别就在于这个f(),这里面最大的区别就是f()是如何产生的,传统的滤镜技术是依靠一个程序员实现的,让他去理解这个画像的风格是什么样的,他自己去手敲代码去实现f()这个函数,而机器学习则是由机器自己从这个图片中提取信息并且计算出f()。这种区别产生的影响有两个:第一个就是程序员写一个梵高画的风格的程序可能需要花费两周的时间,如果再来一个毕加索就可能还需要两周的时间,也就是产生的成本比较高,这是第一个影响,第二个影响是什么呢?就是理解性问题,第一种使用滤镜的方式对于画的理解并不是梵高的理解,而是编写程序的程序员的理解,所以在这里面需要为大家解释清楚的就是机器学习和加滤镜的区别就是机器学习的本质,也就是这个规律是机器自己学习到的,并不需要人来教,人只需要给它数据集就可以了。

这个厉害的深度学习算法实际上并不是Prisma这个公司的创始人发明的,而是在2015年,也就是Prisma大火的前一年,三个德国的数据科学家发明了这个算法并且利用这个算法创办了自己的创业公司叫做DeepArt,它所能做的事情就是提供一个网站让用户将自己的图片上传上去并选择一个风格,经过3到5个小时的计算产生处一个有自己图片内容的大师风格的作品。这个网站上线之后效果还算不错,有一些人愿意花100多欧元去得到这样一幅作品,但是并没有大火。
e7cef577d5dd086a97c20390914e3f45b43ae702
而在2016年年初的时候,一个俄罗斯的软件工程师看到了这个论文并且也看到了DeepArt所做的产品,这个俄罗斯的工程师就认为他们做的产品存在问题。那么这个网站之所以没有火起来是为什么呢?俄罗斯工程师进行了思考,他发现原有产品中存在两个问题,第一个问题就是产生图片的时间太长了,5到6个小时,没有人愿意去等这么长的时间;第二个问题就是DeepArt只提供了一个网站,大家都知道网站无法得到高频的访问,我们需要有个电脑才能去进行登录再访问,所以使用起来的效果并不好。所以这个俄罗斯工程师就想开发一个手机APP,并使得手机APP能够达到的效果是将图片上传上去之后等待10到20秒就能够得到已经选好风格的图片,所以他就开始研究如何让图片转换的时间变短。其实就像刚才提到的,在这里机器学习主要做两件事情,第一件就是去求解代表风格的函数,第二件事情就是利用将值赋给这个函数去计算出最后的结果值,也就是说在做风格转换时的工作就是去解这个方程去求出绘画风格。如果能够像数据库一样将风格函数持久化地存储到硬盘上,每一次生成新图片的时候都将函数从硬盘上进行加载而免去了计算的过程,就可以将原来的6小时变成几分钟甚至更短的时间,实现后这个时间缩短达到了20秒。这个俄罗斯工程师实际上并不是机器学习方面的专家,但是他找到了问题的症结,并在此基础之上使用了一个月的时间开发出了这套Prisma的APP,这个APP在欧洲一上线在大概两周的时间内就有了三千万的下载量。如下图所示,梅德韦杰夫也是Prisma的忠实粉丝。当时在8月份的时候,在欧洲人普遍对于艺术有较高的鉴赏能力的情况下,他们都认为这个应用比较能够打动内心。
f023474cf91a2703d087a8f55ec89ce76b6c8147
刚才讲述的这个故事实际上是想告诉大家一个道理,我们现在正处于AI即将到来的时代,但是AI时代并不只属于数据科学家、AI科学家以及这些程序员们。AI的技术是非常重要的一件事情,但比这件事情更重要的是如何利用AI技术转化出相应的产品,实现数据、技术和产品之间的联动,真正能够将AI技术应用到大家的日常生活中,像Prisma一样应用AI来为大家创造价值,讨得大家的欢心,这个才是最重要的,也是需要大家一起去思考的事情。也许你并不是AI的专家,但是也应该去思考如何才能将AI应用起来。实际上重要的是我们的想法,如果你有自己的想法,再利用一些开源的工具,加上阿里云的资源就可以很容易地构建属于自己的深度学习的应用。
b79c68d886e98105fe7bc881fe4d7ac39fdc41fa
我们所处的是一个开源的时代,很多深度学习和机器学习的学习库实际上都是开放的,包括谷歌的TensorFlow、微软的CNTK、Caffe、Mxnet等这些都是开源的机器学习库,如果大家想去学习这些开源库,其实有很多相关的资源可以参考。
910661d0442f4f8ef571479bcc49e554f17eeac7
在这里主要介绍一下TensorFlow,TensorFlow是2015年谷歌开源的一套机器学习库,其在深度学习方面非常好用,目前在GitHub上面大约有5万颗星,其实也是大家开始深度学习一个非常好的起点,它的最大特点是虽然不算性能最好,但是最为简单。
2657bdf43290cf5aa703cb3084488ea17e51dc5e
在这里想和大家说的是关于刚才提到的风格转换这件事情实际上有很多个实现,依赖于不同的机器学习库,包括TensorFlow、Mxnet、Torch以及Caffe等,在分享的最后也会给大家看一下一些使用这些库实现应用的代码。
cb70533c5ed000f99d96642672d779334242e22d
有了这些机器学习库和机器学习的代码可以供大家进行学习,剩下的就是让大家了解一下如何构建自己的机器学习以及深度学习的应用。刚才提到了整个机器学习的流程从大的方面可以分为两个部分,一部分可以称之为求解方程,第二部分可以称为给方程赋值。所以在机器学习的流程中的第一部分就是训练,根据数据如何去训练出这个机器学习模型,实际上就是在求解这个方程。而第二步当这个方程解完之后,就可以给方程赋予新的值让它去做预测。具体来看,第一步在求解方程中最重要的也是机器学习最核心的事情就是数据和计算量,首先需要准备数据并且上传到云上,这是在云上进行机器学习的最重要的起点。第二步就是需要开发自己的训练程序,这个训练程序所做的事情就是根据数据来进行训练、求解方程,并对于程序的正确性进行确认。第三步,当我们具有大规模数据的时候,就可以执行一些训练,刚开始时可能做的是单机,但是在真正进行训练的时候,可能因为性能的需求、数据量的需求可能需要使用GPU以及分布式的训练,这个时候就是第三步执行训练任务,在执行完训练任务之后有一个很重要的工作就是导出这个训练模型,导出这个训练方程。在最后将这些应用到在线预测中,就是相当于对于方程进行赋值,这就是真正的工作流程。
cdb27f5c364b8b3f40f5b7b63b901c40fabf1021
然后向大家先介绍一下阿里云基于容器服务的机器学习解决方案架构。如下图所示的解决方案是以容器服务为核心的,在这里面所有服务是以容器作为载体的,容器服务贯穿整个机器学习的整个生命周期,包括开发、训练、预测以及数据处理,并且这个解决方案很好地集成了阿里云已有的机器学习能力,比如弹性计算、高性能计算以及弹性GPU计算、VPC网络以及共享存储、运维以及镜像等能力。使大家的深度学习应用能够无缝地和阿里云的服务进行集成,这就是这个方案所能够带来的好处。
812167cab6d20fa539ebc6f0d93099c00acaf527
那么这个事情具体是如何实现的呢?首先第一步是需要准备数据,因为我们知道像在阿里云上做深度学习的话,上传数据最简单的方式是通过OSS,这就可以通过OSS命令或者图形客户端的拖拽方式将数据上传上去。同时如果数据量非常巨大,那么OSS还提供了一套传输上G数据的解决方案,这样就可以支持大规模的运算。
6d6150fe73680addf9b6b425982f6d24cfda7b97
第二步就是开始创建云端的实验开发环境,利用图形应用,在这里是使用阿里云的图形管理界面来创建Jupyter的一套开发测试环境。如果大家曾实现过深度学习的编程可能就会知道Jupyter是一套比较好的交互式的文本,可以在上面写自己的查询代码然后以交互的方式知道每一步执行的结果是什么样子。这里面同时还加入了TensorBoard,TensorBoard具有针对TensorFlow的一些支持,可以将整个学习的过程包括最后求解的方程所求的数值解与真实解之间的误差是多少以图形化的方式展示出来。可以通过这个观察整个误差的发展情况,以此来判断整个的学习过程是不是在正确的方向上。搭建完成环境后的第一个步骤就是构建应用。
46df5bf784e08f6d450b7368371c3c64ca47a130
当程序写完之后,下一步做的事情就是构建云端训练,也就是如何在云上面将真正的程序跑起来,因为这个程序可能是分布式,那么这里面支持的是什么呢?其实通过图形用户化的界面就可以去指定这里面使用到的是单机训练还是多机训练,以及这个程序所需要的依赖是什么。而这里面最重要的是方程的解,这可以通过阿里分布式存储解决方案帮助去将checkpoint和模型保存成为可持久化的数据,同时利用TensorBoard去监控整个训练的过程。
dc3b3b4e020b87b085aa784a8eb981d77cb54144
这里稍微提一下如何使用TensorFlow去保存模型。TensorFlow提供了两种保存模型的方式,第一种方式是Checkpoint,Checkpoint实际上是最常用的保存方式,其最常用的场景就是当进行训练的时候,有时总会因为一些莫名其妙的原因使得整个进程都崩掉了,这时候中间的结果就会丢失了,而Checkpoint的好处就是比如做一千步训练或者多少步训练的时候,就可以将数据保存到一个固定的Checkpoint里面,如果中间崩掉的时候就可以从Checkpoint点重新开始训练,这是Checkpoint的最主要的应用场景。当然由于TensorFlow在最早的时候就将Checkpoint提供出来,所以很多的TensorFlow用户也会使用Checkpoint来做Session,实际上其原理就是将原来训练的结果保存下来,在另外的地方加载下来之后重新再计算一遍f(),也就是在加载之后进行一次运算起到了预测的作用。
1db1d177148a094158017297c7003ceee5268054
现在大家比较常用的一种方式是利用model进行预测,也就是TensorFlow提供了一套预测框架是基于GRTC的TensorFlow Serving,并且它是使用C++完成的,它所接受的数据类型是export类型,而不是Checkpoint类型,所以它有一套特殊的编程API可以把自己的这套model导出,并且由TensorFlow Serving直接进行加载,通过不同的Java客户端、Go客户端、Python客户端甚至Android和IOS客户端来访问它实现预测,它所做的也是TensorFlow相应的运算的方程求解的过程。
a5d11dfa96a848804ae8717a6f2b78aded7747a9
最后的一件事情是当一些Checkpoint运算成功结束之后,Checkpoint保留出来之后就可以进行在线运算和预测的过程。这里还是通过前端的UI指定预测类型以及预测应该用是应该怎样去部署的,可以选择使用GPU还是CPU,选择使用Hadoop TensorFlow的预测方式还是选择使用自定义的预测方式以及通过Checkpoint的预测方式,这些都是支持的。同时也支持运维期间需要的负载均衡和弹性伸缩的能力,这样可以看到将一个正常的图片放进去,选择不同的Checkpoint以及不同的风格类型的时候,能够产生不同的运算结果。
2326b1571e1c582017874dcb29f49091e9da3d30
那么如何在阿里云的这套环境上面进行开发测试呢,首先进去前端控制台,描述应用的名字,然后从多个应用框架进行选择,是使用TensorFlow 1.0还是TensorFlow 0.12还是其他更多的框架。在这里面由于需要监控训练集,所以需要写上需要监控的日志目录是什么。当选择创建之后,就可以看到创建出来两个中心节点,一个是Jupyter的开发测试环境,输入密码之后就可以使用Jupyter执行并看到执行的结果以及训练的过程。当训练完成之后就可以通过TensorBoard看整个训练的结果是什么样子,是不是能够达到最终的目标值的Cost越来越小。在TensorBoard上可以看到训练的趋势是什么样子,其精确度是在向什么样的方向发展,还可以看到在TensorFlow里面进行运算时整个数据组织是什么样的结构。

当程序开发结束之后,开始进行训练。这时就需要指定训练输入的数据集,以及预处理的模型,这里的框架有多种选择,还可以指定预定义的框架,这里面还可以选择是不是支持GPU,然后还有指定数据需要写入到哪个数据件里面以及数据来源是什么,还需要指定总共训练的次数以及需要保存的地点是在什么位置,都是需要一些规约来定义这些事情的。

整个方案的最大特点就是速度会非常快,就是可以快速地在这套解决方案上搭建出来自己的机器学习小应用。这里面做的事情首先会从GitHub上将应用下载下来,然后这里面的规约就会自动安装自定义的Python依赖,之后就开始调用GPU资源并启动,开始构建网络,之后真正开始进行训练。当将Checkpoint指定到一个更好的位置的时候就会将云的产生数据存放到分布式存储上。当拥有这些数据之后就可以进行预测,预测的具体内容包括把之前计算过的东西保存下来,之后根据保存的数据和模型提供一个Read API,这里面并没有TensorFlow Serving这个标准框架而是自己实现了使用Python写的框架,并使用Checkpoint方式加载应用。并且如果需要使用负载均衡可以提供更多的实例的数量,并指定加载数据的模型数据卷以及阿里云的弹性的SLB负载均衡服务,就会很快地将服务提进来。当将服务提进来之后还是通过路由列表,通过阿里云提供的负载均衡访问端点进行访问。它所能提供的东西就是在这里上传一个图片,然后根据所指定的不同的风格进行转换就可以得到不同的风格图片,基本上就实现了与Prisma相似的功能。也就是说在现有的开源技术上,就可以在阿里云上构建自己的一个小应用,并且可以提供一站式运维的体验。甚至在阿里云上不仅可以转换图片的风格,现在还可以转化视频的风格。

总结
6b1b2da467cbedb9efef46be4f860d93e84f6978
最后总结一下,大家可以看到阿里云基于容器的机器学习解决方案的最大特点就是相对而言比较简单,能够根据一些开源的东西以及一些已有的服务快速地构建一套机器学习应用,并且使应用与阿里云上的NAS,OSS,SLB以及简单日志服务等都可以做到无缝集成,只需要通过将他们加在一起就可以了,这是这套方案的第一个优势就是比较简单并且快速。

第二个好处就是优化,与容器服务团队进行合作的还有一个比较有名的就是阿里云的高性能计算团队,像对于阿里妈妈这些的优化都是他们团队做的,他们会提供一些特定场景性能优化的TensorFlow和Caffe的一些镜像,针对一些特定的场景进行性能优化,而不是百分百的优化。另外一件事情就是这套方案在持续集成和持续交付这件事情上是比较有经验的。其实可以将机器学习看做两部分,第一部分可以看做实验科学,需要不断地去尝试,找出最佳的组合来做推演;第二部分其实是交付的科学,如何将模型交付到机器上,如何进行A/B Test,而这件事情又是容器服务团队非常擅长的事情,既可以帮助优化性能,又能够帮助优化流程。

第三件事情就是定制化,阿里云希望能够通过为用户提供更大的灵活性,比如增加自己定义的镜像以及operator等来满足高级用户的需求,并平衡灵活性和自动化之间的关系。
相关实践学习
巧用云服务器ECS制作节日贺卡
本场景带您体验如何在一台CentOS 7操作系统的ECS实例上,通过搭建web服务器,上传源码到web容器,制作节日贺卡网页。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
4天前
|
机器学习/深度学习 人工智能 算法
探索人工智能:机器学习的奥秘与应用
本文深入浅出地探讨了人工智能领域中的核心技术——机器学习,揭示了其背后的原理和广泛的实际应用。通过浅显易懂的语言和生动的例子,本文旨在为非专业读者打开一扇了解并利用机器学习的大门,同时激发对这一前沿技术的兴趣和思考。
18 1
|
6天前
|
机器学习/深度学习 人工智能 搜索推荐
如何让你的Uno Platform应用秒变AI大神?从零开始,轻松集成机器学习功能,让应用智能起来,用户惊呼太神奇!
【9月更文挑战第8天】随着技术的发展,人工智能与机器学习已融入日常生活,特别是在移动应用开发中。Uno Platform 是一个强大的框架,支持使用 C# 和 XAML 开发跨平台应用(涵盖 Windows、macOS、iOS、Android 和 Web)。本文探讨如何在 Uno Platform 中集成机器学习功能,通过示例代码展示从模型选择、训练到应用集成的全过程,并介绍如何利用 Onnx Runtime 等库实现在 Uno 平台上的模型运行,最终提升应用智能化水平和用户体验。
19 1
|
15天前
|
机器学习/深度学习 PHP 开发者
探索PHP中的面向对象编程构建你的首个机器学习模型:以Python和scikit-learn为例
【8月更文挑战第30天】在PHP的世界中,面向对象编程(OOP)是一块基石,它让代码更加模块化、易于管理和维护。本文将深入探讨PHP中面向对象的魔法,从类和对象的定义开始,到继承、多态性、封装等核心概念,再到实战中如何应用这些理念来构建更健壮的应用。我们将通过示例代码,一起见证PHP中OOP的魔力,并理解其背后的设计哲学。
|
17天前
|
机器学习/深度学习 缓存 运维
智能化运维:机器学习在IT管理中的革命性应用
【8月更文挑战第28天】 随着技术的飞速发展,传统的IT运维方式已不能满足现代企业的需求。智能化运维,通过整合机器学习技术,正在重塑我们对IT基础设施的管理方法。本文将探讨智能化运维的概念、实施步骤及其带来的变革,同时分享一些成功案例,以期为读者提供一种全新的视角和思考路径。
43 6
|
14天前
|
机器学习/深度学习 存储 前端开发
实战揭秘:如何借助TensorFlow.js的强大力量,轻松将高效能的机器学习模型无缝集成到Web浏览器中,从而打造智能化的前端应用并优化用户体验
【8月更文挑战第31天】将机器学习模型集成到Web应用中,可让用户在浏览器内体验智能化功能。TensorFlow.js作为在客户端浏览器中运行的库,提供了强大支持。本文通过问答形式详细介绍如何使用TensorFlow.js将机器学习模型带入Web浏览器,并通过具体示例代码展示最佳实践。首先,需在HTML文件中引入TensorFlow.js库;接着,可通过加载预训练模型如MobileNet实现图像分类;然后,编写代码处理图像识别并显示结果;此外,还介绍了如何训练自定义模型及优化模型性能的方法,包括模型量化、剪枝和压缩等。
25 1
|
15天前
|
机器学习/深度学习 数据采集 人工智能
探索机器学习在金融欺诈检测中的应用
【8月更文挑战第30天】 随着金融科技的迅猛发展,机器学习技术在保障交易安全和打击金融欺诈中扮演着越来越重要的角色。本文将深入探讨机器学习模型在识别和预防金融欺诈方面的应用,并分析其优势与面临的挑战。通过对比传统方法,我们突出了机器学习在处理大数据、提高检测速度和精度方面的独特价值。同时,文中还将介绍几种常用的算法和模型,以及它们在实际场景中的运用情况。最后,本文提出了未来发展趋势和需要解决的关键问题。
|
16天前
|
机器学习/深度学习 人工智能 Android开发
揭秘AI编程:从零开始构建你的第一个机器学习模型移动应用开发之旅:从新手到专家
【8月更文挑战第29天】本文将带你走进人工智能的奇妙世界,一起探索如何从零开始构建一个机器学习模型。我们将一步步解析整个过程,包括数据收集、预处理、模型选择、训练和测试等步骤,让你对AI编程有一个全面而深入的理解。无论你是AI初学者,还是有一定基础的开发者,都能在这篇文章中找到你需要的信息和启示。让我们一起开启这段激动人心的AI编程之旅吧! 【8月更文挑战第29天】在这篇文章中,我们将探索移动应用开发的奇妙世界。无论你是刚刚踏入这个领域的新手,还是已经有一定经验的开发者,这篇文章都将为你提供有价值的信息和指导。我们将从基础开始,逐步深入到更复杂的主题,包括移动操作系统的选择、开发工具的使用、
|
17天前
|
机器学习/深度学习 数据处理 定位技术
构建您的首个机器学习项目:从理论到实践
【8月更文挑战第28天】本文旨在为初学者提供一个简明的指南,通过介绍一个基础的机器学习项目——预测房价——来揭示机器学习的神秘面纱。我们将从数据收集开始,逐步深入到数据处理、模型选择、训练和评估等环节。通过实际操作,你将学会如何利用Python及其强大的科学计算库来实现自己的机器学习模型。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你打开一扇通往机器学习世界的大门。
|
17天前
|
机器学习/深度学习 人工智能 算法
【悬念揭秘】ML.NET:那片未被探索的机器学习宝藏,如何让普通开发者一夜变身AI高手?——从零开始,揭秘构建智能应用的神秘旅程!
【8月更文挑战第28天】ML.NET 是微软推出的一款开源机器学习框架,专为希望在本地应用中嵌入智能功能的 .NET 开发者设计。无需深厚的数据科学背景,即可实现预测分析、推荐系统和图像识别等功能。它支持多种数据源,提供丰富的预处理工具和多样化的机器学习算法,简化了数据处理和模型训练流程。
31 1
|
20天前
|
机器学习/深度学习 自动驾驶 算法
揭秘机器学习:用Python构建你的首个预测模型
【8月更文挑战第26天】 机器学习,这个听起来既神秘又遥不可及的领域,实际上正悄然改变着我们的世界。从推荐系统到自动驾驶汽车,机器学习技术无处不在。本文将带你走进机器学习的世界,通过一个简单的Python代码示例,展示如何构建一个基本的线性回归模型来预测房价。不需要复杂的数学公式或深奥的理论,我们将以最直观的方式理解机器学习的核心概念。无论你是编程新手还是数据科学爱好者,这篇文章都将为你打开一扇新的大门,让你看到数据背后的力量。