# 更改日志 ## 发布 1.3 - 12/30/2019 ### 主要功能 #### 支持神经网络架构搜索算法 * [单路径一次性](https://github.com/microsoft/nni/tree/v1.3/examples/nas/spos/)算法和示例 #### 模型压缩算法支持 * [知识蒸馏](https://github.com/microsoft/nni/blob/v1.3/docs/zh_CN/TrialExample/KDExample.md)算法和使用示例 * Pruners * [L2Filter Pruner](https://github.com/microsoft/nni/blob/master/docs/zh_CN/Compressor/Pruner.md#l2filter-pruner) * [ActivationAPoZRankFilterPruner](https://github.com/microsoft/nni/blob/master/docs/zh_CN/Compressor/Pruner.md#activationapozrankfilterpruner) * [ActivationMeanRankFilterPruner](https://github.com/microsoft/nni/blob/master/docs/zh_CN/Compressor/Pruner.md#activationmeanrankfilterpruner) * [BNN Quantizer](https://github.com/microsoft/nni/blob/v1.3/docs/zh_CN/Compressor/Quantizer.md#bnn-quantizer) #### 训练平台 * OpenPAI 的 NFS 支持 从 OpenPAI v0.11开始,HDFS 不再用作默认存储,可将 NFS、AzureBlob 或其他存储用作默认存储。 在本次版本中,NNI 扩展了对 OpenPAI 最近改动的支持,可与 OpenPAI v0.11 及后续版本的默认存储集成。 * Kubeflow 更新适配 适配 Kubeflow 0.7 对 tf-operator 的新支持。 ### 工程(代码和生成自动化) * 启用 [ESLint](https://eslint.org/) 静态代码分析。 ### 小改动和 Bug 修复 * 正确识别内置 Tuner 和定制 Tuner * Dispatcher 基类的日志 * 修复有时 Tuner、Assessor 的失败会终止 Experiment 的 Bug。 * 修复本机作为远程计算机的[问题](https://github.com/microsoft/nni/issues/1852) * SMAC Tuner 中 Trial 配置的去重 [ticket](https://github.com/microsoft/nni/issues/1364) ## 发布 1.2 - 12/02/2019 ### 主要功能 * [特征工程](https://github.com/microsoft/nni/blob/v1.2/docs/zh_CN/FeatureEngineering/Overview.md) - 新增特征工程接口 - 特征选择算法: [Gradient feature selector](https://github.com/microsoft/nni/blob/v1.2/docs/zh_CN/FeatureEngineering/GradientFeatureSelector.md) & [GBDT selector](https://github.com/microsoft/nni/blob/v1.2/docs/zh_CN/FeatureEngineering/GBDTSelector.md) - [特征工程示例](https://github.com/microsoft/nni/tree/v1.2/examples/feature_engineering) - 神经网络结构搜索在 NNI 上的应用 - [新的 NAS 接口](https://github.com/microsoft/nni/blob/v1.2/docs/zh_CN/NAS/NasInterface.md) - NAS 算法: [ENAS](https://github.com/microsoft/nni/blob/v1.2/docs/zh_CN/NAS/Overview.md#enas), [DARTS](https://github.com/microsoft/nni/blob/v1.2/docs/zh_CN/NAS/Overview.md#darts), [P-DARTS](https://github.com/microsoft/nni/blob/v1.2/docs/zh_CN/NAS/Overview.md#p-darts) (PyTorch) - 经典模式下的 NAS(每次 Trial 独立运行) - 模型压缩 - [新增模型剪枝算法](https://github.com/microsoft/nni/blob/v1.2/docs/zh_CN/Compressor/Overview.md): lottery ticket 修剪, L1Filter Pruner, Slim Pruner, FPGM Pruner - [新增模型量化算法](https://github.com/microsoft/nni/blob/v1.2/docs/zh_CN/Compressor/Overview.md): QAT Quantizer, DoReFa Quantizer - 支持导出压缩后模型的 API。 - 训练平台 - 支持 OpenPAI 令牌身份验证 - 示例: - [使用 NNI 自动调优 rocksdb 配置的示例](https://github.com/microsoft/nni/tree/v1.2/examples/trials/systems/rocksdb-fillrandom)。 - [新的支持 TensorFlow 2.0 的 Trial 示例](https://github.com/microsoft/nni/tree/v1.2/examples/trials/mnist-tfv2)。 - 改进 - 远程训练平台中不需要 GPU 的 Trial 任务改为使用随机调度,不再使用轮询调度。 - 添加 pylint 规则来检查拉取请求,新的拉取请求需要符合 [pylint 规则](https://github.com/microsoft/nni/blob/v1.2/pylintrc)。 - Web 门户和用户体验 - 支持用户添加自定义 Trial。 - 除了超参外,用户可放大缩小详细图形。 - 文档 - 改进了 NNI API 文档,增加了更多的 docstring。 ### Bug 修复 - 修复当失败的 Trial 没有指标时,表格的排序问题。 -Issue #1773 - 页面切换时,保留选择的(最大、最小)状态。 -PR#1710 - 使超参数图的默认指标 yAxis 更加精确。 -PR#1736 - 修复 GPU 脚本权限问题。 -Issue #1665 ## 发布 1.1 - 10/23/2019 ### 主要功能 * 新 Tuner: [PPO Tuner](https://github.com/microsoft/nni/blob/v1.1/docs/zh_CN/Tuner/PPOTuner.md) * [查看已停止的 Experiment](https://github.com/microsoft/nni/blob/master/docs/zh_CN/Tutorial/Nnictl.md#view) * Tuner 可使用专门的 GPU 资源(参考[教程](https://github.com/microsoft/nni/blob/v1.1/docs/zh_CN/Tutorial/ExperimentConfig.md)中的 `gpuIndices` 了解详情) * 改进 WEB 界面 - Trial 详情页面可列出每个 Trial 的超参,以及开始结束时间(需要通过 "add column" 添加) - 优化大型 Experiment 的显示性能 - 更多示例 - [EfficientNet PyTorch 示例](https://github.com/ultmaster/EfficientNet-PyTorch) - [Cifar10 NAS 示例](https://github.com/microsoft/nni/blob/v1.1/examples/trials/nas_cifar10/README.md) - [模型压缩工具包 - Alpha 发布](https://github.com/microsoft/nni/blob/v1.1/docs/zh_CN/Compressor/Overview.md):我们很高兴的宣布 NNI 的模型压缩工具包发布了。它还处于试验阶段,会根据使用反馈来改进。 诚挚邀请您使用、反馈,或更多贡献 ### 修复的 Bug * 当搜索空间结束后,多阶段任务会死锁 (issue #1204) * 没有日志时,`nnictl` 会失败 (issue #1548) ## 发布1.0 - 9/2/2019 ### 主要功能 * Tuners 和 Assessors - 支持自动特征生成和选择 -Issue#877 -PR #1387 + 提供自动特征接口 + 基于 Beam 搜索的 Tuner + [增加 Pakdd 示例](https://github.com/microsoft/nni/tree/master/examples/trials/auto-feature-engineering) + 添加并行算法提高 TPE 在高并发下的性能。 -PR #1052 + 为 hyperband 支持多阶段 -PR #1257 + 训练平台 - 支持私有 Docker Registry -PR #755 * 改进 * 增加 RestFUL API 的 Python 包装,支持通过代码获取指标的值 PR #1318 * 新的 Python API : get_experiment_id(), get_trial_id() -PR #1353 -Issue #1331 & -Issue#1368 * 优化 NAS 搜索空间 -PR #1393 + 使用 _type 统一 NAS 搜索空间 -- "mutable_type"e + 更新随机搜索 Tuner + 将 gpuNum 设为可选 -Issue #1365 + 删除 OpenPAI 模式下的 outputDir 和 dataDir 配置 -Issue #1342 + 在 Kubeflow 模式下创建 Trial 时,codeDir 不再被拷贝到 logDir -Issue #1224 + Web 门户和用户体验 - 在 Web 界面的搜索过程中显示最好指标的曲线 -Issue #1218 - 在多阶段 Experiment 中,显示参数列表的当前值 -Issue1210 -PR #1348 - 在 AddColumn 中增加 "Intermediate count" 选项。 -Issue #1210 - 在 Web 界面中支持搜索参数的值 -Issue #1208 - 在默认指标图中,启用指标轴的自动缩放 -Issue #1360 - 在命令行中为 nnictl 命令增加详细文档的连接 -Issue #1260 - 用户体验改进:显示 Error 日志 -Issue #1173 - 文档 - 更新文档结构 -Issue #1231 - [多阶段文档的改进](AdvancedFeature/MultiPhase.md) -Issue #1233 -PR #1242 + 添加配置示例 + [Web 界面描述改进](Tutorial/WebUI.md) -PR #1419 ### Bug 修复 * (Bug 修复)修复 0.9 版本中的链接 -Issue #1236 * (Bug 修复)自动完成脚本 * (Bug 修复) 修复管道中仅检查脚本中最后一个命令退出代码的问题。 -PR #1417 * (Bug 修复) Tuner 的 quniform -Issue #1377 * (Bug fix) 'quniform' 在 GridSearch 和其它 Tuner 之间的含义不同。 -Issue #1335 * (Bug 修复)"nnictl experiment list" 将 "RUNNING" 状态的 Experiment 显示为了 "INITIALIZED" -PR #1388 * (Bug 修复) 在 NNI dev 安装模式下无法安装 SMAC。 -Issue #1376 * (Bug 修复) 无法点击中间结果的过滤按钮 -Issue #1263 * (Bug 修复) API "/api/v1/nni/trial-jobs/xxx" 在多阶段 Experiment 无法显示 Trial 的所有参数 -Issue #1258 * (Bug 修复) 成功的 Trial 没有最终结果,但 Web 界面显示成了 ×××(FINAL) -Issue #1207 * (Bug 修复) nnictl stop -Issue #1298 * (Bug 修复) 修复安全警告 * (Bug 修复) 超参页面损坏 -Issue #1332 * (Bug 修复) 运行 flake8 测试来查找 Python 语法错误和未定义的名称 -PR #1217 ## 发布 0.9 - 7/1/2019 ### 主要功能 * 生成 NAS 编程接口 * 为 NAS 接口添加 `enas-mode` 和 `oneshot-mode`:[PR #1201](https://github.com/microsoft/nni/pull/1201#issue-291094510) * [有 Matern 核的高斯 Tuner](Tuner/GPTuner.md) * 支持多阶段 Experiment * 为多阶段 Experiment 增加新的训练平台:pai 模式从 v0.9 开始支持多阶段 Experiment。 * 为以下内置 Tuner 增加多阶段的功能: * TPE, Random Search, Anneal, Naïve Evolution, SMAC, Network Morphism, Metis Tuner。 有关详细信息,参考[实现多阶段的 Tuner](AdvancedFeature/MultiPhase.md)。 * Web 界面 * 在 Web 界面中可比较 Trial。 有关详细信息,参考[查看 Trial 状态](Tutorial/WebUI.md) * 允许用户调节 Web 界面的刷新间隔。 有关详细信息,参考[查看概要页面](Tutorial/WebUI.md) * 更友好的显示中间结果。 有关详细信息,参考[查看 Trial 状态](Tutorial/WebUI.md) * [命令行接口](Tutorial/Nnictl.md) * `nnictl experiment delete`:删除一个或多个 Experiment,包括其日志,结果,环境信息核缓存。 用于删除无用的 Experiment 结果,或节省磁盘空间。 * `nnictl platform clean`:用于清理目标平台的磁盘空间。 所提供的 YAML 文件包括了目标平台的信息,与 NNI 配置文件的格式相同。 ### Bug 修复和其它更新 * 改进 Tuner 安装过程:增加 [sklearn](https://scikit-learn.org/stable/) 依赖。 * (Bug 修复) 连接 OpenPAI 失败的 HTTP 代码 - [Issue #1076](https://github.com/microsoft/nni/issues/1076) * (Bug 修复) 为 OpenPAI 平台验证文件名 - [Issue #1164](https://github.com/microsoft/nni/issues/1164) * (Bug 修复) 更新 Metis Tunerz 中的 GMM * (Bug 修复) Web 界面负数的刷新间隔时间 - [Issue #1182](https://github.com/microsoft/nni/issues/1182), [Issue #1185](https://github.com/microsoft/nni/issues/1185) * (Bug 修复) 当只有一个超参时,Web 界面的超参无法正确显示 - [Issue #1192](https://github.com/microsoft/nni/issues/1192) ## 发布 0.8 - 6/4/2019 ### 主要功能 * 在 Windows 上支持 NNI 的 OpenPAI 和远程模式 * NNI 可在 Windows 上使用 OpenPAI 模式 * NNI 可在 Windows 上使用 OpenPAI 模式 * GPU 的高级功能 * 在本机或远程模式上,可在同一个 GPU 上运行多个 Trial。 * 在已经运行非 NNI 任务的 GPU 上也能运行 Trial * 支持 Kubeflow v1beta2 操作符 * 支持 Kubeflow TFJob/PyTorchJob v1beta2 * [通用 NAS 编程接口](https://github.com/microsoft/nni/blob/v0.8/docs/zh_CN/GeneralNasInterfaces.md) * 实现了 NAS 的编程接口,可通过 NNI Annotation 很容易的表达神经网络架构搜索空间 * 提供新命令 `nnictl trial codegen` 来调试 NAS 代码生成部分 * 提供 NAS 编程接口教程,NAS 在 MNIST 上的示例,用于 NAS 的可定制的随机 Tuner * 支持在恢复 Experiment 时,同时恢复 Tuner 和 Advisor 的状态 * 在恢复 Experiment 时,Tuner 和 Advisor 会导入已完成的 Trial 的数据。 * Web 界面 * 改进拷贝 Trial 参数的设计 * 在 hyper-parameter 图中支持 'randint' 类型 * 使用 ComponentUpdate 来避免不必要的刷新 ### Bug 修复和其它更新 * 修复 `nnictl update` 不一致的命令行风格 * SMAC Tuner 支持导入数据 * 支持 Experiment 状态从 ERROR 回到 RUNNING * 修复表格的 Bug * 优化嵌套搜索空间 * 优化 'randint' 类型,并支持下限 * [比较不同超参搜索调优算法](CommunitySharings/HpoComparision.md) * [NAS 算法的对比](CommunitySharings/NasComparision.md) * [Recommenders 上的实践](CommunitySharings/RecommendersSvd.md) ## 发布 0.7 - 4/29/2018 ### 主要功能 * [支持在 Windows 上使用 NNI](Tutorial/InstallationWin.md) * NNI 可在 Windows 上使用本机模式 * [支持新的 Advisor: BOHB](Tuner/BohbAdvisor.md) * 支持新的 BOHB Advisor,这是一个健壮而有效的超参调优算法,囊括了贝叶斯优化和 Hyperband 的优点 * [支持通过 nnictl 来导入导出 Experiment 数据](Tutorial/Nnictl.md#experiment) * 在 Experiment 执行完后,可生成分析结果报告 * 支持将先前的调优数据导入到 Tuner 和 Advisor 中 * [可为 NNI Trial 任务指定 GPU](Tutorial/ExperimentConfig.md#localConfig) * 通过 gpuIndices 配置来为 Trial 任务指定GPU。如果 Experiment 配置文件中有 gpuIndices,则只有指定的 GPU 会被用于 NNI 的 Trial 任务。 * 改进 Web 界面 * 在 Web 界面上使用十进制格式的指标 * 添加多阶段训练相关的提示 * 可将超参复制为 Python dict 格式 * 可将提前终止的 Trial 数据传入 Tuner。 * 为 nnictl 提供更友好的错误消息 * 为 YAML 文件格式错误提供更有意义的错误信息 ### Bug 修复 * 运行 nnictl stop 的异步 Dispatcher 模式时,无法杀掉所有的 Python 线程 * nnictl --version 不能在 make dev-install 下使用 * OpenPAI 平台下所有的 Trial 任务状态都是 'WAITING' ## 发布 0.6 - 4/2/2019 ### 主要功能 * [版本检查](TrainingService/PaiMode.md) * 检查 nniManager 和 trialKeeper 的版本是否一致 * [提前终止的任务也可返回最终指标](https://github.com/microsoft/nni/issues/776) * 如果 includeIntermediateResults 为 true,最后一个 Assessor 的中间结果会被发送给 Tuner 作为最终结果。 includeIntermediateResults 的默认值为 false。 * [分离 Tuner/Assessor](https://github.com/microsoft/nni/issues/841) * 增加两个管道来分离 Tuner 和 Assessor 的消息 * 使日志集合功能可配置 * 为所有 Trial 增加中间结果的视图 ### Bug 修复 * [为 OpenPAI 增加 shmMB 配置](https://github.com/microsoft/nni/issues/842) * 修复在指标为 dict 时,无法显示任何结果的 Bug。 * 修复 hyperband 中浮点类型的计算问题 * 修复 SMAC Tuner 中搜索空间转换的错误 * 修复 Web 界面中解析 Experiment 的错误格式 * 修复 Metis Tuner 冷启动时的错误 ## 发布 0.5.2 - 3/4/2019 ### 改进 * 提升 Curve fitting Assessor 的性能。 ### 文档 * 发布中文文档网站:https://nni.readthedocs.io/zh/latest/ * 调试和维护:https://nni.readthedocs.io/zh/latest/Tutorial/HowToDebug.html * Tuner、Assessor 参考:https://nni.readthedocs.io/zh/latest/sdk_reference.html#tuner ### Bug 修复和其它更新 * 修复了在某些极端条件下,不能正确存储任务的取消状态。 * 修复在使用 SMAC Tuner 时,解析搜索空间的错误。 * 修复 CIFAR-10 示例中的 broken pipe 问题。 * 为本地训练和 NNI 管理器添加单元测试。 * 为远程服务器、OpenPAI 和 Kubeflow 训练平台在 Azure 中增加集成测试。 * 在 OpenPAI 客户端中支持 Pylon 路径。 ## 发布 0.5.1 - 1/31/2018 ### 改进 * 可配置[日志目录](https://github.com/microsoft/nni/blob/v0.5.1/docs/ExperimentConfig_zh_CN.md)。 * 支持[不同级别的日志](https://github.com/microsoft/nni/blob/v0.5.1/docs/ExperimentConfig_zh_CN.md),使其更易于调试。 ### 文档 * 重新组织文档,新的主页位置:https://nni.readthedocs.io/zh/latest/ ### Bug 修复和其它更新 * 修复了 Python 虚拟环境中安装的 Bug,并重构了安装逻辑。 * 修复了在最新的 OpenPAI 下存取 HDFS 失败的问题。 * 修复了有时刷新 stdout 会造成 Experiment 崩溃的问题。 ## 发布 0.5.0 - 01/14/2019 ### 主要功能 #### 支持新的 Tuner 和 Assessor * 支持新的 [Metis Tuner](Tuner/MetisTuner.md)。 对于**在线**超参调优的场景,Metis 算法已经被证明非常有效。 * 支持 [ENAS customized tuner](https://github.com/countif/enas_nni)。由 GitHub 社区用户所贡献。它是神经网络的搜索算法,能够通过强化学习来学习神经网络架构,比 NAS 的性能更好。 * 支持 [Curve fitting (曲线拟合)Assessor](Assessor/CurvefittingAssessor.md),通过曲线拟合的策略来实现提前终止 Trial。 * [权重共享的](https://github.com/microsoft/nni/blob/v0.5/docs/AdvancedNAS.md)高级支持:为 NAS Tuner 提供权重共享,当前支持 NFS。 #### 改进训练平台 * [FrameworkController 训练平台](TrainingService/FrameworkControllerMode.md):支持使用在 Kubernetes 上使用 FrameworkController 运行。 * FrameworkController 是 Kubernetes 上非常通用的控制器(Controller),能用来运行基于各种机器学习框架的分布式作业,如 TensorFlow,Pytorch, MXNet 等。 * NNI 为作业定义了统一而简单的规范。 * 如何使用 FrameworkController 的 MNIST 示例。 #### 改进用户体验 * 为 OpenPAI, Kubeflow 和 FrameworkController 模式提供更好的日志支持。 * 改进后的日志架构能将尝试的 stdout/stderr 通过 HTTP POST 方式发送给 NNI 管理器。 NNI 管理器将 Trial 的 stdout/stderr 消息存储在本地日志文件中。 * 在 WEB 界面上显示 Trial 日志的链接。 * 支持将最终结果显示为键值对。 ## 发布 0.4.1 - 12/14/2018 ### 主要功能 #### 支持新的 Tuner * 支持新的 [network morphism](Tuner/NetworkmorphismTuner.md) Tuner。 #### 改进训练平台 * 将 [Kubeflow 训练平台](TrainingService/KubeflowMode.md)的依赖从 kubectl CLI 迁移到 [Kubernetes API](https://kubernetes.io/docs/concepts/overview/kubernetes-api/) 客户端。 * Kubeflow 训练平台支持 [Pytorch-operator](https://github.com/kubeflow/pytorch-operator)。 * 改进将本地代码文件上传到 OpenPAI HDFS 的性能。 * 修复 OpenPAI 在 WEB 界面的 Bug:当 OpenPAI 认证过期后,Web 界面无法更新 Trial 作业的状态。 #### 改进 NNICTL * 在 nnictl 和 WEB 界面中显示 NNI 的版本信息。 可使用 **nnictl -v** 来显示安装的 NNI 版本。 #### 改进 WEB 界面 * 在 Experiment 运行中可修改并发数量 * 增加指向 NNI Github 的反馈链接,可直接创建问题 * 可根据指标,定制选择(最大或最小)的前 10 个 Trial。 * 为 dispatcher 和 nnimanager 提供下载日志的功能 * 为指标数值图提供自动缩放的数轴 * 改进 Annotation,支持在搜索空间中显示实际的选项 ### 新示例 * [FashionMnist](https://github.com/microsoft/nni/tree/master/examples/trials/network_morphism),使用 network morphism Tuner * 使用 PyTorch 的[分布式 MNIST 示例](https://github.com/microsoft/nni/tree/master/examples/trials/mnist-distributed-pytorch) ## 发布 0.4 - 12/6/2018 ### 主要功能 * [Kubeflow 训练平台](TrainingService/KubeflowMode.md) * 支持 tf-operator * 使用 Kubeflow 的[分布式 Trial 示例](https://github.com/microsoft/nni/tree/master/examples/trials/mnist-distributed/dist_mnist.py) * [遍历搜索 Tuner](Tuner/GridsearchTuner.md) * [Hyperband Tuner](Tuner/HyperbandAdvisor.md) * 支持在 MAC 上运行 NNI Experiment * Web 界面 * 支持 hyperband Tuner * 移除 tensorboard 按钮 * 显示 Experiment 的错误消息 * 显示搜索空间和 Trial 配置的行号 * 支持通过指定的 Trial id 来搜索 * 显示 Trial 的 hdfsLogPath * 下载 Experiment 参数 ### 其它 * 异步调度 * 更新 Docker 文件,增加 pytorch 库 * 重构 'nnictl stop' 过程,发送 SIGTERM 给 NNI 管理器进程,而不是调用停止 Restful API. * 修复 OpenPAI 训练平台的 Bug * 在 NNI 管理器中为 OpenPAI 集群配置文件支持 IP 配置(nniManagerIp),来修复用户计算机没有 eth0 设备的问题。 * codeDir 中的文件数量上限改为1000,避免用户无意中填写了 root 目录。 * 移除 OpenPAI 作业的 stdout 日志中无用的 ‘metrics is empty’。 在新指标被记录时,仅输出有用的消息,来减少用户检查 OpenPAI Trial 输出时的困惑。 * 在 Trial keeper 的开始增加时间戳。 ## 发布 0.3.0 - 11/2/2018 ### NNICTL 的新功能和更新 * 支持同时运行多个 Experiment。 在 v0.3 以前,NNI 仅支持一次运行一个 Experiment。 此版本开始,用户可以同时运行多个 Experiment。 每个 Experiment 都需要一个唯一的端口,第一个 Experiment 会像以前版本一样使用默认端口。 需要为其它 Experiment 指定唯一端口: ```bash nnictl create --port 8081 --config ``` * 支持更新最大 Trial 的数量。 使用 `nnictl update --help` 了解详情。 或参考 [NNICTL](Tutorial/Nnictl.md) 查看完整帮助。 ### API 的新功能和更新 * 不兼容的改动:nn.get_parameters() 改为 nni.get_next_parameter。 所有以前版本的示例将无法在 v0.3 上运行,需要重新克隆 NNI 代码库获取新示例。 如果在自己的代码中使用了 NNI,也需要相应的更新。 * 新 API **nni.get_sequence_id()**。 每个 Trial 任务都会被分配一个唯一的序列数字,可通过 nni.get_sequence_id() API 来获取。 ```bash git clone -b v0.3 https://github.com/microsoft/nni.git ``` * **nni.report_final_result(result)** API 对结果参数支持更多的数据类型。 可用类型: * int * float * 包含有 'default' 键值的 dict,'default' 的值必须为 int 或 float。 dict 可以包含任何其它键值对。 ### 支持新的 Tuner * **Batch Tuner(批处理调参器)** 会执行所有超参组合,可被用来批量提交 Trial 任务。 ### 新示例 * 公开的 NNI Docker 映像: ```bash docker pull msranni/nni:latest ``` * 新的 Trial 示例:[NNI Sklearn 示例](https://github.com/microsoft/nni/tree/master/examples/trials/sklearn) * 新的竞赛示例:[Kaggle Competition TGS Salt](https://github.com/microsoft/nni/tree/master/examples/trials/kaggle-tgs-salt) ### 其它 * 界面重构,参考[网页文档](Tutorial/WebUI.md),了解如何使用新界面。 * 持续集成:NNI 已切换到 Azure pipelines。 ## 发布 0.2.0 - 9/29/2018 ### 主要功能 * 支持 [OpenPAI](https://github.com/microsoft/pai) (又称 pai) 训练平台 (参考[这里](TrainingService/PaiMode.md)来了解如何在 OpenPAI 下提交 NNI 任务) * 支持 pai 模式的训练平台。 NNI Trial 可发送至 OpenPAI 集群上运行 * NNI Trial 输出 (包括日志和模型文件) 会被复制到 OpenPAI 的 HDFS 中。 * 支持 [SMAC](https://www.cs.ubc.ca/~hutter/papers/10-TR-SMAC.pdf) Tuner (参考[这里](Tuner/SmacTuner.md),了解如何使用 SMAC Tuner) * [SMAC](https://www.cs.ubc.ca/~hutter/papers/10-TR-SMAC.pdf) 基于 Sequential Model-Based Optimization (SMBO). 它会利用使用过的结果好的模型(高斯随机过程模型),并将随机森林引入到 SMBO 中,来处理分类参数。 NNI 的 SMAC 通过包装 [SMAC3](https://github.com/automl/SMAC3) 来支持。 * 支持将 NNI 安装在 [conda](https://conda.io/docs/index.html) 和 Python 虚拟环境中。 * 其它 * 更新 ga squad 示例与相关文档 * 用户体验改善及 Bug 修复 ## 发布 0.1.0 - 9/10/2018 (首个版本) 首次发布 Neural Network Intelligence (NNI)。 ### 主要功能 * 安装和部署 * 支持 pip 和源代码安装 * 支持本机(包括多 GPU 卡)训练和远程多机训练模式 * Tuner ,Assessor 和 Trial * 支持的自动机器学习算法包括: hyperopt_tpe, hyperopt_annealing, hyperopt_random, 和 evolution_tuner。 * 支持 Assessor(提前终止)算法包括:medianstop。 * 提供 Python API 来自定义 Tuner 和 Assessor * 提供 Python API 来包装 Trial 代码,以便能在 NNI 中运行 * Experiment * 提供命令行工具 'nnictl' 来管理 Experiment * 提供网页界面来查看并管理 Experiment * 持续集成 * 使用 Ubuntu 的 [travis-ci](https://github.com/travis-ci) 来支持持续集成 * 其它 * 支持简单的 GPU 任务调度