码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • NNI自动调参工具


    官方文档:https://nni.readthedocs.io/zh/stable/

    官方文档中的命令行自动调参写的并不十分明白,为避免后来人踩坑,做此纪录。
    总结一下,按三步走即可,十分方便。

    step.1 修改源代码

    假设源文件train.py中的超参数由如下代码获得

    args = args.parse_args()
    a = args.P_a
    b = args.P_b
    c = args.P_c
    
    • 1
    • 2
    • 3
    • 4

    那么你日常训练model的命令为:

    python train.py --P_a 0.1 --P_b 1 --P_c niubi
    
    • 1

    利用NNI进行自动调参时,需要修改源码,如下示例。注意get_next_parameter()返回字典类型!!!

    import nni
    args= nni.get_next_parameter()
    a = args["P_a"] # 字典类型!!!
    b = args["P_b"]
    c = args["P_c"]
    
    • 1
    • 2
    • 3
    • 4
    • 5

    然后在评估模型时,用nni.report_intermediate_result()提交当前结果
    用nni.report_final_result()提交最终(一般为最优)结果

    nni.report_intermediate_result(score)
    nni.report_final_result(best_score)
    
    • 1
    • 2

    step.2 创建config.yaml

    参考该说明设置需要调整超参数的type和value

    search_space:
      P_a:
        _type: uniform
        _value: [ 0, 1 ]
      P_a:
        _type: quniform
        _value: [ 0, 5, 1]
      P_c:
        _type: choice
        _value: ["niubi","niubi_plus"]
    
    trial_command: python train.py
    trial_code_directory: .
    
    trial_concurrency: 1
    max_trial_number: 100
    
    tuner:
      name: TPE
      class_args:
        optimize_mode: maximize
    
    training_service:
      platform: local
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    step.3 运行NNICTL命令

    运行nnictl create,端口可自行设置

    nnictl create --config config.yaml --port 8080
    
    • 1

    打开网页http://127.0.0.1:8080(或远程服务器主机地址:8080)即可看到运行情况

    后记

    如果运行Failed,可以参考下图看看命令行输出的报错信息,快速定位错误原因。

    再次感谢microsoft的NNI团队为炼丹事业所做出的巨大贡献!

  • 相关阅读:
    基于springboot的在线小说阅读平台设计与实现-计算机毕业设计源码+LW文档
    LeetCode——622.设计循环队列
    TI的单芯片毫米波雷达传感器配置命令是如何传递到DSP和ARM核的?(串口程序代码走读)
    Word2Vec详解
    基于YOLOv8的多目标检测与自动标注软件【python源码+PyqtUI界面+exe文件】【深度学习】
    pandas 将一行拆分为多行,将多行合并为一行
    分享5款小而精的实用软件
    MyBatis的简介和核心的组件(映射器、执行器、SqlSession及其工厂)
    2. 多机多卡运行nccl-tests对比分析
    CSS常见布局方式
  • 原文地址:https://blog.csdn.net/zhongzhehua/article/details/125486518
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号