ML.NET是Microsoft最近发布的用于机器学习的开源,跨平台,代码优先的框架。尽管对我们来说是一个新的框架,但该框架的根源是Microsoft Research,并且在过去十年中已被许多内部团队使用,包括那些您几乎肯定听说过的产品的开发人员-Microsoft Windows,Office和Bing,仅举几例。

ML.NET使.NET开发人员可以轻松地将机器学习集成到其应用程序中,无论是控制台,桌面还是Web。它涵盖了机器学习活动的整个生命周期,从模型的训练和评估到使用和部署。支持许多典型的有监督和无监督机器学习任务,包括分类,回归,推荐和聚类。该框架还与TensorFlow集成,使.NET开发人员能够从熟悉的环境调用深度学习模型(适用于诸如对象检测或语音分析之类的任务)。

为什么选择ML.NET?

如今,在为我们的应用程序添加机器学习或AI功能的选项方面,我们总是无所适从。借助NuGet包和仅几行代码,我们就可以利用Azure认知服务的强大功能以高度的准确性和性能执行情感分析,对象检测和OCR等复杂任务。微软确实做了令人难以置信的工作,使各种经验的开发人员都可以使用这些工具。

ML.NET如何适合?您可以使用ML.NET来执行许多与Azure一样的机器学习任务。但是,作为一个高度可配置的基于代码的框架,它肯定会花费多行代码。在差异化方面,您可能会考虑ML.NET的一些关键原因是:

  • 训练特定领域的模型:
    许多认知服务模型都在广泛的数据集上进行了训练,以便为各种用例提供​​良好的体验。这非常适合接送和使用以及许多实际需求。但是,如果您正在处理特殊问题,那么通用模型可能不太适合。例如,认知服务将毫不费力地告诉您图像是否包含帽子或动物。如果您想检测和区分不同种类的帽子(例如,您自己的帽子收藏)并且不关心识别动物或其他物体,则可以从训练自己的领域特定模型中受益,ML.NET允许你轻松做。

  • 将数据保存在网络中或用户的机器上:
    许多Cognitive Services确实允许您通过提供自定义示例来训练自定义模型或扩展内置模型。在某些情况下,还可以导出和下载模型,以实现离线使用。但是,出于法规或隐私的原因,您可能不希望或被允许上传训练数据或将预测输入发送到云提供商。ML.NET可以以离线方式端到端地用于训练和预测。如果您需要训练和/或预测数据来保持内部,则ML.NET是一个不错的选择。

  • 动态生成ML模型:
    作为代码优先的框架,ML.NET使得基于编译时未知的信息来动态生成机器学习模型非常容易。如果您的应用程序支持动态内容(例如,用户定义的模式),并且您希望集成ML功能,则可以选择ML.NET。

  • 修改或扩展框架:
    作为一个开放源代码项目,ML.NET的完整源代码可在GitHub上获得,从而使您可以根据需要快速研究实现细节,修复错误甚至添加功能。

  • 避免基于消耗的定价:
    ML.NET可以免费使用,无论您执行多少操作。当然,运行自己的系统也要付费!

与Azure认知服务相比,访问这些差异化功能的最大障碍可能是ML.NET对机器学习知识的更高要求。使用ML.NET要求您更多地考虑诸如数据预处理,数据管道,算法选择,模型验证和性能指标之类的事情。虽然理解这些概念将为您提供扎实的机器学习基础,但立即解决所有这些问题可能会有些令人生畏。幸运的是,ML.NET团队已经完成了一些工作,可以帮助新手入门。

缩小差距— AutoML和Model Builder

如果您想使用ML.NET,但是构建管道,选择训练师和评估模型的想法让您三思而后行,那么您可以选择AutoML形式的选择,它是ML.NET的配套库。AutoML通过自动化生命周期的各个部分并尝试为您的数据生成最佳的机器学习模型,降低了新机器学习开发人员的进入门槛。具体来说,它会自动:

  • 从SQL或基于文本的源中加载训练数据

  • 执行输入数据的基本预处理,包括检测分类字段和删除对预测无用的字段

  • 探索潜在的算法和参数,迭代训练模型并根据输入数据评估每种算法和有效性

  • (通过CLI或Model Builder使用时)生成代码以加载经过训练的最佳模型,准备提供新的预测

可以从代码(Install-Package Microsoft.ML.AutoML),命令行界面(dotnet tool install -g mlnet)或通过GUI工具(以Visual Studio扩展,Model Builder的形式)调用AutoML 。

在本文的其余部分,我们将通过一个示例使用Model Builder自动训练机器学习模型并生成使用该模型的代码。

演练—使用Model Builder自动训练出租车票价预测模型

在本演练中,我们将基于时间,距离,乘客人数和付款方式等输入信息,构建一个预测纽约出租车票价的模型。我们将使用ML.NET示例存储库中的数据作为输入。

先决条件:

如果您没有Visual Studio 2017或2019,请在尝试安装Model Builder扩展之前安装其中之一。

步骤1:在Visual Studio中创建一个新项目

ML.NET可在.NET Core所运行的任何x86或x64环境中运行,因此我们可以从许多内置模板开始。在这种情况下,我们将创建一个新的.NET Core控制台应用程序。

创建项目后,请等到屏幕上看到熟悉的空控制台应用程序项目。

步骤2:将“机器学习”添加到您的项目中

安装扩展后,我们可以通过在解决方案资源管理器中右键单击我们的项目,然后选择添加->机器学习来调用模型生成器。完成此操作后,您会看到ML.NET Model Builder首屏引导界面。

步骤3:为您的数据集配置Model Builder

选择方案

我们与Model Builder的交互首先是从一些预定义的场景中进行选择。本质上,这些是针对特定机器学习任务量身定制的模板。在我们的案例中,我们希望预测出租车价格,因此“价格预测”是一个不错的选择。

加载训练数据

下一个任务是指定我们要用于训练的数据。价格预测是监督学习任务的一个示例,其中训练了机器学习模型,通过显示历史数据的示例来进行预测。示例包括模型输入(在我们的示例中为时间,距离和乘客数量)以及输出值(行程的实际票价)。稍后,当我们要预测票价时,我们的模型将采用新行程的详细信息,并将其与从训练数据中得出的关系一起使用,以预测票价。

为了评估机器学习模型的质量,我们通常从训练中排除部分历史数据。这样可以确保我们拥有一些已知的良好输入/输出组合(我们的模型尚未看到),可以将它们与模型的输出进行比较。为此,AutoML会自动撤消部分数据,因此我们可以为其提供完整的数据集。如果完成了可选的先决条件,则应在“选择文件”对话框中选择级联的数据集。否则,您可以粘贴训练数据的URL。使用级联数据集的好处是您将为AutoML提供更大的训练数据。

加载文件后,Model Builder将自动检测列并提供数据预览。我们需要告诉Model Builder我们要预测哪个领域;在我们的例子中是“ fare_amount”字段。

步骤4:使用模型生成器生成最佳模型

训练优化模型

Model Builder使用AutoML迭代探索选项并确定给定数据集的最佳预测算法和参数。迭代时间的上限取决于我们,主要应受训练数据集的大小影响。

ML.NET团队对各种数据集大小的迭代持续时间有一些指导。对于我们的数据集(介于2.5mb和5mb之间,取决于您是否将测试数据和训练数据连接在一起),仅十秒钟就足够了。单击“训练”后,Model Builder将开始迭代模型并显示有关其进度的一些详细信息。Model Builder评估它训练的每个模型,并将模型的RSquared得分用作比较它们的机制。

审查模型效果

执行优化后,Model Builder将概述该过程,包括它能够在迭代时间内生成的最佳五种配置的评估指标。

尽管“Model Builder”会自动选择效果最佳的模型,但是值得花一点时间查看最终指标。如果所选模型的指标不佳,则不太可能在新输入上表现良好。在这种情况下,您可能需要迭代模型训练过程。选项可能包括:

  • 增加AutoML的探索时间(允许它查找更好的算法或参数)
  • 训练数据的数量增加(提供更多示例,更好地代表您的域的可变性)
  • 预处理训练数据(公开可以提高可预测性的新功能,或删除可能无法提高的功能)

在上面的例子中,使用LightGbmRegression训练器生成了最佳模型,其RSquared得分为0.94,这应该表现良好。

步骤5:使用模型

评估后,Model Builder将自动将两个新项目添加到您的解决方案中。第一个是包含模型和输入类的库,现有项目可以引用该库。第二个是带有代码的示例控制台应用程序,该代码演示了如何加载和使用模型。

生成了这两个项目后,我们就可以看到实际的模型了。该示例应用程序使用来自训练数据集的硬编码单个输入来演示模型的用法。为了使其更具交互性,您可以使用以下内容替换Program.cs的内容,从而使您可以交互地输入行程详细信息并获得预计的票价:

  1. using System;
  2. using System.IO;
  3. using System.Linq;
  4. using Microsoft.ML;
  5. using PredictTaxiFareML.Model.DataModels;
  6. using static System.Console;
  7. using static System.Environment;
  8.  
  9. namespace PredictTaxiFareML.ConsoleApp
  10. {
  11. class Program
  12. {
  13. private const string Quit = "quit";
  14. private const string ModelPath = @"MLModel.zip";
  15.  
  16. static void Main(string[] args)
  17. {
  18. var context = new MLContext().Model;
  19. var model = context.Load(GetPath(ModelPath), out _);
  20. var engine = context.CreatePredictionEngine<ModelInput, ModelOutput>(model);
  21.  
  22. WriteLine("== AutoML Interactive Taxi Fare Predictor == ");
  23. while (GetInput(out var input))
  24. WriteLine($"{NewLine}Predicted fare: " +
  25. $"{engine.Predict(input).Score:C}{NewLine}");
  26. }
  27.  
  28. private static bool GetInput(out ModelInput input)
  29. {
  30. WriteLine($"{NewLine}Enter trip details:{NewLine}");
  31.  
  32. input = new ModelInput
  33. {
  34. Passenger_count = ReadF("Passenger count", ),
  35. Trip_time_in_secs = ReadF("Trip time (mins)", ) * ,
  36. Trip_distance = ReadF("Distance (mi)", ),
  37. Vendor_id = ReadCat("Vendor", "VTS", "CMD"),
  38. Rate_code = ReadF("Rate code (0 - 6)", , ),
  39. Payment_type = ReadCat("Payment type", "CRD", "CSH"),
  40. };
  41.  
  42. return true;
  43. }
  44.  
  45. private static float ReadF(string title,
  46. float min = float.MinValue, float max = float.MaxValue)
  47. {
  48. while (true)
  49. {
  50. try { return Clamp(float.Parse(Prompt(title)), min, max); }
  51. catch (Exception ex) { WriteLine(ex.Message); }
  52. }
  53. }
  54.  
  55. private static string ReadCat(string title, params string[] values)
  56. {
  57. title = $"{title} [{String.Join(", ", values)}]";
  58.  
  59. var ret = "";
  60. while (!values.Contains(ret))
  61. ret = Prompt(title);
  62.  
  63. return ret;
  64. }
  65.  
  66. private static string Prompt(string title)
  67. {
  68. Write($" - {title}: ");
  69. return ReadLine().Trim().ToUpper();
  70. }
  71.  
  72. private static float Clamp(float input, float min, float max)
  73. {
  74. var ret = Math.Max(Math.Min(input, max), min);
  75.  
  76. if (Math.Abs(ret - input) > 0.1)
  77. WriteLine($"Clamping to {ret}");
  78.  
  79. return ret;
  80. }
  81.  
  82. private static string GetPath(string relativePath)
  83. {
  84. var root = new FileInfo(typeof(Program).Assembly.Location);
  85. var asmPath = root.Directory.FullName;
  86.  
  87. return Path.Combine(asmPath, relativePath);
  88. }
  89. }
  90. }

运行中的代码如下所示:

就是这样!我们已经成功地使用了Model Builder来自动生成优化的模型,以便根据出租车费用数据集进行预测。AutoML自动为我们处理了一些棘手的步骤,使我们无需成为机器学习专家就可以从ML.NET的某些独特功能中受益。希望这个例子有助于为您提供使用ML.NET的启发,您自己可以尝试在某些数据上创建自定义模型。

使用ML.NET进行自定义机器学习的更多相关文章

  1. ML.NET---.NET下的机器学习引擎(简介)

    ML.NET 是一个跨平台的开源机器学习框架,它可以使 .NET 开发人员更容易的开展机器学习工作. ML.NET 允许 .NET 开发人员开发自己的模型,即使没有机器学习的开发经验,也可以很容易的将 ...

  2. ML:吴恩达 机器学习 课程笔记(Week1~2)

    吴恩达(Andrew Ng)机器学习课程:课程主页 由于博客编辑器有些不顺手,所有的课程笔记将全部以手写照片形式上传.有机会将在之后上传课程中各个ML算法实现的Octave版本. Linear Reg ...

  3. ML(1)——机器学习简述

    简述 机器学习是人工智能的一种实现方式:深度学习是一种实现机器学习的技术,或者说是一种特殊的机器学习方法,可以说广义上的机器学习也包括了深度学习,三者的关系如下图所示: 从判别垃圾邮件到无人驾驶技术, ...

  4. 【ML入门】李宏毅机器学习笔记01-Learning Map

    版权声明:小博主水平有限,希望大家多多指导.本文仅代表作者本人观点,转载请联系知乎原作者——BG大龍. 目录 1 什么是机器学习? 2 机器学习的3个步骤 3 李宏毅老师的机器学习课程 4 按“模型的 ...

  5. ML:吴恩达 机器学习 课程笔记(Week7~8)

    Support Vector Machines Unsupervised Learning Dimensionality Reduction

  6. ML:吴恩达 机器学习 课程笔记(Week5~6)

    Neural Networks: Learning Advice for Applying Machine Learning Machine Learning System Design

  7. ML:吴恩达 机器学习 课程笔记(Week9~10)

    Anomaly Detection Recommender Systems Large Scale Machine Learning

  8. ML:吴恩达 机器学习 课程笔记(Week3~4)

    Logistic Regression Regularization Neural Networks: Representation

  9. Core ML 机器学习

    在WWDC 2017开发者大会上,苹果宣布了一系列新的面向开发者的机器学习 API,包括面部识别的视觉 API.自然语言处理 API,这些 API 集成了苹果所谓的 Core ML 框架.Core M ...

随机推荐

  1. IDEA 运行后乱码问题解决

    页面乱码: 在edit configurations->vm options 添加 -Dfile.encoding=UTF-8 调整idea文件编码格式,全部为 UTF-8 (file -> ...

  2. git upstream

    git remote add upstream https://github.com/SchedMD/slurm git fetch upstream git rebase upstream/mast ...

  3. 来个ADG switch over

    怕以后忘了,做个试验记录一下,这个switch比较常规1]主--备库先查一遍,如下的话就可以开始了两者当前序列一致角色状态如下--主库SQL> archive log list;数据库日志模式 ...

  4. 201871010108-高文利《面向对象程序设计(java)》第十四周学习总结

    项目 内容 这个作业属于哪个课程 <任课教师博客主页链接> https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 <作业链接地址> ht ...

  5. java之API初识

    API概念 API(Application Programming Interface),应用程序编程接口.JavaAPI是一本程序员的字典 ,是JDK中提供给 我们使用的类的说明文档.这些类将底层的 ...

  6. 【转】关于web项目中的图片上传、并在前端显示问题(tomcat中配置文件上传虚拟路径)

    一.数据库存储 直接把图片的二进制码存到数据库,可参考blog:http://blog.csdn.net/hope2jiang/article/details/590733 直接存图片在mysql上面 ...

  7. 瓜子IM智能客服系统的数据架构设计(整理自现场演讲)

    本文由ITPub根据封宇在[第十届中国系统架构师大会(SACC2018)]现场演讲内容整理而成. 1.引言 瓜子业务重线下,用户网上看车.预约到店.成交等许多环节都发生在线下.瓜子IM智能客服系统的目 ...

  8. SLB外部端口非80时---》转发到nginx---》URL跳转丢失端口的解决方案

    配置nginx反向代理时遇到一个问题,当设置nginx监听80端口时转发请求没有问题.但一旦设置为监听其他端口,就一直跳转不正常: 如,访问欢迎页面时应该是重定向到登录页面,在这个重定向的过程中端口丢 ...

  9. mysqlslap详解--MySQL自带的性能压力测试工具(转)

    本文的参考博客地址为:https://blog.csdn.net/fuzhongfaya/article/details/80943991 和 https://www.cnblogs.com/davy ...

  10. Spring Cloud Gateway入坑记

    Spring Cloud Gateway入坑记 前提 最近在做老系统的重构,重构完成后新系统中需要引入一个网关服务,作为新系统和老系统接口的适配和代理.之前,很多网关应用使用的是Spring-Clou ...