AI平台-AutoSKlearn【AutoML】

简介: Auto-sklean 是基于Auto-Weka(https://www.automl.org/automl/autoweka/)使用的 CASH(组合算法选择和超参数优化)问题的定义以及和 AzureAutomated ML 相同的思路构建的:他们考虑同时选择一个学习算法和设置其超参数的问题。

1. AutoSKlearn是什么?

传统的机器学习任务从开始到建模的一般流程是:获取数据 -> 数据预处理 -> 训练建模 -> 模型评估 -> 预测,分类。本文我们将依据传统机器学习的流程,看看在每一步流程中都有哪些常用的函数以及它们的用法是怎么样的。希望你看完这篇文章可以最为快速的开始你的学习任务。
Autosklearn是Hutter等人设计的自动调参框架,其核心是使用SMAC算法,一种采用黑箱调优的算法,对超参进行迭代优化从而进一步选出能够使得在这种参数下,模型的某种指标最好的超参。为了更进一步高效地寻找到最有的超参,autosklearn还引入了metalearning等过程加速超参搜索。除了黑箱调优算法外,autosklearn还做了特征工程和数据工程,从而实现了部分的机器学习自动化。从使用者的角度看,在给定一个数据集和期盼最小化的指标(如auc,logloss等)的情况下,autosklearn完全可以出给适当的模型和对应的输入超参,使得对应的指标在指定数据集下最小。
Auto-sklean 是基于Auto-Weka(https://www.automl.org/automl/autoweka/)使用的 CASH(组合算法选择和超参数优化)问题的定义以及和 AzureAutomated ML 相同的思路构建的:他们考虑同时选择一个学习算法和设置其超参数的问题。他们提出的主要区别是将两个额外的步骤合并到主进程中:一开始是元学习步骤,最后是自动化集成构造步骤,详情请参阅论文《Efficient and Robust Automated Machine Learning》。

image
Aotusklearn在一定程度上满足了自动机器学习的要求。单纯就模型结果上看,即便输入给autosklearn的是一组没有经过很详细特征处理的数据集,输出结构都会比当前市场上的一些自动调优框架好。下图就是我们将一些数据集作为基准,使用autosklearn和当前市场上某款自动调优工具的效果对比,这两款产品使用了相同的时间资源并且指定了同一种模型。这里我们使用auc和logloss作为我们的目标指标。标黄的部分是对比优异的项。

这里我们可以看到,autosklearn在大多数数据集和目标指标上,都比市面上这款自动调优产品要好很多。那么autosklean到底做了那些操作,使得一个开源会比商业软件取得更好的结果呢?

整体上说,autosklearn的工作流程如下:

这里我们可以看到autosklearn除了迭代调整输入模型的超参之外,还迭代调整了输入模型所需要的数据处理方法和特征处理方法和参数。最终通过集成不同机器学习模型完成整个自动学习过程。下面我们就会具体讨论每个步骤到底做了些怎么样的操作。

Metalearning:

Metalearning操作的目的是为整个迭代选取一个接近收敛点的初值,从而加快SMAC算法的收敛速度。

在autosklearn中,作者将已有的metalearning数据库存入以下所示的文件夹中,每个文件夹内都存有指标+模型特征+任务类型所对应的超参初始值。这些初始值都是作者通过优化其他类似数据集后(其中可能是手动优化的结果)总结出来的数据库。通过选择与当前训练数据接近的先前的k个优化结果作为初始值,加入到SMAC算法中进行优化,进而加速SMAC收敛的速度。

Metalearning并不能从根本上提升SMAC算法所给出的最优点的性能。但是一个较好的初始值可以大大加快SMAC找到最优点的速度。从而减少时间资源的消耗。同时,当所给时间不足时,autosklearn会直接给出metalearning的值,这个值虽然不是SMAC能给出最好的结果,但是依旧是一个效果不错的超参选择。

数据预处理和特征预处理:

根们我们已有的经验可以看出,数据预处理和特征预处理对于最后结果来说至关重要。很多kaggle竞赛的核心步骤的大部分时间都花在了分析数据,预处理数据集和特征预处理上。如果不经过相关的数据预处理,特征预处理,即便是SMAC算法也难以找到一个可以使得指标很低的超参和模型。

在数据预处理方面SMAC算法主要做了如下四种预处理:

其中balance操作只对特定的one_hot编码选项有效。

在特征预处理方面,SMAC最多做了如下记住特征预处理:

其中除了标红的kernel_pca, kitchen_sinks和nystroem_sampler以外,所有其他特征预处理只对multinomial_nb模型有效。

由此可见,实际上autosklearn并没有对数据集做什么“专业级”的预处理,比如分析数据产生新特征等等。但是autosklearn不同的是他将每种预处理方法的不同参数也带入smac中进行调优,从而充分利用了每种预处理带来的性能提升,从而得到了比市场上大多数自动调优框架更好的结果。

SMAC:

SMAC算法是一种强大的黑箱条又算法,如果单讲SMAC算法可以另起一个主题进行分析。这里考虑到这篇文章的目的是分享autosklearn做了些什么操作,而不是分解每个操作的具体步骤。因此这里只简单体描述一下SMAC算法的流程。

SMAC是SMBO算法的一种算法。SMBO算法的每个迭代步可以分为如下的步骤:1.依据历史信息构造(超参,性能)的性能函数,2.依照性能函数,选取最有可能是最小值的超参,并将这个点对应性能算出。3.将新的(超参,性能)加入历史信息中,进行重复的迭代。

将SMBO算法实例化到SMAC算法,所对应的是则是:1.性能模型是随机森林的高斯过程模型。2.通过局部搜索和全局的随即选点,算出多个最有可能达到最小值的点进行进一步筛选。3.筛选点的过程是一个bandit问题,这里SMAC算法通过intensify过程使用经可能少的资源找到最有超参。

集成模型:

集成模型步是整个Autosklearn除去训练模型外,几乎唯一的多线程部分。除此之外,autosklearn都处在单线程的运转状态。

Autosklearn的集成模型方法使用了Rich Caruana在04年icml上所提出的集成模型方法,具体操作如下:

1.选取一张50个空白项的表,其中表中的每一项权重为0.02。

2.从已有的多个模型中选取一个可以提升表性能的模型加入到表中或替换性能不佳的模型。

3.重复第二步直到达到最大的迭代步骤。

4.将表中相同模型的权重累加得到此模型在集成模型中的权重。

2. autosklearn特点:

auto-sklearnAutoML 方法

该方法使用了全部 38 个元特征来描述数据集,包括简单的、信息论的和统计的元特征,如数据点的数量、特征和分类,以及数据偏度和目标的熵。利用这些信息,他们会选择 k 个采样点作为贝叶斯优化的初始采样点(seed)。注意,这种元学习方法通过使用数据集存储库来获得强大的功能(就像 Azure Automated ML 那样)。

在完成贝叶斯优化之后,它们会构建一个由所有尝试过的模型组成的集成模型。这一步的思路是将训练每个模型所做的努力都存储下来。他们没有抛弃这些模型而选择更好的模型,而是将它们存储起来,最终构建出一个它们的集成模型。这种自动集成构造方法避免了让自己陷入单个超参数的设置中,因此鲁棒性更强(并且不容易过拟合)。他们使用集成选择(这个贪婪过程从空集成开始,迭代地添加能够最大化集成验证性能的模型)来构建集成模型。
AutoSKlearn效果好的原因:

  1. autosklearn通过metalearning在较短时间内找到了相对较好的配置,并以此为基准进行迭代容易超过很多现有工具和平台。
  2. 尽管特征工程和数据预处理方法相对简单,但是每个处理的参数都带入了SMAC整个迭代中进行参数调优,从而将每个简单的处理效果发挥到了极致。

3. 参考资料

  1. 论文《Efficient and Robust Automated Machine Learning》
目录
相关文章
|
6天前
|
机器学习/深度学习 人工智能 监控
Java与AI模型部署:构建企业级模型服务与生命周期管理平台
随着企业AI模型数量的快速增长,模型部署与生命周期管理成为确保AI应用稳定运行的关键。本文深入探讨如何使用Java生态构建一个企业级的模型服务平台,实现模型的版本控制、A/B测试、灰度发布、监控与回滚。通过集成Spring Boot、Kubernetes、MLflow和监控工具,我们将展示如何构建一个高可用、可扩展的模型服务架构,为大规模AI应用提供坚实的运维基础。
67 0
|
11天前
|
人工智能 Java 测试技术
【556AI】(一)IntelliJ IDEA全流程AI设计开发平台
556AI支持IDEA、PHPSTORM、PYCHARM最新版 AI平台定位是开发大型软件项目,大型软件项目代码AI生成引擎,OA/ERP/MES 百万行代码一次性AI生成 支持axure原型导入预览,集成AI软件设计/AI软件开发/AI软件测试整个流程 支持 若依 JEECG SmartAdmin THINKPHP Django等多种JAVA/PHP/python框架 实现了java php python 的统一增强行调试方式 可以链接多个AI大模型,进行AI生成代码
197 8
|
19天前
|
人工智能 运维 安全
从被动防御到主动免疫进化!迈格网络 “天机” AI 安全防护平台,助推全端防护性能提升
迈格网络推出“天机”新版本,以AI自学习、全端防护、主动安全三大核心能力,重构网络安全防线。融合AI引擎与DeepSeek-R1模型,实现威胁预测、零日防御、自动化响应,覆盖Web、APP、小程序全场景,助力企业从被动防御迈向主动免疫,护航数字化转型。
从被动防御到主动免疫进化!迈格网络 “天机” AI 安全防护平台,助推全端防护性能提升
|
19天前
|
存储 人工智能 达摩院
|
20天前
|
人工智能 API 开发者
Dify x AiOnly平台:手把手教你调用GPT-5从零构建AI工作流!
本文介绍如何通过Dify与AiOnly平台,快速构建基于GPT-5等顶尖大模型的AI应用。涵盖环境部署、模型接入、工作流编排及实战案例,助力开发者低门槛打造专属聊天机器人,轻松实现AI应用落地。(238字)
|
28天前
|
人工智能 数据可视化 前端开发
AI Ping:精准可靠的大模型服务性能评测平台
AI Ping是清华系团队推出的“大模型服务评测平台”,被誉为“AI界的大众点评”。汇聚230+模型服务,7×24小时监测性能数据,以吞吐量、延迟等硬指标助力开发者科学选型。界面简洁,数据可视化强,支持多模型对比,横向对标国内外主流平台,为AI应用落地提供权威参考。
240 3
人工智能 安全 Ubuntu
232 0
|
1月前
|
人工智能 数据可视化 测试技术
AI测试平台自动遍历:低代码也能玩转全链路测试
AI测试平台的自动遍历功能,通过低代码配置实现Web和App的自动化测试。用户只需提供入口链接或安装包及简单配置,即可自动完成页面结构识别、操作验证,并生成可视化报告,大幅提升测试效率,特别适用于高频迭代项目。
|
1月前
|
人工智能 自然语言处理 测试技术
AI测试平台的用例管理实践:写得清晰,管得高效,执行更智能
在测试过程中,用例分散、步骤模糊、回归测试效率低等问题常困扰团队。霍格沃兹测试开发学社推出的AI测试平台,打通“用例编写—集中管理—智能执行”全流程,提升测试效率与覆盖率。平台支持标准化用例编写、统一管理操作及智能执行,助力测试团队高效协作,释放更多精力优化测试策略。目前平台已开放内测,欢迎试用体验!

热门文章

最新文章